From 3064a503bc6d0030c1f812d57c4ba2cb7a650fea Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 02 Sep 2022 14:27:45 +0800
Subject: [PATCH] 20220822

---
 src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java |   50 ++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 38 insertions(+), 12 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
index 1d6ec95..b41bbb9 100644
--- a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java
@@ -5,19 +5,11 @@
 import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.properties.XcxProperties;
-import cc.mrbird.febs.common.utils.MallUtils;
-import cc.mrbird.febs.common.utils.OssUtils;
-import cc.mrbird.febs.common.utils.RedisUtils;
-import cc.mrbird.febs.common.utils.SpringContextHolder;
+import cc.mrbird.febs.common.utils.*;
 import cc.mrbird.febs.mall.dto.ApiRechargeWalletDto;
 import cc.mrbird.febs.mall.dto.RechargeWalletMessageSendDto;
-import cc.mrbird.febs.mall.entity.DataDictionaryCustom;
-import cc.mrbird.febs.mall.entity.MallMember;
-import cc.mrbird.febs.mall.entity.MallOrderInfo;
-import cc.mrbird.febs.mall.entity.MallOrderItem;
-import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
-import cc.mrbird.febs.mall.mapper.MallMemberMapper;
-import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
+import cc.mrbird.febs.mall.entity.*;
+import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.mall.vo.RechargeWalletMessageSendVo;
 import cc.mrbird.febs.pay.model.*;
@@ -26,6 +18,7 @@
 import cc.mrbird.febs.pay.util.WeixinServiceUtil;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.IdUtil;
+import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.json.JSONObject;
 import cn.hutool.json.JSONUtil;
@@ -61,6 +54,10 @@
     WeixinServiceUtil weixinServiceUtil;
     @Autowired
     private DataDictionaryCustomMapper dataDictionaryCustomMapper;
+    @Autowired
+    private MallMoneyFlowMapper mallMoneyFlowMapper;
+    @Autowired
+    private MallMemberWithdrawMapper mallMemberWithdrawMapper;
     private final IMallMoneyFlowService mallMoneyFlowService;
     @Autowired
     RedisUtils redisUtils;
@@ -76,7 +73,7 @@
         BrandWCPayRequestData payData;
         String productNames = "小程序充值";
         MallMember mallMember = mallMemberMapper.selectById(apiRechargeWalletDto.getMemberId());
-        String rechargeNo = "CZ."+MallUtils.getOrderNum();
+        String rechargeNo = "CZ_"+MallUtils.getOrderNum();
         Boolean debug = xcxProperties.getDebug();
         String attrStr = "{'rechargeNo':"+rechargeNo+",'memberId':"+mallMember.getId()+"}";
         if (debug) {
@@ -119,6 +116,35 @@
     }
 
     @Override
+    public Boolean memberWithdrawal(MemberWithdrawalDto info) {
+        log.info("后台同意提现申请..."+JSONUtil.toJsonStr(info));
+        boolean flag=false;
+        BigDecimal unit = new BigDecimal("100");
+        BigDecimal money = new BigDecimal(info.getTotalFee().toString());
+        String outTradeNo = info.getOutTradeNo();
+        String openid = info.getOpenid();
+        String desc = info.getDesc();
+
+        MallMember mallMember = mallMemberMapper.selectMemberByOpenId(openid);
+        if(ObjectUtil.isEmpty(mallMember)){
+            return flag;
+        }
+        MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectByWithDrawNoAndMemberIdAndState(outTradeNo,mallMember.getId(),1);
+        if(ObjectUtil.isEmpty(mallMemberWithdraw)){
+            return flag;
+        }
+        Boolean debug = xcxProperties.getDebug();
+        if (debug) {
+            flag = weixinServiceUtil.comPay("[测试]" + desc, outTradeNo,
+                    1, openid);
+        } else {
+            flag = weixinServiceUtil.comPay(desc, outTradeNo,
+                    unit.multiply(money).intValue(),openid);
+        }
+        return flag;
+    }
+
+    @Override
     public BrandWCPayRequestData startPayment(MallOrderInfo mallOrderInfo) throws Exception {
         BigDecimal unit = new BigDecimal("100");
         BigDecimal money = new BigDecimal(mallOrderInfo.getAmount().toString());

--
Gitblit v1.9.1