From 29d9b3490f9deca91801be61aeeed9b8d7e432bb Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Thu, 01 Sep 2022 15:53:07 +0800
Subject: [PATCH] 20220822

---
 src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java |  182 +++++++++++++++++++++++++++++++++++++--------
 1 files changed, 149 insertions(+), 33 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 8fa7dbc..bed6f12 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
@@ -1,39 +1,41 @@
 package cc.mrbird.febs.pay.service.impl;
 
+import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
+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.RedisUtils;
-import cc.mrbird.febs.common.utils.SpringContextHolder;
-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.pay.model.BrandWCPayRequestData;
-import cc.mrbird.febs.pay.model.OrderStateDto;
-import cc.mrbird.febs.pay.model.OrderStateMsgVo;
-import cc.mrbird.febs.pay.model.WxTemplateData;
+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.*;
+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.*;
 import cc.mrbird.febs.pay.service.IXcxPayService;
 import cc.mrbird.febs.pay.util.WechatConfigure;
 import cc.mrbird.febs.pay.util.WeixinServiceUtil;
-import cn.binarywang.wx.miniapp.bean.WxMaSubscribeMessage;
-import cn.binarywang.wx.miniapp.config.impl.WxMaDefaultConfigImpl;
 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;
-import cn.hutool.log.Log;
-import com.alibaba.fastjson.JSON;
+import com.baomidou.dynamic.datasource.toolkit.Base64;
+import com.baomidou.mybatisplus.extension.exceptions.ApiException;
+import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.collections.CollectionUtils;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.beans.factory.annotation.Value;
+import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 import org.springframework.stereotype.Service;
 import org.springframework.web.client.RestTemplate;
 
-import java.io.IOException;
+import java.io.*;
 import java.math.BigDecimal;
+import java.net.*;
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
@@ -41,6 +43,7 @@
 
 @Slf4j
 @Service
