From e58bda9eed3e15ca0be919715861a30f75344e2f Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 14 Aug 2023 10:49:11 +0800
Subject: [PATCH] 赠送积分更新状态

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java |  218 +++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 172 insertions(+), 46 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index 3717948..18d8f58 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -20,6 +20,7 @@
 import cc.mrbird.febs.mall.vo.*;
 import cc.mrbird.febs.pay.model.BrandWCPayRequestData;
 import cc.mrbird.febs.pay.service.IXcxPayService;
+import cc.mrbird.febs.rabbit.producter.AgentProducer;
 import cn.hutool.core.bean.BeanUtil;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.IdUtil;
@@ -69,6 +70,7 @@
     private final SpringContextHolder springContextHolder;
     private final MallAgentRecordMapper mallAgentRecordMapper;
     private final IMallMoneyFlowService mallMoneyFlowService;
+    private final AgentProducer agentProducer;
 
 
     @Value("${spring.profiles.active}")
@@ -199,7 +201,9 @@
 
     public String generateAsaToken(String token) {
         RSA rsa = new RSA(null, AppContants.PUBLIC_KEY);
-        return rsa.encryptBase64(token + "_" + System.currentTimeMillis(), KeyType.PublicKey);
+//        return rsa.encryptBase64(token + "_" + System.currentTimeMillis(), KeyType.PublicKey);
+        //去掉时间戳
+        return rsa.encryptBase64(token, KeyType.PublicKey);
     }
 
     @Override
@@ -235,7 +239,7 @@
         MallMember mallMember = this.baseMapper.selectById(id);
 
         MallMemberVo mallMemberVo = MallMemberConversion.INSTANCE.entityToVo(mallMember);
-        if(StrUtil.isNotEmpty(mallMember.getReferrerId())){
+        if(!"".equals(mallMember.getReferrerId()) && ObjectUtil.isNotEmpty(mallMember.getReferrerId())){
             MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
             if (referMember != null) {
                 mallMemberVo.setReferrerName(referMember.getName());
@@ -265,10 +269,28 @@
             mallMemberVo.setIsAgent(1);
         }else if(ObjectUtil.isNotEmpty(mallAgentRecordAgree)){
             mallMemberVo.setIsAgent(2);
+            if(StrUtil.isNotEmpty(mallAgentRecordAgree.getAgentLevel())){
+                DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectDicDataByTypeAndCode("AGENT_LEVEL_APPLY", mallAgentRecordAgree.getAgentLevel());
+                mallMemberVo.setAgentLevelName(dataDictionaryCustom.getDescription());
+            }
+            if(AgentLevelEnum.LEVEL_ONE.name().equals(mallAgentRecordAgree.getAgentLevel())){
+                mallMemberVo.setAgentLevel(1);
+            }
+            if(AgentLevelEnum.LEVEL_TWO.name().equals(mallAgentRecordAgree.getAgentLevel())){
+                mallMemberVo.setAgentLevel(2);
+            }
+            if(AgentLevelEnum.LEVEL_THREE.name().equals(mallAgentRecordAgree.getAgentLevel())){
+                mallMemberVo.setAgentLevel(3);
+            }
         }else if(ObjectUtil.isNotEmpty(mallAgentRecordDisagree)){
             mallMemberVo.setIsAgent(3);
         }
-
+//        log.info(mallMemberVo.getName()+"---"+mallMemberVo.getAgentLevel());
+        DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.SCORE_CHANGE.getType(),
+                DataDictionaryEnum.SCORE_CHANGE.getCode()
+        );
+        mallMemberVo.setScoreChange(dataDictionaryCustom.getValue() == null ? "1" : dataDictionaryCustom.getValue());
         return new FebsResponse().success().data(mallMemberVo);
     }
 
@@ -337,11 +359,10 @@
         MallMember mallMember = this.baseMapper.selectById(memberId);
 
         List<TeamListVo> list = this.baseMapper.selectTeamListByInviteId(mallMember.getInviteId());
-
         MyTeamVo myTeamVo = new MyTeamVo();
         myTeamVo.setTeam(list);
