From 3ff5638ae0ec0e52c2c314471a57ab4ef84fa3f9 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Wed, 15 Dec 2021 18:13:39 +0800
Subject: [PATCH] fix

---
 gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java |  133 +++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 130 insertions(+), 3 deletions(-)

diff --git a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java
index 5ac2574..eb5269d 100644
--- a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java
+++ b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java
@@ -6,7 +6,9 @@
 import cn.hutool.core.date.DateUtil;
 import com.github.pagehelper.PageHelper;
 import com.github.pagehelper.PageInfo;
+import com.xzx.gc.common.constant.CommonEnum;
 import com.xzx.gc.common.exception.RestException;
+import com.xzx.gc.common.utils.RedisUtil;
 import com.xzx.gc.common.utils.StringUtils;
 import com.xzx.gc.entity.*;
 import com.xzx.gc.user.dto.*;
@@ -30,6 +32,7 @@
 
 import javax.annotation.Resource;
 import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.util.HashMap;
 import java.util.List;
 
@@ -55,6 +58,10 @@
     private UserShareInfoMapper userShareInfoMapper;
     @Autowired
     private SysMessageMapper sysMessageMapper;
+    @Autowired
+    private RedisUtil redisUtil;
+    @Autowired
+    private ScoreDetailsMapper scoreDetailsMapper;
 
     public ViewSettingVo viewSetting(String ruleStr) {
         ViewSettingVo viewSettingVo = new ViewSettingVo();
@@ -181,6 +188,7 @@
         stringBuffer.append(pointReward);
         redPaperRule.setStatus((short) 0);
         redPaperRule.setRuleName("分销规则");
+        redPaperRule.setRuleType("9");
         redPaperRule.setSharingProfitType("frist_reward,order_num_frist,regular_point,regular_money_percent,point_reward");
         redPaperRule.setShareRatio(stringBuffer.toString());
         redPaperRuleMapper.insert(redPaperRule);
@@ -406,6 +414,7 @@
             viewScoreSettingVo.setShareScore(0);
             viewScoreSettingVo.setShareScoreTime(0);
             viewScoreSettingVo.setFirstScore(0);
+            viewScoreSettingVo.setStatus((short) 0);
         }else{
             String shareRatio = redPaperRule.getShareRatio();
             if(StrUtil.isNotEmpty(shareRatio)){
@@ -416,6 +425,7 @@
                     viewScoreSettingVo.setShareScore(StrUtil.isEmpty(shareRatios.get(1))?0:Integer.parseInt(shareRatios.get(1)));
                     viewScoreSettingVo.setShareScoreTime(StrUtil.isEmpty(shareRatios.get(2))?0:Integer.parseInt(shareRatios.get(2)));
                     viewScoreSettingVo.setFirstScore(StrUtil.isEmpty(shareRatios.get(3))?0:Integer.parseInt(shareRatios.get(3)));
+                    viewScoreSettingVo.setStatus(redPaperRule.getStatus());
                 }
             }else{
                 viewScoreSettingVo.setId(redPaperRule.getId());
@@ -423,6 +433,7 @@
                 viewScoreSettingVo.setShareScore(0);
                 viewScoreSettingVo.setShareScoreTime(0);
                 viewScoreSettingVo.setFirstScore(0);
+                viewScoreSettingVo.setStatus(redPaperRule.getStatus());
             }
         }
         return viewScoreSettingVo;
@@ -438,10 +449,11 @@
         int shareScoreTime = ObjectUtil.isEmpty(model.getShareScoreTime()) ? 0 : model.getShareScoreTime();
         stringBuffer.append(shareScoreTime+",");
         int firstScore = ObjectUtil.isEmpty(model.getFirstScore()) ? 0 : model.getFirstScore();
-        stringBuffer.append(firstScore+",");
+        stringBuffer.append(firstScore);
         redPaperRule.setStatus((short) 0);
         redPaperRule.setRuleName("积分运行设置");
-        redPaperRule.setSharingProfitType("register_score,share_score,share_score_time");
+        redPaperRule.setRuleType("10");
+        redPaperRule.setSharingProfitType("register_score,share_score,share_score_time,first_score");
         redPaperRule.setShareRatio(stringBuffer.toString());
         redPaperRuleMapper.insert(redPaperRule);
     }
@@ -457,11 +469,126 @@
             int shareScoreTime = ObjectUtil.isEmpty(model.getShareScoreTime()) ? 0 : model.getShareScoreTime();
             stringBuffer.append(shareScoreTime+",");
             int firstScore = ObjectUtil.isEmpty(model.getFirstScore()) ? 0 : model.getFirstScore();
-            stringBuffer.append(firstScore+",");
+            stringBuffer.append(firstScore);
             redPaperRule.setStatus(model.getStatus());
             redPaperRule.setSharingProfitType("register_score,share_score,share_score_time,first_score");
             redPaperRule.setShareRatio(stringBuffer.toString());
             redPaperRuleMapper.updateByPrimaryKey(redPaperRule);
         }
     }
