From e70f0cc17b3377a1e200490df94cda368098ff08 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 26 Jul 2023 14:24:26 +0800
Subject: [PATCH] 短信认证

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java |  202 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 173 insertions(+), 29 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 0f02d33..75b4dc6 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
@@ -1,19 +1,18 @@
 package cc.mrbird.febs.mall.service.impl;
 
 import cc.mrbird.febs.common.entity.FebsResponse;
-import cc.mrbird.febs.common.enumerates.AgentLevelEnum;
-import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
+import cc.mrbird.febs.common.enumerates.*;
 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.*;
-import cc.mrbird.febs.mall.service.IAgentService;
-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.*;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateField;
+import cn.hutool.core.date.DateTime;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.crypto.SecureUtil;
@@ -50,6 +49,14 @@
     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;
+    private final IMallMoneyFlowService mallMoneyFlowService;
+    private final MallMemberClassMapper mallMemberClassMapper;
+    private final MallMemberHouseMapper mallMemberHouseMapper;
 
     @Override
     @Transactional(rollbackFor = Exception.class)
@@ -234,7 +241,7 @@
     @Override
     public void addMemberScan(String str) {
 
-        String[] split = StrUtil.split(str, "-");
+        String[] split = StrUtil.split(str, "@");
         String referrerId = split[0];
         String openId = split[1];
         MallMember mallMember = memberMapper.selectMemberByOpenId(openId);
@@ -293,14 +300,15 @@
 
     @Override
     public void updateMemberInfo(String str) {
-        String[] split = StrUtil.split(str, "-");
+        String[] split = StrUtil.split(str, "|");
         String accessToken = split[0];
         String openId = split[1];
         MallMember mallMember = memberMapper.selectMemberByOpenId(openId);
-        if (ObjectUtil.isNotEmpty(mallMember)) {
+        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));
@@ -324,30 +332,166 @@
         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");
+                mallMoneyFlowService.addMoneyFlow(id, amountActual, MoneyFlowTypeEnum.DYNAMIC_ACHIEVE.getValue(),
+                        mallOrderInfo.getOrderNo(),  FlowTypeEnum.BALANCE.getValue());
+            }
+        }
+        for(MallOrderItem mallOrderItem : mallOrderItemList){
+            Long goodsId = mallOrderItem.getGoodsId();
+            MallGoods mallGoods = mallGoodsMapper.selectById(goodsId);
+            if(ObjectUtil.isEmpty(mallGoods)){
+                break;
+            }
+            if(1 == mallGoods.getIsUnreal()){
+                mallOrderInfo.setStatus(OrderStatusEnum.FINISH.getValue());
+                mallOrderInfoMapper.updateById(mallOrderInfo);
+            }
+            //是否送券 1:是 2:否
+            BigDecimal levelTwoPrice = mallGoods.getLevelTwoPrice();
+            if(BigDecimal.ONE.compareTo(levelTwoPrice) == 0){
+                MallRollPerk mallRollPerk = new MallRollPerk();
+                mallRollPerk.setMemberId(memberId);
+                mallRollPerk.setState(1);
+                mallRollPerk.setRollId(mallGoods.getLevelThreePrice().longValue());
+                mallRollPerkMapper.insert(mallRollPerk);
+            }
+            //赠送积分
+            BigDecimal levelOnePrice = mallGoods.getLevelOnePrice();
+            if(BigDecimal.ZERO.compareTo(levelOnePrice) <= 0){
+                memberWalletService.add(levelOnePrice, memberId, "score");
+
+                mallMoneyFlowService.addMoneyFlow(memberId, levelOnePrice, MoneyFlowTypeEnum.STATIC_BONUS.getValue(),
+                        mallOrderInfo.getOrderNo(),  FlowTypeEnum.SCORE.getValue());
+            }
+        }
+    }
+
+    @Override
+    public void rollSendMsg(Long orderId) {
+        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId);
+        if(ObjectUtil.isEmpty(mallOrderInfo)){
+            return;
+        }
+        Long memberId = mallOrderInfo.getMemberId();
+        MallMember mallMember = memberMapper.selectById(memberId);
+        if(ObjectUtil.isEmpty(mallMember)){
+            return;
+        }
+
+        List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(orderId);
+        if(CollUtil.isEmpty(mallOrderItemList)){
+            return;
+        }
+        MallOrderItem mallOrderItem = mallOrderItemList.get(0);
+        String goodsName = mallOrderItem.getGoodsName();
+        String skuImage = mallOrderItem.getSkuImage();
+        Long goodsId = mallOrderItem.getGoodsId();
+        MallGoods mallGoods = mallGoodsMapper.selectById(goodsId);
+        if(ObjectUtil.isEmpty(mallGoods)){
+            return;
+        }
+        Integer isNormal = mallGoods.getIsNormal();
+        if(4 == isNormal){
+            //课程卷
+            MallMemberClass mallMemberClass = new MallMemberClass();
+            mallMemberClass.setMemberId(mallMember.getId());
+            mallMemberClass.setOrderId(orderId);
+            mallMemberClass.setClassName(goodsName);
+            mallMemberClass.setClassPic(skuImage);
+            mallMemberClass.setClassUrl(mallGoods.getVideoUrl());
+            mallMemberClassMapper.insert(mallMemberClass);
+            return;
+        }else if(5 == isNormal){
+            //民宿卷
+            MallMemberHouse mallMemberHouse = new MallMemberHouse();
+            mallMemberHouse.setOrderId(orderId);
+            mallMemberHouse.setOrderNo(mallOrderInfo.getOrderNo());
+            mallMemberHouse.setMemberId(memberId);
+            mallMemberHouse.setState(1);
+            mallMemberHouse.setCreateTime(DateUtil.date());
+            mallMemberHouse.setUpdateTime(mallOrderInfo.getUseTime());
+            mallMemberHouse.setUnuseTime(DateUtil.date().offset(DateField.HOUR_OF_DAY,48));
+            mallMemberHouse.setHouseName(mallGoods.getHouseName());
+            mallMemberHouse.setHouseAddress(mallGoods.getHouseAddress());
+            mallMemberHouse.setHousePic(mallGoods.getThumb());
+            mallMemberHouseMapper.insert(mallMemberHouse);
+            return;
+        }else{
+            return;
+        }
     }
 
     public static void main(String[] args) {
 
-        RestTemplate restTemplate = new RestTemplate();
-        String accessToken = "70_6yOz-tXaDx6qMswGgmfl6j3LfgG-ur3JE-top_QvX5Oea9ryFxzEBwgVoW53IpMrzcS7mpPJf7tI3czT_kA2l5Y_Xu1WS7d7xDNbMs97ARk";
-        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");
+        DateTime offset = DateUtil.date().offset(DateField.HOUR_OF_DAY, 48);
+        System.out.println(offset);
 
-        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);
+//        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