From fd2d18b4facf87aa7048e3ba010e7594f4df8576 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Fri, 28 Jul 2023 16:17:53 +0800
Subject: [PATCH] 赠送积分更新状态

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java |  611 ++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 528 insertions(+), 83 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 a3529ea..bd602c8 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
@@ -2,21 +2,26 @@
 
 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.FlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.common.properties.XcxProperties;
 import cc.mrbird.febs.common.utils.*;
 import cc.mrbird.febs.mall.conversion.MallMemberConversion;
+import cc.mrbird.febs.mall.conversion.MallShopApplyConversion;
 import cc.mrbird.febs.mall.dto.*;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.IApiMallMemberService;
 import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
 import cc.mrbird.febs.mall.service.ICommonService;
-import cc.mrbird.febs.mall.vo.MallMemberVo;
-import cc.mrbird.febs.mall.vo.MoneyFlowVo;
-import cc.mrbird.febs.mall.vo.RankListVo;
-import cc.mrbird.febs.mall.vo.TeamListVo;
+import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
+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;
 import cn.hutool.core.util.ObjectUtil;
@@ -24,6 +29,7 @@
 import cn.hutool.crypto.SecureUtil;
 import cn.hutool.crypto.asymmetric.KeyType;
 import cn.hutool.crypto.asymmetric.RSA;
+import cn.hutool.json.JSONUtil;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -31,14 +37,14 @@
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Value;
+import org.springframework.boot.autoconfigure.security.SecurityProperties;
+import org.springframework.http.HttpStatus;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.io.IOException;
 import java.math.BigDecimal;