-        myTeamVo.setMyAchieve(this.baseMapper.selectAchieveByMemberId(mallMember.getInviteId(), 1));
-        myTeamVo.setMyTeamAchieve(this.baseMapper.selectAchieveByMemberId(mallMember.getInviteId(), 2));
+        myTeamVo.setMyAchieve(this.baseMapper.selectOrderAmountByMemberId(mallMember.getInviteId(), 1));
+        myTeamVo.setMyTeamAchieve(this.baseMapper.selectOrderAmountByMemberId(mallMember.getInviteId(), 2));
         myTeamVo.setMyTeamCnt(this.baseMapper.selectAllChildAgentListByInviteId(mallMember.getInviteId()).size());
         return new FebsResponse().success().data(myTeamVo);
     }
@@ -474,7 +495,7 @@
         MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
         if (referMember != null) {
             commissionVo.setReferrerName(referMember.getName());
-            commissionVo.setAvatar(referMember.getAvatar());
+            commissionVo.setReferrerAvatar(referMember.getAvatar());
         }
 
         DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(AppContants.AGENT_LEVEL, mallMember.getLevel());
@@ -577,34 +598,61 @@
             }
 
             String openId = json.getString("openid");
-            String sessionKey = json.getString("session_key");
-            log.info("openId={},sessionKey={}", openId, sessionKey);
+            String accessToken = json.getString("access_token");
+            log.info("openId={}", openId);
             // 查询用户是否存在
-            MallMember mallMember = null;
-            synchronized (this) {
-                mallMember = this.baseMapper.selectMemberByOpenId(openId);
-                if (ObjectUtil.isEmpty(mallMember)) {
-                    // 新增用户
-                    mallMember = new MallMember();
-                    mallMember.setAccountStatus(MallMember.ACCOUNT_STATUS_ENABLE);
-                    mallMember.setAccountType(MallMember.ACCOUNT_TYPE_NORMAL);
-                    mallMember.setLevel(AgentLevelEnum.ZERO_LEVEL.name());
-                    mallMember.setOpenId(openId);
-                    mallMember.setSessionKey(sessionKey);
-                    this.baseMapper.insert(mallMember);
-
-                    mallMember = this.baseMapper.selectMemberByOpenId(openId);
-                    String inviteId = ShareCodeUtil.toSerialCode(mallMember.getId());
-                    mallMember.setInviteId(inviteId);
-                    this.baseMapper.updateById(mallMember);
-                    MallMemberWallet wallet = new MallMemberWallet();
-                    wallet.setBalance(BigDecimal.ZERO);
-                    wallet.setMemberId(mallMember.getId());
-                    mallMemberWalletMapper.insert(wallet);
-                } else {
-                    mallMember.setSessionKey(sessionKey);
-                    this.baseMapper.updateById(mallMember);
+            MallMember mallMember = this.baseMapper.selectMemberByOpenId(openId);
+            if (ObjectUtil.isEmpty(mallMember)) {
+                //根据OPENID,查询用户信息,如果存在,直接返回
+                mallMember = new MallMember();
+                mallMember.setPassword(SecureUtil.md5("a123456"));
+                mallMember.setName("微信用户");
+                mallMember.setSubStatus(MallMember.SUB_STATUS_DISABLED);
+                mallMember.setReferrerId(null);
+                mallMember.setPhone(null);
+                mallMember.setAccountStatus(MallMember.ACCOUNT_STATUS_ENABLE);
+                mallMember.setAccountType(MallMember.ACCOUNT_TYPE_NORMAL);
+                mallMember.setLevel(AgentLevelEnum.ZERO_LEVEL.name());
+                mallMember.setSex("男");
+                mallMember.setBindPhone(null);
+                mallMember.setOpenId(openId);
+                this.baseMapper.insert(mallMember);
+                //生成邀请码
+                String inviteId = ShareCodeUtil.toSerialCode(mallMember.getId());
+                mallMember.setInviteId(inviteId);
+                //推荐人和推荐人链
+                boolean flag = false;
+                String parentId = mallMember.getReferrerId();
+                if (StrUtil.isBlank(parentId)) {
+                    flag = true;
                 }
+                String ids = "";
+                while (!flag) {
+                    if (StrUtil.isBlank(ids)) {
+                        ids += parentId;
+                    } else {
+                        ids += ("," + parentId);
+                    }
+                    MallMember parentMember = this.baseMapper.selectInfoByInviteId(parentId);
+                    if (parentMember == null) {
+                        break;
+                    }
+                    parentId = parentMember.getReferrerId();
+                    if (StrUtil.isBlank(parentMember.getReferrerId())) {
+                        flag = true;
+                    }
+                }
+                if (StrUtil.isNotBlank(ids)) {
+                    mallMember.setReferrerIds(ids);
+                }
+                this.baseMapper.updateById(mallMember);
+                //初始化钱包信息
+                MallMemberWallet wallet = new MallMemberWallet();
+                wallet.setBalance(BigDecimal.ZERO);
+                wallet.setMemberId(mallMember.getId());
+                mallMemberWalletMapper.insert(wallet);
+
+                return new FebsResponse().fail().message("请先关注公众号");
             }
             // 存放redis
             String redisKey = AppContants.XCX_LOGIN_PREFIX + mallMember.getId();
@@ -616,13 +664,16 @@
                 }
             }
             String token = IdUtil.simpleUUID();
