From c4bf5ac4f2316110c416fbf4cdec1dddc91f5860 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Thu, 12 Oct 2023 10:44:20 +0800 Subject: [PATCH] redbagprod --- src/main/java/cc/mrbird/febs/pay/controller/UnipayController.java | 149 ++++++++++++++++++++++++++++++++++++------------- 1 files changed, 108 insertions(+), 41 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 58321a5..49a2210 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,7 +24,10 @@ 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; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; @@ -43,6 +43,8 @@ @Slf4j @RestController @RequestMapping(value = "/api/unipay") +@RequiredArgsConstructor +@Api(value = "ApiMallMemberController", tags = "支付接口类") public class UnipayController { @Autowired @@ -67,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){ @@ -125,45 +137,56 @@ } mallMoneyFlowService.addMoneyFlow(mallMember.getId(), orderInfo.getAmount().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue()); - agentProducer.sendAutoLevelUpMsg(mallMember.getId()); - agentProducer.sendOrderReturn(orderInfo.getId()); } } } 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) { + String agreeMentPaySms = unipayService.getAgreeMentPaySms(agreeMentPaySmsDto); + if("JS000000".equals(agreeMentPaySms)){ + return new FebsResponse().success().message("获取成功"); + }else{ + return new FebsResponse().fail().message(agreeMentPaySms); + } + } -// @ApiOperation(value = "获取协议支付签约短信", notes = "获取协议支付签约短信") -// @PostMapping(value = "getAgreeMentPaySms") -// public FebsResponse getAgreeMentPaySms(@RequestBody AgreeMentPaySmsDto agreeMentPaySmsDto) { -// unipayService.getAgreeMentPaySms(agreeMentPaySmsDto); -// return new FebsResponse().success().message("申请成功"); -// } - -// 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){ @@ -186,6 +209,7 @@ orderInfo.setPayResult("1"); orderInfo.setPayTime(DateUtil.parse(pay_success_time)); orderInfo.setPayTradeNo(jp_order_no); + orderInfo.setPayOrderNo(orderNo); orderInfoMapper.updateById(orderInfo); boolean hasTc = false; @@ -224,12 +248,55 @@ } mallMoneyFlowService.addMoneyFlow(mallMember.getId(), orderInfo.getAmount().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue()); - agentProducer.sendAutoLevelUpMsg(mallMember.getId()); - agentProducer.sendOrderReturn(orderInfo.getId()); } } } 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