From f52cfc92db48d9a215d7f728ce4000de1cdd6ae2 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Tue, 10 Sep 2024 09:55:31 +0800 Subject: [PATCH] 增加会员升级日志打印 --- src/main/java/cc/mrbird/febs/pay/controller/UnipayController.java | 128 +++++++++++++++++++++++++++++++----------- 1 files changed, 95 insertions(+), 33 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/pay/controller/UnipayController.java b/src/main/java/cc/mrbird/febs/pay/controller/UnipayController.java index 4e1bcda..d3a7a68 100644 --- a/src/main/java/cc/mrbird/febs/pay/controller/UnipayController.java +++ b/src/main/java/cc/mrbird/febs/pay/controller/UnipayController.java @@ -5,19 +5,16 @@ import cc.mrbird.febs.common.enumerates.FlowTypeEnum; import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum; import cc.mrbird.febs.common.enumerates.OrderStatusEnum; +import cc.mrbird.febs.common.exception.FebsException; +import cc.mrbird.febs.common.utils.LoginUserUtil; import cc.mrbird.febs.mall.dto.RegisterAppealDto; import cc.mrbird.febs.mall.entity.*; -import cc.mrbird.febs.mall.mapper.MallGoodsMapper; -import cc.mrbird.febs.mall.mapper.MallGoodsSkuMapper; -import cc.mrbird.febs.mall.mapper.MallMemberMapper; -import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper; +import cc.mrbird.febs.mall.mapper.*; import cc.mrbird.febs.mall.service.IApiMallMemberService; import cc.mrbird.febs.mall.service.IApiMallMemberWalletService; import cc.mrbird.febs.mall.service.IMallAchieveService; import cc.mrbird.febs.mall.service.IMallMoneyFlowService; -import cc.mrbird.febs.pay.model.AgreeMentPayCallBackDto; -import cc.mrbird.febs.pay.model.AgreeMentPaySmsDto; -import cc.mrbird.febs.pay.model.UniPayCallBackDto; +import cc.mrbird.febs.pay.model.*; import cc.mrbird.febs.pay.service.UnipayService; import cc.mrbird.febs.pay.util.JsonUtil; import cc.mrbird.febs.rabbit.producter.AgentProducer; @@ -27,6 +24,7 @@ import cn.hutool.core.util.StrUtil; import cn.hutool.json.JSONObject; import cn.hutool.json.JSONUtil; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.RequiredArgsConstructor; @@ -71,6 +69,16 @@ private MallMemberMapper memberMapper; @Autowired private UnipayService unipayService; + @Autowired + private MallMemberBankMapper mallMemberBankMapper; + @Autowired + private MallMemberBankSignMapper mallMemberBankSignMapper; + @Autowired + private MallMemberWithdrawMapper mallMemberWithdrawMapper; + @Autowired + private MallMoneyFlowMapper mallMoneyFlowMapper; + + private final IApiMallMemberWalletService iApiMallMemberWalletService; @GetMapping(value = "/unipayCallBack") public String unipayCallBack(HttpServletRequest request, UniPayCallBackDto uniPayCallBackDto){ @@ -123,7 +131,7 @@ MallMember mallMember = memberMapper.selectById(orderInfo.getMemberId()); if (hasTc) { if (AgentLevelEnum.ZERO_LEVEL.name().equals(mallMember.getLevel())) { - mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name()); + mallMember.setLevel(AgentLevelEnum.SECOND_LEVEL.name()); memberMapper.updateById(mallMember); } } @@ -137,23 +145,6 @@ return "success"; } -// public static void main(String[] args) { -// String output = "https://www.baidu.com?r1_MerchantNo=888000000000000&r2_OrderNo=2020100000000000000&r3_Amount=10.00&r4_Cur=1&r5_Mp=goods&r6_Status=100&r7_TrxNo=100220100000000000&r8_BankOrderNo=100220100000000000&r9_BankTrxNo=4200000000202000000000000000&ra_PayTime=2022-08-11%2B16%253A14%253A39&rb_DealTime=2022-08-11%2B16%253A14%253A39&rc_BankCode=WEIXI_GZH&hmac=14c3819b5cc7bb80635901934f76c7a4"; -// String params = StrUtil.subAfter(output, "?", true); -// System.out.println(params); -// List<String> paramStrList = StrUtil.splitTrim(params, "&"); -// String orderNo = ""; -// if(CollUtil.isNotEmpty(paramStrList)){ -// for(String paramStr :paramStrList){ -// boolean r2_orderNo = paramStr.startsWith("r2_OrderNo"); -// if(r2_orderNo){ -// orderNo = StrUtil.subAfter(paramStr, "=", true); -// } -// } -// } -// System.out.println(orderNo); -// } - @ApiOperation(value = "获取协议支付签约短信", notes = "获取协议支付签约短信") @PostMapping(value = "getAgreeMentPaySms") public FebsResponse getAgreeMentPaySms(@RequestBody AgreeMentPaySmsDto agreeMentPaySmsDto) { @@ -165,13 +156,39 @@ } } -// public static void main(String[] args) { -// String data = "{\\\"bank_trx_no\\\":\\\"0825144603229910\\\",\\\"jp_order_no\\\":\\\"100120220825446322447537651712\\\",\\\"mch_order_no\\\":\\\"2022082514435329133\\\",\\\"order_amount\\\":0.10,\\\"order_desc\\\":\\\"测试\\\",\\\"order_status\\\":\\\"P1000\\\",\\\"pay_success_time\\\":\\\"2022-08-25 14:46:04\\\"}"; -// JSONObject jsonObject = JSONUtil.parseObj(data); -// String orderNo = jsonObject.get("mch_order_no").toString(); -// String pay_success_time = jsonObject.get("pay_success_time").toString(); -// System.out.println(orderNo +"222"+pay_success_time); -// } + @ApiOperation(value = "协议支付签约短信签约", notes = "协议支付签约短信签约") + @PostMapping(value = "agreeMentPaySmsSign") + public FebsResponse agreeMentPaySmsSign(@RequestBody AgreementSignDto agreementSignDto) { + String agreeMentPaySms = unipayService.agreementSign(agreementSignDto); + if("fail".equals(agreeMentPaySms)){ + return new FebsResponse().fail().message("签约失败,请重新下单"); + }else{ + JSONObject jsonObject = JSONUtil.parseObj(agreeMentPaySms); + String resultStr = (String) jsonObject.get("biz_code"); + String signData = (String) jsonObject.get("data"); + String signBizMsg = (String) jsonObject.get("biz_msg"); + if(StrUtil.isNotBlank(signData)){ + JSONObject signDatajsonObject = JSONUtil.parseObj(signData); + String err_msg = (String) signDatajsonObject.get("err_msg"); + if(ObjectUtil.isNotNull(signDatajsonObject.get("err_code"))){ + return new FebsResponse().fail().message(err_msg+"签约失败,请重新下单"); + } + } + if(!"JS000000".equals(resultStr)){ + return new FebsResponse().fail().message(signBizMsg+"签约失败,请重新下单"); + }else{ + MallMember member = LoginUserUtil.getLoginUser(); + Long bankId = agreementSignDto.getBankId(); + MallMemberBank mallMemberBank = mallMemberBankMapper.selectById(bankId); + String bankNo = mallMemberBank.getBankNo(); + MallMemberBankSign mallMemberBankSign = new MallMemberBankSign(); + mallMemberBankSign.setMemberId(member.getId()); + mallMemberBankSign.setBankCardNo(bankNo); + mallMemberBankSignMapper.insert(mallMemberBankSign); + return new FebsResponse().success().message(signBizMsg); + } + } + } @PostMapping(value = "/agreeMentPayCallBack") public String agreeMentPayCallBack(@RequestBody AgreeMentPayCallBackDto agreeMentPayCallBackDto){ @@ -227,7 +244,7 @@ MallMember mallMember = memberMapper.selectById(orderInfo.getMemberId()); if (hasTc) { if (AgentLevelEnum.ZERO_LEVEL.name().equals(mallMember.getLevel())) { - mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name()); + mallMember.setLevel(AgentLevelEnum.SECOND_LEVEL.name()); memberMapper.updateById(mallMember); } } @@ -241,4 +258,49 @@ return "success"; } + @PostMapping(value = "/singlePayCallBack") + public JSONObject singlePayCallBack(@RequestBody SinglePayCallBackDto singlePayCallBackDto){ + log.info("进入汇聚支付代付回调"+ JSONUtil.parseObj(singlePayCallBackDto)); + String status = singlePayCallBackDto.getStatus(); + BigDecimal paidAmount = singlePayCallBackDto.getPaidAmount(); + BigDecimal paidAmountFee = singlePayCallBackDto.getFee(); + String errorCode = singlePayCallBackDto.getErrorCode(); + String errorCodeDesc = singlePayCallBackDto.getErrorCodeDesc(); + String merchantOrderNo = singlePayCallBackDto.getMerchantOrderNo(); + + log.info("进入汇聚支付代付回调"+status+";"+paidAmount+";"+paidAmountFee+";"); + if("205".equals(status) && "".equals(errorCode)){ + QueryWrapper<MallMemberWithdraw> objectQueryWrapper = new QueryWrapper<>(); + objectQueryWrapper.eq("withdraw_no",merchantOrderNo); + MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectOne(objectQueryWrapper); + if(ObjectUtil.isNotEmpty(mallMemberWithdraw)){ + mallMemberWithdraw.setStatus(2); + mallMemberWithdrawMapper.updateById(mallMemberWithdraw); + + QueryWrapper<MallMoneyFlow> flowQueryWrapper = new QueryWrapper<>(); + flowQueryWrapper.eq("order_no",mallMemberWithdraw.getWithdrawNo()); + flowQueryWrapper.eq("type",MoneyFlowTypeEnum.WITHDRAWAL.getValue()); + MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOne(flowQueryWrapper); + if(ObjectUtil.isNotEmpty(mallMoneyFlow)){ + mallMoneyFlow.setStatus(2); + mallMoneyFlowMapper.updateById(mallMoneyFlow); + } + } + }else{ + QueryWrapper<MallMemberWithdraw> objectQueryWrapper = new QueryWrapper<>(); + objectQueryWrapper.eq("withdraw_no",merchantOrderNo); + MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectOne(objectQueryWrapper); + if(ObjectUtil.isNotEmpty(mallMemberWithdraw)){ + mallMemberWithdraw.setRemark(errorCodeDesc); + mallMemberWithdrawMapper.updateById(mallMemberWithdraw); + } + } + + SinglePayCallBackVo singlePayCallBackVo = new SinglePayCallBackVo(); + singlePayCallBackVo.setStatusCode("2001"); + singlePayCallBackVo.setMessage("成功"); + JSONObject jsonObject = JSONUtil.parseObj(singlePayCallBackVo); + return jsonObject; + } + } -- Gitblit v1.9.1