-            redisUtils.set(token, JSONObject.toJSONString(mallMember), 360000);
-            redisUtils.set(redisKey, token, 360000);
+            redisUtils.set(token, JSONObject.toJSONString(mallMember), -1);
+            redisUtils.set(redisKey, token, -1);
             Map<String, Object> authInfo = new HashMap<>();
             authInfo.put("token", token);
             authInfo.put("appid", xcxProperties.getXcxAppid());
             authInfo.put("member", mallMember);
             authInfo.put("rasToken", generateAsaToken(token));
+            authInfo.put("accessToken",accessToken);
+            authInfo.put("openId",openId);
+            agentProducer.sendMemberInfoMsg(accessToken+"|"+openId);
             febsResponse.success().data(authInfo);
         } else {
             return febsResponse.fail().message("自动登录失败");
@@ -746,11 +797,13 @@
         Integer type = apiRechargeWalletDto.getType();
         if(2 == type){
             //成为合伙人的充值金额
-            DataDictionaryCustom agentPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.PRICE_AMOUNT.getType(),
-                    DataDictionaryEnum.PRICE_AMOUNT.getCode());
-            String agentPrice = agentPriceDic.getValue();
-            BigDecimal price = new BigDecimal(agentPrice);
-            if(price.compareTo(amount) != 0){
+            MallAgentRecord mallAgentRecord = mallAgentRecordMapper.selectById(apiRechargeWalletDto.getAgentApplyId());
+            BigDecimal agentPrice = mallAgentRecord.getAmount();
+//            DataDictionaryCustom agentPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.PRICE_AMOUNT.getType(),
+//                    DataDictionaryEnum.PRICE_AMOUNT.getCode());
+//            String agentPrice = agentPriceDic.getValue();
+//            BigDecimal price = new BigDecimal(agentPrice);
+            if(agentPrice.compareTo(amount) != 0){
                 return new FebsResponse().fail().message("成为合伙人的金额为"+agentPrice);
             }
         }
@@ -768,8 +821,7 @@
                 amount,
                 MoneyFlowTypeEnum.RECHARGE.getValue(),
                 rechargeNo,
-                FlowTypeEnum.BALANCE.getValue(),
-                "余额充值",1);
+                FlowTypeEnum.BALANCE.getValue());
 
         String wxResultStr = JSONUtil.toJsonStr(brandWCPayRequestData);
         String payResultStr = brandWCPayRequestData.getPrepay_id();
@@ -780,15 +832,89 @@
     }
 
     @Override
-    public void updateMemberAgent(Long memberId) {
+    public void updateMemberAgent(Long memberId,String levelCode) {
         mallAgentRecordMapper.updateStateByMemberId(memberId);
-
+        MallAgentRecord mallAgentRecord = mallAgentRecordMapper.selectById(memberId);
         //更新用户表中的LEVEL
-        MallMember mallMember = this.baseMapper.selectById(memberId);
-        mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name());
+        MallMember mallMember = this.baseMapper.selectById(mallAgentRecord.getMemberId());
+        mallMember.setLevel(levelCode);
         this.baseMapper.updateById(mallMember);
     }
 
