From e94e6721a4aeb8c21e97878239ec3429fc76d1ad Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Mon, 08 May 2023 14:23:45 +0800 Subject: [PATCH] 创建订单之前的判断修改 --- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java | 104 +++++++++++++++++++++++++++++++--------------------- 1 files changed, 62 insertions(+), 42 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java index 8a17ee8..d23ad06 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java @@ -17,9 +17,11 @@ import cc.mrbird.febs.mall.vo.*; import cc.mrbird.febs.pay.model.AgreementPayDto; import cc.mrbird.febs.pay.model.AgreementSignDto; +import cc.mrbird.febs.pay.model.LaKaLaCreateOrderReqDate; import cc.mrbird.febs.pay.model.UnipayDto; import cc.mrbird.febs.pay.service.IAliPayService; import cc.mrbird.febs.pay.service.IPayService; +import cc.mrbird.febs.pay.service.LaKaLaService; import cc.mrbird.febs.pay.service.UnipayService; import cc.mrbird.febs.rabbit.producter.AgentProducer; import cn.hutool.core.collection.CollUtil; @@ -72,6 +74,7 @@ private final IMallAchieveService mallAchieveService; private final UnipayService unipayService; private final IPayService wechatPayService; + private final LaKaLaService laKaLaService; private final MallMemberBankSignMapper mallMemberBankSignMapper; private final MallMemberBankMapper mallMemberBankMapper; @@ -293,35 +296,49 @@ orderInfo.setPayResult("2"); break; case "2": -// if (StrUtil.isNotBlank(orderInfo.getPayOrderNo())) { -// payResultStr = orderInfo.getPayOrderNo(); -// } else { -// payResultStr = payService.aliPay(orderInfo); + LaKaLaCreateOrderReqDate laKaLaCreateOrderReqDate = new LaKaLaCreateOrderReqDate(); + //订单编号 + laKaLaCreateOrderReqDate.setOut_order_no(orderInfo.getOrderNo()); + //订单金额,分计 + laKaLaCreateOrderReqDate.setTotal_amount(orderInfo.getAmount().multiply(new BigDecimal(100)).longValue()); + List<MallOrderItem> itemsLKL = orderInfo.getItems(); + //商品名称 + if(CollUtil.isEmpty(itemsLKL)){ + laKaLaCreateOrderReqDate.setOrder_info("商品"); + }else{ + laKaLaCreateOrderReqDate.setOrder_info(itemsLKL.get(0).getGoodsName()); + } + payResultStr = laKaLaService.verifyCreateOrder(laKaLaCreateOrderReqDate); + JSONObject parseObj = JSONUtil.parseObj(payResultStr); + String code = parseObj.get("code").toString(); + if (!"true".equals(code)) { + throw new FebsException("跳转收银台失败"); + } + + orderInfo.setPayOrderNo(parseObj.get("payOrderNo").toString()); + orderInfo.setPayMethod("拉卡拉支付"); + orderInfo.setPayResult("2"); +// UnipayDto unipayDto = new UnipayDto(); +// unipayDto.setAmount(orderInfo.getAmount()); +// unipayDto.setFrpCode("ALIPAY_H5"); +// unipayDto.setTradeMerchantNo("777184100385821"); +// unipayDto.setOrderNo(orderInfo.getOrderNo()); +// List<MallOrderItem> items = orderInfo.getItems(); +// if(CollUtil.isEmpty(items)){ +// unipayDto.setProductName("商品"); +// }else{ +// unipayDto.setProductName(items.get(0).getGoodsName()); // } - UnipayDto unipayDto = new UnipayDto(); -// unipayDto.setAmount(new BigDecimal("0.01")); - unipayDto.setAmount(orderInfo.getAmount()); - unipayDto.setFrpCode("ALIPAY_H5"); - unipayDto.setTradeMerchantNo("777184100385821"); - unipayDto.setOrderNo(orderInfo.getOrderNo()); - List<MallOrderItem> items = orderInfo.getItems(); - if(CollUtil.isEmpty(items)){ - unipayDto.setProductName("商品"); - }else{ - unipayDto.setProductName(items.get(0).getGoodsName()); - } - String unipayStr = unipayService.unipay(unipayDto); - if("fail" == unipayStr){ - throw new FebsException("支付失败"); - }else{ -// JSONUtil.parseObj(unipayStr); - JSONObject jsonObject = JSONUtil.parseObj(unipayStr); - payResultStr = (String) jsonObject.get("r7_TrxNo"); - rcResult = (String) jsonObject.get("rc_Result"); - } - orderInfo.setPayOrderNo(payResultStr); - orderInfo.setPayMethod("支付宝支付"); -// agentProducer.sendOrderReturn(orderInfo.getId()); +// String unipayStr = unipayService.unipay(unipayDto); +// if("fail" == unipayStr){ +// throw new FebsException("支付失败"); +// }else{ +// JSONObject jsonObject = JSONUtil.parseObj(unipayStr); +// payResultStr = (String) jsonObject.get("r7_TrxNo"); +// rcResult = (String) jsonObject.get("rc_Result"); +// } +// orderInfo.setPayOrderNo(payResultStr); +// orderInfo.setPayMethod("支付宝支付"); break; case "3": payResultStr = balancePay(orderInfo, payOrderDto.getTradePwd(), "balance"); @@ -732,20 +749,6 @@ if(prizeScore.compareTo(score) < 0){ throw new FebsException("积分不足"); } - if(hasTc){ - //系统设置的个人贡献点最大值 - DataDictionaryCustom starGetDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( - DataDictionaryEnum.STAR_GET.getType(), - DataDictionaryEnum.STAR_GET.getCode()); - if(ObjectUtil.isNotEmpty(starGetDic)){ - String starGetStr = StrUtil.isEmpty(starGetDic.getValue()) ? "0" : starGetDic.getValue(); - BigDecimal starGet = new BigDecimal(starGetStr); - BigDecimal star = new BigDecimal(mallMemberWallet.getStar()); - if(starGet.compareTo(BigDecimal.ZERO) != 0 && starGet.compareTo(star) <= 0){ - throw new FebsException("无法购买套餐"); - } - } - } /** * 使用积分折扣现金 */ @@ -764,6 +767,23 @@ if(scorePercentMaxAmount.compareTo(score) < 0){ throw new FebsException("最多可使用"+scorePercentMaxAmount+"积分"); } + + if(hasTc){ + //系统设置的个人贡献点最大值 + DataDictionaryCustom starGetDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.STAR_GET.getType(), + DataDictionaryEnum.STAR_GET.getCode()); + if(ObjectUtil.isNotEmpty(starGetDic)){ + String starGetStr = StrUtil.isEmpty(starGetDic.getValue()) ? "0" : starGetDic.getValue(); + BigDecimal starGet = new BigDecimal(starGetStr); + BigDecimal star = new BigDecimal(mallMemberWallet.getStar()); + if(starGet.compareTo(BigDecimal.ZERO) != 0 && starGet.compareTo(star) <= 0){ + + return new FebsResponse().success().message("购买套餐不会获得贡献点"); +// throw new FebsException("无法购买套餐"); + } + } + } return new FebsResponse().success(); } -- Gitblit v1.9.1