From 6edbf12f8d6fc4d8da1161b77ea9703ecb3b0f64 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Thu, 20 Jul 2023 14:44:57 +0800
Subject: [PATCH] 支付返利,微信余额支付会有返利。发卷,赠送积分逻辑

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java |  151 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 147 insertions(+), 4 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
index 694cdee..709dec4 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
@@ -2,9 +2,11 @@
 
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.enumerates.AgentLevelEnum;
+import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
 import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.exception.FebsException;
 import cc.mrbird.febs.common.utils.AppContants;
+import cc.mrbird.febs.common.utils.HttpCurlUtil;
 import cc.mrbird.febs.common.utils.ShareCodeUtil;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
@@ -16,20 +18,25 @@
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.crypto.SecureUtil;
+import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
 import jdk.nashorn.internal.ir.IfNode;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
+import org.springframework.http.HttpHeaders;
 import org.springframework.http.HttpStatus;
+import org.springframework.http.MediaType;
+import org.springframework.http.converter.StringHttpMessageConverter;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
+import org.springframework.web.client.RestTemplate;
 
+import javax.annotation.Resource;
+import java.io.IOException;
 import java.math.BigDecimal;
 import java.math.RoundingMode;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.nio.charset.Charset;
+import java.util.*;
 
 /**
  * @author wzy
@@ -43,6 +50,12 @@
     private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
     private final MallMemberMapper memberMapper;
     private final MallMemberWalletMapper mallMemberWalletMapper;
+    private final RestTemplate restTemplate;
+    private final MallOrderInfoMapper mallOrderInfoMapper;
+    private final MallOrderItemMapper mallOrderItemMapper;
+    private final MallGoodsMapper mallGoodsMapper;
+    private final IApiMallMemberWalletService memberWalletService;
+    private final MallRollPerkMapper mallRollPerkMapper;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -283,4 +296,134 @@
         mallMemberWalletMapper.insert(wallet);
         return;
     }
+
+    @Override
+    public void updateMemberInfo(String str) {
+        String[] split = StrUtil.split(str, "|");
+        String accessToken = split[0];
+        String openId = split[1];
+        MallMember mallMember = memberMapper.selectMemberByOpenId(openId);
+        if (ObjectUtil.isEmpty(mallMember)) {
+            return;
+        }
+        String requrl = "https://api.weixin.qq.com/sns/userinfo?access_token="+accessToken+"&openid="+openId+"&lang=zh_CN";
+
+        // 创建一个StringHttpMessageConverter,并设置字符集为UTF-8
+        StringHttpMessageConverter stringConverter = new StringHttpMessageConverter(Charset.forName("UTF-8"));
+        stringConverter.setSupportedMediaTypes(Collections.singletonList(MediaType.TEXT_PLAIN));
+        // 将StringHttpMessageConverter添加到RestTemplate的消息转换器列表中
+        restTemplate.getMessageConverters().add(0, stringConverter);
+        // 创建HttpHeaders对象,设置Accept头部的值为"text/plain;charset=UTF-8"
+        HttpHeaders headers = new HttpHeaders();
+        headers.setAccept(Collections.singletonList(MediaType.TEXT_PLAIN));
+        headers.set(HttpHeaders.ACCEPT_CHARSET, "UTF-8");
+
+        String responseStr = restTemplate.getForObject(requrl, String.class);
+        net.sf.json.JSONObject json = net.sf.json.JSONObject.fromObject(responseStr);
+        log.info("微信获取用户信息={}", json);
+
+        if (json.containsKey("errcode")) {
+            log.info("微信登录获取到异常信息errcode");
+            return;
+        }
+        String nickname = json.getString("nickname");
+        String headImgUrl = json.getString("headimgurl");
+        mallMember.setName(nickname);
+        mallMember.setAvatar(headImgUrl);
+        memberMapper.updateById(mallMember);
+        return;
+    }
+
+
+    @Override
+    public void orderGetMsg(String str) {
+        /**
+         * String str : orderId@amount
+         */
+        String[] split = StrUtil.split(str, "@");
+        String orderId = split[0];
+        String amount = split[1];
+        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId);
+        if(ObjectUtil.isEmpty(mallOrderInfo)){
+            return;
+        }
+        Long memberId = mallOrderInfo.getMemberId();
+        MallMember mallMember = memberMapper.selectById(memberId);
+
+
+        List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(mallOrderInfo.getId());
+        if(CollUtil.isEmpty(mallOrderItemList)){
+            return;
+        }
+
+        /**
+         * 支付后同意验证
+         *  1:是否送券
+         *  2:是否送积分
+         *  3:是否返利
+         */
+        //是否返利
+        BigDecimal amountBigDecimal = new BigDecimal(StrUtil.isEmpty(amount) ? "0" : amount);
+        if(BigDecimal.ZERO.compareTo(amountBigDecimal) < 0){
+            if(ObjectUtil.isNotEmpty(mallMember.getReferrerId())){
+                String referrerId = mallMember.getReferrerId();
+                MallMember mallMemberParent = memberMapper.selectInfoByInviteId(referrerId);
+                Long id = mallMemberParent.getId();
+                DataDictionaryCustom returnPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                        DataDictionaryEnum.MEMBER_RETURN_PERCENT.getType(),
+                        DataDictionaryEnum.MEMBER_RETURN_PERCENT.getCode()
+                );
+                String returnPercentStr = StrUtil.isNotEmpty(returnPercentDic.getValue()) ? "1" : returnPercentDic.getValue();
+                BigDecimal returnPercent = new BigDecimal(returnPercentStr).divide(new BigDecimal(100), 2, BigDecimal.ROUND_DOWN);
+                BigDecimal amountActual = amountBigDecimal.multiply(returnPercent).setScale(2, BigDecimal.ROUND_DOWN);
+                memberWalletService.add(amountActual, id, "balance");
+            }
+        }
+        for(MallOrderItem mallOrderItem : mallOrderItemList){
+            Long goodsId = mallOrderItem.getGoodsId();
+            MallGoods mallGoods = mallGoodsMapper.selectById(goodsId);
+            if(ObjectUtil.isEmpty(mallGoods)){
+                break;
+            }
+            //是否送券 1:是 2:否
+            BigDecimal levelTwoPrice = mallGoods.getLevelTwoPrice();
+            if(BigDecimal.ONE.compareTo(levelTwoPrice) == 0){
+                MallRollPerk mallRollPerk = new MallRollPerk();
+                mallRollPerk.setMemberId(memberId);
+                mallRollPerk.setState(1);
+                mallRollPerk.setRollId(Long.parseLong(mallGoods.getLevelThreePrice().toString()));
+                mallRollPerkMapper.insert(mallRollPerk);
+            }
+            //赠送积分
+            BigDecimal levelOnePrice = mallGoods.getLevelOnePrice();
+            if(BigDecimal.ZERO.compareTo(levelOnePrice) <= 0){
+                memberWalletService.add(levelOnePrice, memberId, "score");
+            }
+        }
+    }
+
+    public static void main(String[] args) {
+
+        RestTemplate restTemplate = new RestTemplate();
+        String accessToken = "70__DR_q_qmjcMfPQEBwmjdfJFWnpml55Bq6JK2vt9MMdcRLsHaYM1BQGFWzLUISjcFC8HAYTKOaPJH93KHNvo4KIeMZkxFF2qP66nAdygUQ6c";
+        String openId = "oXL7Y6LW5KGQTbmmP5W3JljjApSo";
+        String requrl = "https://api.weixin.qq.com/sns/userinfo?access_token="+accessToken+"&openid="+openId+"&lang=zh_CN";
+        // 创建一个StringHttpMessageConverter,并设置字符集为UTF-8
+        StringHttpMessageConverter stringConverter = new StringHttpMessageConverter(Charset.forName("UTF-8"));
+        stringConverter.setSupportedMediaTypes(Collections.singletonList(MediaType.TEXT_PLAIN));
+        // 将StringHttpMessageConverter添加到RestTemplate的消息转换器列表中
+        restTemplate.getMessageConverters().add(0, stringConverter);
+        // 创建HttpHeaders对象,设置Accept头部的值为"text/plain;charset=UTF-8"
+        HttpHeaders headers = new HttpHeaders();
+        headers.setAccept(Collections.singletonList(MediaType.TEXT_PLAIN));
+        headers.set(HttpHeaders.ACCEPT_CHARSET, "UTF-8");
+
+        String responseStr = restTemplate.getForObject(requrl, String.class);
+        net.sf.json.JSONObject json = net.sf.json.JSONObject.fromObject(responseStr);
+        log.info("微信获取用户信息={}", json);
+        String nickname = json.getString("nickname");
+        String headImgUrl = json.getString("headimgurl");
+        System.out.println(nickname);
+        System.out.println(headImgUrl);
+    }
 }

--
Gitblit v1.9.1