+    @Override
+    public FebsResponse agentDetail() {
+        DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.AGENT_DETAILS.getType(), DataDictionaryEnum.AGENT_DETAILS.getCode());
+        Map<String, Object> map = new HashMap<>();
+        if(ObjectUtil.isNotEmpty(dataDictionaryCustom)){
+            map.put("agentDetail", dataDictionaryCustom.getValue());
+        }
+        return new FebsResponse().success().data(map);
+    }
+
+    @Override
+    public FebsResponse activityInfo() {
+        DataDictionaryCustom activityBulletinDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.ACTIVITY_BULLETIN.getType(), DataDictionaryEnum.ACTIVITY_BULLETIN.getCode());
+        DataDictionaryCustom giveAmountDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.GIVE_AMOUNT.getType(), DataDictionaryEnum.GIVE_AMOUNT.getCode());
+        DataDictionaryCustom giveStateDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.GIVE_STATE.getType(), DataDictionaryEnum.GIVE_STATE.getCode());
+        Map<String, Object> map = new HashMap<>();
+        if(ObjectUtil.isNotEmpty(activityBulletinDic)){
+            map.put("activityBulletin",
+                    ObjectUtil.isEmpty(activityBulletinDic.getValue()) ? "暂无活动" : activityBulletinDic.getValue());
+        }
+        if(ObjectUtil.isNotEmpty(giveAmountDic)){
+            map.put("giveAmount",
+                    ObjectUtil.isEmpty(giveAmountDic.getValue()) ? 0 : giveAmountDic.getValue());
+        }
+        map.put("giveState",giveStateDic.getValue());
+        return new FebsResponse().success().data(map);
+    }
+
+    @Override
+    public FebsResponse agentApplyInfo() {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        ApiMallAgentRecordVo apiMallAgentRecordVo = mallAgentRecordMapper.selectApiMallAgentRecordVoByMemberIdAndState(memberId,MallAgentRecord.APPLY_ING);
+        return new FebsResponse().success().data(apiMallAgentRecordVo);
+    }
+
+    @Override
+    public FebsResponse findMallRollPerkInPage(ApiMallRollPerkDto queryDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        Page<MallRollPerk> page = new Page<>(queryDto.getPageNow(), queryDto.getPageSize());
+        MallRollPerk mallRollPerk = new MallRollPerk();
+        if(ObjectUtil.isNotEmpty(queryDto.getState())){
+            mallRollPerk.setState(queryDto.getState());
+        }
+        mallRollPerk.setRollId(queryDto.getRollId());
+        mallRollPerk.setMemberId(memberId);
+        IPage<MallRollPerk> mallGoodsCommentVoIPage = this.baseMapper.findMallRollPerkInPage(page,mallRollPerk);
+        return new FebsResponse().success().data(mallGoodsCommentVoIPage);
+    }
+
+    @Override
+    public FebsResponse findMallMemberClassInPage(ApiMemberClassDto queryDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        MallMemberClass mallMemberClass = new MallMemberClass();
+        Page<MallMemberClass> page = new Page<>(queryDto.getPageNow(), queryDto.getPageSize());
+        mallMemberClass.setMemberId(memberId);
+        IPage<MallMemberClass> mallMemberClassList = this.baseMapper.findMallMemberClassInPage(page,mallMemberClass);
+        return new FebsResponse().success().data(mallMemberClassList);
+    }
+
+    @Override
+    public FebsResponse findMallMemberHouseInPage(ApiMemberHouseDto queryDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        MallMemberHouse mallMemberHouse = new MallMemberHouse();
+        Page<MallMemberHouse> page = new Page<>(queryDto.getPageNow(), queryDto.getPageSize());
+        mallMemberHouse.setMemberId(memberId);
+        mallMemberHouse.setState(queryDto.getState());
+        IPage<MallMemberHouse> mallMemberHouseList = this.baseMapper.findMallMemberHouseInPage(page,mallMemberHouse);
+        return new FebsResponse().success().data(mallMemberHouseList);
+    }
+
     private  String getXcxLoginUrl(String code) {
         String wechatLoginUrl =xcxProperties.getWecharLoginUrl();
         return String.format(wechatLoginUrl, xcxProperties.getXcxAppid(), xcxProperties.getXcxSecret(), code);

--
Gitblit v1.9.1