+
+    public void shareToMoments(String userId) {
+        List<RedPaperRule> redPaperRules = redPaperRuleMapper.selectByRuleType("10");
+        if (CollUtil.isEmpty(redPaperRules)) {
+            return;
+        }
+
+        RedPaperRule rule = redPaperRules.get(0);
+        if (rule.getStatus() == 0) {
+            log.info("规则被禁用, 不执行返利");
+            return;
+        }
+
+        String shareTimes = getRuleValue(rule, CommonEnum.朋友圈分享限次.getValue());
+
+        String shareScore = getRuleValue(rule, CommonEnum.朋友圈分享奖励.getValue());
+        String key = "moments:times:" + userId;
+        Integer times = redisUtil.getAsInt("moments:times:" + userId);
+        times = times == null ? 1 : times + 1;
+
+        if (StrUtil.isNotBlank(shareTimes)) {
+            if (times > Integer.parseInt(shareTimes)) {
+                throw new RestException("达到24小时内最大分享次数");
+            }
+
+            if (StrUtil.isBlank(shareScore)) {
+                return;
+            }
+
+            AccountInfo accountInfo = accountMapper.selectOneByUserId(userId);
+            BigDecimal returnScore = new BigDecimal(shareScore);
+            BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO;
+            accountInfo.setCollectScore(collectScore.add(returnScore).setScale(0, RoundingMode.DOWN).toString());
+            accountMapper.updateByPrimaryKey(accountInfo);
+
+            ScoreDetails scoreDetails = new ScoreDetails();
+            scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore()));
+            scoreDetails.setOriginalScore(collectScore);
+            scoreDetails.setChangeScore(returnScore);
+            scoreDetails.setCreatedTime(new Date());
+            scoreDetails.setType(ScoreDetails.SCORE_TYPE_SHARE_MOMENTS);
+            scoreDetails.setUserId(accountInfo.getUserId());
+            scoreDetailsMapper.insert(scoreDetails);
+
+            SysMessage sysMessage = new SysMessage();
+            sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
+            sysMessage.setCreateUserId(accountInfo.getUserId());
+            sysMessage.setUserId(accountInfo.getUserId());
+            sysMessage.setMessageType("4");
+            sysMessage.setMessageSubTypeName("朋友圈分享");
+            sysMessage.setMessage("朋友圈分享, 积分:" + returnScore);
+            sysMessage.setFlag("2");
+            sysMessageMapper.insert(sysMessage);
+
+            Date tomorrow = DateUtil.parse(DateUtil.tomorrow().toString("yyyy-MM-dd") + " 00:00:00", "yyyy-MM-dd HH:mm:ss");
+            long time = DateUtil.between(new Date(), tomorrow, DateUnit.SECOND, false);
+            redisUtil.setex(key, times.toString(), (int) time);
+        }
+    }
+
+    public void inviteAward(String phone) {
+        AccountInfo accountInfo = accountMapper.selectAccountInfoByPhone(phone);
+
+        List<RedPaperRule> redPaperRules = redPaperRuleMapper.selectByRuleType("10");
+        if (CollUtil.isEmpty(redPaperRules)) {
+            return;
+        }
+
+        RedPaperRule rule = redPaperRules.get(0);
+        String invite = getRuleValue(rule, CommonEnum.邀请奖励.getValue());
+
+        if (StrUtil.isBlank(invite)) {
+            return;
+        }
+
+        List<UserShareInfo> hasInvite = userShareInfoMapper.selectByPhone(phone);
+        if (CollUtil.isNotEmpty(hasInvite)) {
+            if (hasInvite.size() >= 10) {
+                log.info("超过10个,邀请无效:{}", phone);
+                return;
+            }
+        }
+
+        BigDecimal returnScore = new BigDecimal(invite);
+        BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO;
+        accountInfo.setCollectScore(collectScore.add(returnScore).setScale(0, RoundingMode.DOWN).toString());
+        accountMapper.updateByPrimaryKey(accountInfo);
+
+        ScoreDetails scoreDetails = new ScoreDetails();
+        scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore()));
+        scoreDetails.setOriginalScore(collectScore);
+        scoreDetails.setChangeScore(returnScore);
+        scoreDetails.setCreatedTime(new Date());
+        scoreDetails.setType(ScoreDetails.SCORE_TYPE_INVITE);
+        scoreDetails.setUserId(accountInfo.getUserId());
+        scoreDetailsMapper.insert(scoreDetails);
+
+        SysMessage sysMessage = new SysMessage();
+        sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss"));
+        sysMessage.setCreateUserId(accountInfo.getUserId());
+        sysMessage.setUserId(accountInfo.getUserId());
+        sysMessage.setMessageType("4");
+        sysMessage.setMessageSubTypeName("邀请奖励");
+        sysMessage.setMessage("邀请奖励, 积分:" + returnScore);
+        sysMessage.setFlag("2");
+        sysMessageMapper.insert(sysMessage);
+    }
+
+    private String getRuleValue(RedPaperRule redPaperRule, String key) {
+        List<String> rules = StrUtil.split(redPaperRule.getSharingProfitType(), ',');
+        List<String> values = StrUtil.split(redPaperRule.getShareRatio(), ',');
+
+        int i = rules.indexOf(key);
+        return values.get(i);
+    }
 }

--
Gitblit v1.9.1