-import java.util.Date;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 /**
  * @author wzy
@@ -58,6 +64,14 @@
     private final IApiMallMemberWalletService walletService;
     private final MallMemberPaymentMapper mallMemberPaymentMapper;
     private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
+    private final MallShopApplyMapper mallShopApplyMapper;
+    private final MallRegisterAppealMapper mallRegisterAppealMapper;
+    private final MallTeamLeaderMapper mallTeamLeaderMapper;
+    private final SpringContextHolder springContextHolder;
+    private final MallAgentRecordMapper mallAgentRecordMapper;
+    private final IMallMoneyFlowService mallMoneyFlowService;
+    private final AgentProducer agentProducer;
+
 
     @Value("${spring.profiles.active}")
     private String active;
@@ -70,11 +84,21 @@
             throw new FebsException("该账号已被占用");
         }
 
+        List<MallMember> mallMembers = this.baseMapper.selectMemberByName(registerDto.getName());
+        if (CollUtil.isNotEmpty(mallMembers)) {
+            MallRegisterAppeal registerAppeal = mallRegisterAppealMapper.selectByPhoneAndName(registerDto.getName(), registerDto.getAccount());
+            if (registerAppeal == null || registerAppeal.getStatus() != 1) {
+                return new FebsResponse().code(HttpStatus.ACCEPTED).message("用户名已存在");
+            }
+        }
+
         String account = registerDto.getAccount();
-        String code = registerDto.getCode();
-        boolean flags = commonService.verifyCode(account, code);
-        if(!flags) {
-            throw new FebsException("验证码错误");
+        if (!"admin".equals(registerDto.getRegistType())) {
+            String code = registerDto.getCode();
+            boolean flags = commonService.verifyCode(account, code);
+            if (!flags) {
+                throw new FebsException("验证码错误");
+            }
         }
 
         mallMember = new MallMember();
@@ -97,11 +121,12 @@
             mallMember.setReferrerId(registerDto.getInviteId());
 
         }
-        mallMember.setName(registerDto.getAccount());
+        mallMember.setName(registerDto.getName());
         mallMember.setAccountStatus(MallMember.ACCOUNT_STATUS_ENABLE);
         mallMember.setAccountType(MallMember.ACCOUNT_TYPE_NORMAL);
         mallMember.setLevel(AgentLevelEnum.ZERO_LEVEL.name());
         mallMember.setSex("男");
+        mallMember.setBindPhone(registerDto.getAccount());
 
         this.baseMapper.insert(mallMember);
 
@@ -176,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
@@ -201,7 +228,8 @@
     @Override
     public FebsResponse logout() {
         Long id = LoginUserUtil.getLoginUser().getId();
-        redisUtils.del(AppContants.APP_LOGIN_PREFIX + id);
+        redisUtils.del(AppContants.XCX_LOGIN_PREFIX + id);
+        redisUtils.del(AppContants.XCX_LOGIN_PHONE_PREFIX + id);
         return new FebsResponse().success().message("退出登录");
     }
 
@@ -211,10 +239,11 @@
         MallMember mallMember = this.baseMapper.selectById(id);
 
         MallMemberVo mallMemberVo = MallMemberConversion.INSTANCE.entityToVo(mallMember);
-
-        MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
-        if (referMember != null) {
-            mallMemberVo.setReferrerName(referMember.getName());
+        if(!"".equals(mallMember.getReferrerId()) && ObjectUtil.isNotEmpty(mallMember.getReferrerId())){
+            MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
+            if (referMember != null) {
+                mallMemberVo.setReferrerName(referMember.getName());
+            }
         }
 
         if (StrUtil.isNotBlank(mallMember.getTradePassword())) {
@@ -226,15 +255,42 @@
             mallMemberVo.setHasPayment(1);
         }
 
-        DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(AppContants.AGENT_LEVEL, mallMember.getLevel());
-        if (dic != null) {
-            mallMemberVo.setLevelName(dic.getDescription());
-        }
         MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(mallMemberVo.getId());
         mallMemberVo.setBalance(wallet.getBalance());
         mallMemberVo.setScore(wallet.getScore());
         mallMemberVo.setPrizeScore(wallet.getPrizeScore());
         mallMemberVo.setTotalCost(mallOrderInfoMapper.selectTotalAmount(id));
+
+        //代理状态
+        MallAgentRecord mallAgentRecordIng = mallAgentRecordMapper.selectByMemberIdAndState(id, MallAgentRecord.APPLY_ING);
+        MallAgentRecord mallAgentRecordAgree = mallAgentRecordMapper.selectByMemberIdAndState(id, MallAgentRecord.APPLY_AGREE);
+        MallAgentRecord mallAgentRecordDisagree = mallAgentRecordMapper.selectByMemberIdAndState(id, MallAgentRecord.APPLY_DISAGREE);
+        if(ObjectUtil.isNotEmpty(mallAgentRecordIng)){
+            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);
     }
 
@@ -303,20 +359,18 @@
         MallMember mallMember = this.baseMapper.selectById(memberId);
 
         List<TeamListVo> list = this.baseMapper.selectTeamListByInviteId(mallMember.getInviteId());
-        BigDecimal ownAmount = this.baseMapper.selectOwnOrderAmountByInviteId(mallMember.getInviteId());
 
-        TeamListVo own = new TeamListVo();
-        own.setCreatedTime(mallMember.getCreatedTime());
-        own.setAmount(ownAmount);
-        own.setName(mallMember.getName());
-        own.setPhone(mallMember.getPhone());
-        own.setInviteId(mallMember.getInviteId());
-        own.setIsCurrent(1);
-        own.setCnt(this.baseMapper.selectOwnCntByInviteId(mallMember.getInviteId()));
-        own.setOrderCnt(this.baseMapper.selectOwnOrderCntByInviteId(mallMember.getInviteId()));
-        own.setId(mallMember.getId());
-        list.add(0, own);
-        return new FebsResponse().success().data(list);
+        MyTeamVo myTeamVo = new MyTeamVo();
+        myTeamVo.setTeam(list);
+        myTeamVo.setMyAchieve(this.baseMapper.selectAchieveByMemberId(mallMember.getInviteId(), 1));
+        myTeamVo.setMyTeamAchieve(this.baseMapper.selectAchieveByMemberId(mallMember.getInviteId(), 2));
+        myTeamVo.setMyTeamCnt(this.baseMapper.selectAllChildAgentListByInviteId(mallMember.getInviteId()).size());
+        return new FebsResponse().success().data(myTeamVo);
+    }
+
+    @Override
+    public MyTeamVo teamListForMine(TeamListDto teamListDto) {
+        return null;
     }
 
     @Override
@@ -375,43 +429,6 @@
     }
 
     @Override
-    public void withdrawal(WithdrawalDto withdrawalDto) {
-        Long memberId = LoginUserUtil.getLoginUser().getId();
-        MallMember mallMember = this.baseMapper.selectById(memberId);
-        if (StrUtil.isBlank(mallMember.getTradePassword())) {
-            throw new FebsException("未设置支付密码");
-        }
-
-        if (!mallMember.getTradePassword().equals(SecureUtil.md5(withdrawalDto.getTradePwd()))) {
-            throw new FebsException("支付密码错误");
-        }
-
-        if (withdrawalDto.getAmount().compareTo(BigDecimal.valueOf(100)) < 0) {
-            throw new FebsException("最小提现金额为100");
-        }
-
-//        MallMemberPayment payment = mallMemberPaymentMapper.selectByMemberId(memberId);
-//        if (payment == null) {
-//            throw new FebsException("未设置收款方式");
-//        }
-
-        BigDecimal profit = mallMoneyFlowMapper.selectProfitByDateAndMemberId(memberId);
-        MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
-        if (profit != null) {
-            // 可提现
-            BigDecimal canMoney = wallet.getCommission().subtract(profit);
-
-            if(withdrawalDto.getAmount().compareTo(canMoney) > 0) {
-                throw new FebsException("提现金额不足");
-            }
-        }
-
-        walletService.reduceCommission(withdrawalDto.getAmount(), memberId);
-        String orderNo = MallUtils.getOrderNum("W");
-        this.addMoneyFlow(memberId, withdrawalDto.getAmount().negate(), MoneyFlowTypeEnum.WITHDRAWAL.getValue(), orderNo, null, null, null, 1, FlowTypeEnum.COMMISSION.getValue());
-    }
-
-    @Override
     public void setPayment(MallMemberPayment mallMemberPayment) {
         MallMember member = LoginUserUtil.getLoginUser();
 
@@ -441,7 +458,7 @@
         Long id = LoginUserUtil.getLoginUser().getId();
         MallMember member = this.baseMapper.selectById(id);
 
-        member.setBindPhone(accountAndCodeDto.getAccount());
+        member.setPhone(accountAndCodeDto.getAccount());
         this.baseMapper.updateById(member);
     }
 
@@ -449,15 +466,7 @@
     public BigDecimal canMoney() {
         Long memberId = LoginUserUtil.getLoginUser().getId();
         MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
-        BigDecimal profit = mallMoneyFlowMapper.selectProfitByDateAndMemberId(memberId);
-
-        BigDecimal canMoney = wallet.getBalance();
-        if (profit != null) {
-            if(canMoney.compareTo(BigDecimal.ZERO) > 0) {
-                canMoney = canMoney.subtract(profit);
-            }
-        }
-        return canMoney;
+        return wallet.getBalance().setScale(2,BigDecimal.ROUND_DOWN);
     }
 
     @Override
@@ -476,4 +485,440 @@
     public MallMember findMemberInfoByAccount(String phone) {
         return this.baseMapper.selectInfoByAccount(phone);
     }
+
+    @Override
+    public MyCommissionVo myCommission() {
+        Long id = LoginUserUtil.getLoginUser().getId();
+        MallMember mallMember = this.baseMapper.selectById(id);
+
+        MyCommissionVo commissionVo = MallMemberConversion.INSTANCE.entityToCommissionVo(mallMember);
+
+        MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
+        if (referMember != null) {
+            commissionVo.setReferrerName(referMember.getName());
+            commissionVo.setReferrerAvatar(referMember.getAvatar());
+        }
+
+        DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(AppContants.AGENT_LEVEL, mallMember.getLevel());
+        if (dic != null) {
+            commissionVo.setLevelName(dic.getDescription());
+        }
+
+        MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(id);
+        commissionVo.setCommission(wallet.getCommission());
+        commissionVo.setToday(mallMoneyFlowMapper.selectCommissionIncome(1, new Date(), id));
+        commissionVo.setMonth(mallMoneyFlowMapper.selectCommissionIncome(2, new Date(), id));
+        commissionVo.setTotal(mallMoneyFlowMapper.selectCommissionIncome(null, null, id));
+        commissionVo.setWaitCommission(BigDecimal.ZERO);
+        return commissionVo;
+    }
+
+    @Override
+    public void shopApply(ShopApplyDto shopApplyDto) {
+        MallMember member = LoginUserUtil.getLoginUser();
+
+        MallShopApply hasApply = mallShopApplyMapper.selectNewestApplyByMemberId(member.getId());
+        if (hasApply != null) {
+            if (!hasApply.getStatus().equals(MallShopApply.APPLY_DISAGREE)) {
+                throw new FebsException("请勿重复提交申请");
+            }
+        }
+
+        MallShopApply mallShopApply = new MallShopApply();
+        BeanUtil.copyProperties(shopApplyDto, mallShopApply);
+
+        mallShopApply.setStatus(MallShopApply.APPLY_ING);
+        mallShopApply.setMemberId(member.getId());
+        mallShopApplyMapper.insert(mallShopApply);
+    }
+
+    @Override
+    public MallShopApply findNewestApply() {
+        MallMember member = LoginUserUtil.getLoginUser();
+
+        return mallShopApplyMapper.selectNewestApplyByMemberId(member.getId());
+    }
+
+    @Override
+    public void addRegisterAppeal(RegisterAppealDto registerAppeal) {
+        MallRegisterAppeal isExist = mallRegisterAppealMapper.selectByPhoneAndName(registerAppeal.getName(), registerAppeal.getPhone());
+        if (isExist != null) {
+            throw new FebsException("申诉已存在");
+        }
+
+        isExist = new MallRegisterAppeal();
+        isExist.setName(registerAppeal.getName());
+        isExist.setPhone(registerAppeal.getPhone());
+        isExist.setStatus(2);
+
+        mallRegisterAppealMapper.insert(isExist);
+    }
+
+    @Override
+    public CashOutSettingVo cashOutSetting() {
+        CashOutSettingVo cashOutSettingVo = new CashOutSettingVo();
+        DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.CASHOUT_SETTING.getType(), DataDictionaryEnum.CASHOUT_SETTING.getCode());
+        if (dic != null) {
+            cashOutSettingVo = JSONObject.parseObject(dic.getValue(), CashOutSettingVo.class);
+        }
+        return cashOutSettingVo;
+    }
+
+    @Override
+    public List<ShopListVo> findShopListVo(ShopListDto shopListDto) {
+        Page<MallShopApply> page = new Page<>(shopListDto.getPageNow(), shopListDto.getPageSize());
+
+        MallShopApply shopApply = new MallShopApply();
+        shopApply.setStatus(MallShopApply.APPLY_AGREE);
+        IPage<MallShopApply> pageResult = mallShopApplyMapper.selectShopApplyInPage(shopApply, page);
+
+        List<MallShopApply> list = pageResult.getRecords();
+        if (CollUtil.isEmpty(list)) {
+            list = new ArrayList<>();
+        }
+        return MallShopApplyConversion.INSTANCE.entitiesToVOs(list);
+    }
+
+
+    private final XcxProperties xcxProperties = SpringContextHolder.getBean(XcxProperties.class);
+
+    @Override
+    public FebsResponse xcxLogin(ApiXcxLoginDto apiXcxLoginDto) throws IOException {
+        FebsResponse febsResponse = new FebsResponse();
+        String code = apiXcxLoginDto.getCode();
+        log.info("code:" + code);
+        if (StrUtil.isNotBlank(code)) {
+            String requrl = getXcxLoginUrl(code);
+            String reslutData = HttpCurlUtil.sendGetHttp(requrl, null);
+            net.sf.json.JSONObject json = net.sf.json.JSONObject.fromObject(reslutData);
+            log.info("微信登录获取到登录信息={}", json);
+
+            if (json.containsKey("errcode")) {
+                log.info("微信登录获取到异常信息errcode");
+                return febsResponse.fail().message("自动登录失败");
+            }
+
+            String openId = json.getString("openid");
+            String accessToken = json.getString("access_token");
+            log.info("openId={}", openId);
+            // 查询用户是否存在
+            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();
+            String existToken = redisUtils.getString(redisKey);
+            if (StrUtil.isNotBlank(existToken)) {
+                Object o = redisUtils.get(existToken);
+                if (ObjectUtil.isNotEmpty(o)) {
+                    redisUtils.del(existToken);
+                }
+            }
+            String token = IdUtil.simpleUUID();
+            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("自动登录失败");
+        }
+        return febsResponse;
+    }
+
+    @Override
+    public FebsResponse xcxSaveInfo(ApiXcxSaveInfoDto apiXcxSaveInfoDto) {
+        log.info("name={},phone={},avatar={},sex={}",
+                apiXcxSaveInfoDto.getNickName(),apiXcxSaveInfoDto.getPhone(),apiXcxSaveInfoDto.getAvatarUrl(),apiXcxSaveInfoDto.getGender());
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        MallMember mallMember = this.baseMapper.selectById(memberId);
+        String nickName = apiXcxSaveInfoDto.getNickName();
+        if(StrUtil.isNotEmpty(nickName)){
+            mallMember.setName(nickName);
+        }
+        String phone = apiXcxSaveInfoDto.getPhone();
+        if(StrUtil.isNotEmpty(phone)){
+            mallMember.setPhone(phone);
+        }
+        String avatarUrl = apiXcxSaveInfoDto.getAvatarUrl();
+        if(StrUtil.isNotEmpty(avatarUrl)){
+            mallMember.setAvatar(avatarUrl);
+        }
+//        mallMember.setSex(1 == apiXcxSaveInfoDto.getGender() ? "女" : "男");
+        this.baseMapper.updateById(mallMember);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse xcxPhoneLogin(ApiXcxPhoneLoginDto apiXcxPhoneLoginDto) {
+        String phone = apiXcxPhoneLoginDto.getPhone();
+        boolean flag = commonService.verifyCode(phone, apiXcxPhoneLoginDto.getCode());
+        if (flag) {
+            // 查询用户是否存在
+            MallMember mallMember = null;
+            synchronized (this) {
+                mallMember = this.baseMapper.selectInfoByAccount(apiXcxPhoneLoginDto.getPhone());
+                if (ObjectUtil.isEmpty(mallMember)) {
+                    // 新增用户
+                    mallMember = new MallMember();
+                    mallMember.setPhone(phone);
+                    mallMember.setAccountStatus(MallMember.ACCOUNT_STATUS_ENABLE);
+                    mallMember.setAccountType(MallMember.ACCOUNT_TYPE_NORMAL);
+                    mallMember.setLevel(AgentLevelEnum.ZERO_LEVEL.name());
+                    this.baseMapper.insert(mallMember);
+
+                    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);
+                }
+            }
+            // 存放redis
+            String redisKey = AppContants.XCX_LOGIN_PHONE_PREFIX + mallMember.getId();
+            String existToken = redisUtils.getString(redisKey);
+            if (StrUtil.isNotBlank(existToken)) {
+                Object o = redisUtils.get(existToken);
+                if (ObjectUtil.isNotEmpty(o)) {
+                    redisUtils.del(existToken);
+                }
+            }
+            String token = IdUtil.simpleUUID();
+            redisUtils.set(token, JSONObject.toJSONString(mallMember), 360000);
+            redisUtils.set(redisKey, token, 360000);
+            Map<String, Object> authInfo = new HashMap<>();
+            authInfo.put("token", token);
+            authInfo.put("member", mallMember);
+            authInfo.put("rasToken", generateAsaToken(token));
+            return new FebsResponse().success().data(authInfo);
+        }
+        return new FebsResponse().fail().message("验证码错误");
+    }
+
+    @Override
+    public FebsResponse xcxOpen(ApiXcxOpenDto apiXcxOpenDto) {
+        DataDictionaryCustom rangeSwitch = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.RANGE_SWITCH.getType(), DataDictionaryEnum.RANGE_SWITCH.getCode());
+        if(StrUtil.isNotBlank(rangeSwitch.getValue()) && "1".equals(rangeSwitch.getValue())){
+            if(ObjectUtil.isNull(apiXcxOpenDto.getLongitude()) || ObjectUtil.isNull(apiXcxOpenDto.getLatitude())){
+                return new FebsResponse().fail().message("请授权位置信息");
+            }
+            Double longitude = apiXcxOpenDto.getLongitude();
+            Double latitude = apiXcxOpenDto.getLatitude();
+
+            DataDictionaryCustom rangeSize = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.RANGE_SIZE.getType(), DataDictionaryEnum.RANGE_SIZE.getCode());
+            if(ObjectUtil.isEmpty(rangeSize)){
+                return new FebsResponse().success().data(2);
+            }
+            if(StrUtil.isBlank(rangeSize.getValue())){
+                return new FebsResponse().success().data(2);
+            }
+            //方位大小,换成单位:米
+            Integer value = Integer.parseInt(rangeSize.getValue()) * 1000;
+            //根据经纬度获取周围团长的距离
+            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByLonAndLat(longitude, latitude);
+            if(ObjectUtil.isEmpty(mallTeamLeader)){
+                return new FebsResponse().success().data(2);
+            }
+            Double distance = mallTeamLeader.getDistance();
+            if(value <= distance){
+                return new FebsResponse().success().data(2);
+            }
+        }
+        return new FebsResponse().success().data(1);
+    }
+
+    private final IXcxPayService iXcxPayService;
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public FebsResponse rechargeWallet(ApiRechargeWalletDto apiRechargeWalletDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        BigDecimal amount = apiRechargeWalletDto.getAmount();
+        if(BigDecimal.ZERO.compareTo(amount)>0){
+            return new FebsResponse().fail().message("请输入正确的充值金额");
+        }
+        Integer type = apiRechargeWalletDto.getType();
+        if(2 == type){
+            //成为合伙人的充值金额
+            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);
+            }
+        }
+        String rechargeNo = "CZ_"+MallUtils.getOrderNum();
+        apiRechargeWalletDto.setRechargeNo(rechargeNo);
+        apiRechargeWalletDto.setMemberId(memberId);
+        BrandWCPayRequestData brandWCPayRequestData = null;
+        try {
+            brandWCPayRequestData = iXcxPayService.startRechargeWallet(apiRechargeWalletDto);
+        } catch (Exception e) {
+            throw new FebsException("支付失败");
+        }
+        mallMoneyFlowService.addMoneyFlow(
+                memberId,
+                amount,
+                MoneyFlowTypeEnum.RECHARGE.getValue(),
+                rechargeNo,
+                FlowTypeEnum.BALANCE.getValue(),
+                "余额充值",1);
+
+        String wxResultStr = JSONUtil.toJsonStr(brandWCPayRequestData);
+        String payResultStr = brandWCPayRequestData.getPrepay_id();
+        Map<String, Object> map = new HashMap<>();
+        map.put("orderInfo", payResultStr);
+        map.put("wxResultStr", wxResultStr);
+        return new FebsResponse().success().data(map).message("充值即将到账");
+    }
+
+    @Override
+    public void updateMemberAgent(Long memberId,String levelCode) {
+        mallAgentRecordMapper.updateStateByMemberId(memberId);
+        MallAgentRecord mallAgentRecord = mallAgentRecordMapper.selectById(memberId);
+        //更新用户表中的LEVEL
+        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