+@RequiredArgsConstructor
 public class XcxPayServiceImpl implements IXcxPayService {
 
     @Autowired
@@ -52,11 +55,93 @@
     @Autowired
     private DataDictionaryCustomMapper dataDictionaryCustomMapper;
     @Autowired
-    RedisUtils redisUtils;
+    private MallMoneyFlowMapper mallMoneyFlowMapper;
     @Autowired
-    private SpringContextHolder springContextHolder;
+    private MallMemberWithdrawMapper mallMemberWithdrawMapper;
+    private final IMallMoneyFlowService mallMoneyFlowService;
+    @Autowired
+    RedisUtils redisUtils;
+
+    private final SpringContextHolder springContextHolder;
 
     private final XcxProperties xcxProperties = SpringContextHolder.getBean(XcxProperties.class);
+
+    @Override
+    public BrandWCPayRequestData startRechargeWallet(ApiRechargeWalletDto apiRechargeWalletDto) throws Exception {
+        BigDecimal unit = new BigDecimal("100");
+        BigDecimal money = new BigDecimal(apiRechargeWalletDto.getAmount().toString());
+        BrandWCPayRequestData payData;
+        String productNames = "小程序充值";
+        MallMember mallMember = mallMemberMapper.selectById(apiRechargeWalletDto.getMemberId());
+        String rechargeNo = "CZ."+MallUtils.getOrderNum();
+        Boolean debug = xcxProperties.getDebug();
+        String attrStr = "{'rechargeNo':"+rechargeNo+",'memberId':"+mallMember.getId()+"}";
+        if (debug) {
+            payData = weixinServiceUtil.createRechargeWallet("[测试]" + productNames, rechargeNo,
+                    1, mallMember.getOpenId(), attrStr);
+        } else {
+            payData = weixinServiceUtil.createRechargeWallet(productNames, rechargeNo,
+                    unit.multiply(money).intValue(),mallMember.getOpenId(), attrStr);
+        }
+        mallMoneyFlowService.addMoneyFlow(
+                mallMember.getId(),
+                money,
+                MoneyFlowTypeEnum.RECHARGE.getValue(),
+                rechargeNo,
+                FlowTypeEnum.BALANCE.getValue(),
+                "余额充值",1);
+        return payData;
+    }
+
+    @Override
+    public void rechargeWalletMessageSend(RechargeWalletMessageSendDto info) {
+        RestTemplate restTemplate = new RestTemplate();
+        String url =  WechatConfigure.SEND_INFO_URL  + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY);
+        //拼接推送的模版
+        RechargeWalletMessageSendVo orderStateMsgVo = new RechargeWalletMessageSendVo();
+        orderStateMsgVo.setTouser(info.getOpenId());//用户的openId
+        orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id
+        orderStateMsgVo.setPage(info.getPage());
+        Map<String, WxTemplateData> m = new HashMap<>(4);
+        m.put("character_string1", new WxTemplateData(info.getRechargeNo()));
+        m.put("amount3", new WxTemplateData(info.getRechargeAmount()));
+        m.put("amount4", new WxTemplateData(info.getBalance()));
+        m.put("date5", new WxTemplateData(info.getCreateTime()));
+        orderStateMsgVo.setData(m);
+        String s = JSONUtil.toJsonStr(orderStateMsgVo);
+        log.info(s);
+        ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, orderStateMsgVo, String.class);
+        log.info(responseEntity.getBody());
+
+    }
+
+    @Override
+    public Boolean memberWithdrawal(MemberWithdrawalDto 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 {
@@ -87,12 +172,11 @@
         orderStateMsgVo.setTouser(info.getOpenId());//用户的openId
         orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id
         orderStateMsgVo.setPage(info.getPage());
-        Map<String, WxTemplateData> m = new HashMap<>(5);
-        m.put("character_string1", new WxTemplateData(info.getOrderNo()));
-        m.put("thing9", new WxTemplateData(info.getGoodsName()));
-        m.put("phrase2", new WxTemplateData(info.getOrderState()));
-        m.put("thing13", new WxTemplateData(info.getAddressArea()));
-        m.put("thing16", new WxTemplateData(info.getTakeCode()));
+        Map<String, WxTemplateData> m = new HashMap<>(4);
+        m.put("character_string2", new WxTemplateData(info.getOrderNo()));
+        m.put("thing11", new WxTemplateData(info.getGoodsName()));
+        m.put("amount1", new WxTemplateData(info.getAmount()));
+        m.put("character_string9", new WxTemplateData(info.getTakeCode()));
         orderStateMsgVo.setData(m);
         String s = JSONUtil.toJsonStr(orderStateMsgVo);
         log.info(s);
@@ -137,12 +221,11 @@
         orderStateMsgVo.setTouser(info.getOpenId());//用户的openId
         orderStateMsgVo.setTemplate_id(info.getTemplateId());//订阅消息模板id
         orderStateMsgVo.setPage(info.getPage());
-        Map<String, WxTemplateData> m = new HashMap<>(5);
-        m.put("character_string1", new WxTemplateData(info.getOrderNo()));
-        m.put("thing9", new WxTemplateData(info.getGoodsName()));
-        m.put("phrase2", new WxTemplateData(info.getOrderState()));
-        m.put("thing13", new WxTemplateData(info.getAddressArea()));
-        m.put("thing16", new WxTemplateData(info.getTakeCode()));
+        Map<String, WxTemplateData> m = new HashMap<>(4);
+        m.put("character_string2", new WxTemplateData(info.getOrderNo()));
+        m.put("thing11", new WxTemplateData(info.getGoodsName()));
+        m.put("amount1", new WxTemplateData(info.getAmount()));
+        m.put("character_string9", new WxTemplateData(info.getTakeCode()));
         orderStateMsgVo.setData(m);
         String s = JSONUtil.toJsonStr(orderStateMsgVo);
         log.info(s);
@@ -162,6 +245,39 @@
         return wxTemplates;
     }
 
+    @Override
+    public FebsResponse generateQrCode(WxGenerateQrCodeDto wxGenerateQrCodeDto) {
+        String base64 = null;
+        try {
+            RestTemplate restTemplate = new RestTemplate();
+            String url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" + redisUtils.get(WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY);
+            Map<String, Object> params = new HashMap<>();
+            params.put("scene", wxGenerateQrCodeDto.getScene());
+            params.put("page", wxGenerateQrCodeDto.getPage());
+            params.put("width", 430);
+            ResponseEntity<byte[]> responseEntity = restTemplate.postForEntity(url, params, byte[].class);
+            if (responseEntity.getStatusCode() == HttpStatus.OK) {
+                byte[] body = responseEntity.getBody();
+                InputStream inputStream = new ByteArrayInputStream(body);
+                // 将获取流转为base64格式
+                byte[] data = null;
+                ByteArrayOutputStream swapStream = new ByteArrayOutputStream();
+                byte[] buff = new byte[100];
+                int rc = 0;
+                while ((rc = inputStream.read(buff, 0, 100)) > 0) {
+                    swapStream.write(buff, 0, rc);
+                }
+                data = swapStream.toByteArray();
+                base64 = Base64.byteArrayToBase64(data);
+                inputStream.close();
+                swapStream.close();
+            }
+        } catch (IOException e) {
+            throw new ApiException("生成二维码失败");
+        }
+        return new FebsResponse().success().data(base64);
+    }
+
     /**
      * 根据用户ID和订单ID获取所购买商品名称
      * @return 所含商品名称(多个以","隔开)

--
Gitblit v1.9.1