From 0a6e3fcaa4850d319c4cfeb60b96c255eb476075 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Wed, 31 Jan 2024 11:04:40 +0800 Subject: [PATCH] 会员列表增加波卷功能 --- src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java | 302 ++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 291 insertions(+), 11 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..361081e 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,35 +1,40 @@ 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; +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 +48,16 @@ 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; + private final IMallMoneyFlowService mallMoneyFlowService; + private final MallMemberClassMapper mallMemberClassMapper; + private final MallMemberHouseMapper mallMemberHouseMapper; + private final MallMoneyFlowMapper mallMoneyFlowMapper; @Override @Transactional(rollbackFor = Exception.class) @@ -227,7 +242,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); @@ -283,4 +298,269 @@ 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); + /** + * 用户是否满足最低消费,满足则升级成为会员,可以邀请用户,并且查看会员商城 + */ + Integer isMember = mallMember.getIsMember(); + if(AppContants.MEMBER_STATE_NO == isMember){ + List<MallOrderInfo> mallOrderInfos = mallOrderInfoMapper.selectOrderInfoByStatus(OrderStatusEnum.FINISH.getValue()); + if(CollUtil.isNotEmpty(mallOrderInfos)){ + DataDictionaryCustom minAmountDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.MIN_AMOUNT_IS_MEMBER.getType(), + DataDictionaryEnum.MIN_AMOUNT_IS_MEMBER.getCode() + ); + BigDecimal minAmount = new BigDecimal(minAmountDic.getValue());//系统设置的累计消费金额 + BigDecimal accumulateAmount = mallOrderInfos.stream().map(MallOrderInfo::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);//累计消费金额 + if(minAmount.compareTo(accumulateAmount) <= 0){//用户累计消费大于系统设置的累计消费 + mallMember.setIsMember(AppContants.MEMBER_STATE_YES); + memberMapper.updateById(mallMember); + } + } + } + + List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(mallOrderInfo.getId()); + if(CollUtil.isEmpty(mallOrderItemList)){ + return; + } + + /** + * 支付后同意验证 + * 1:是否送券 + * 2:是否送积分 + * 3:是否返利 + */ + //是否返利 + BigDecimal amountBigDecimal = new BigDecimal(StrUtil.isEmpty(amount) ? "0" : amount); + BigDecimal parentUpAmount = BigDecimal.ZERO; + if(BigDecimal.ZERO.compareTo(amountBigDecimal) < 0){ + if(ObjectUtil.isNotEmpty(mallMember.getReferrerId())){ + String referrerId = mallMember.getReferrerId(); + MallMember mallMemberParent = memberMapper.selectInfoByInviteId(referrerId); + Long id = mallMemberParent.getId(); + + MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOneByOrderNoAndMemberIdAndRtMemberId(mallOrderInfo.getOrderNo(), memberId, id); + if(ObjectUtil.isEmpty(mallMoneyFlow)){ + DataDictionaryCustom returnPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.MEMBER_RETURN_PERCENT.getType(), + DataDictionaryEnum.MEMBER_RETURN_PERCENT.getCode() + ); + String returnPercentStr = StrUtil.isEmpty(returnPercentDic.getValue()) ? "10" : 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); + + mallMoneyFlowService.addMoneyFlow( + id, + amountActual, + MoneyFlowTypeEnum.DYNAMIC_ACHIEVE.getValue(), + mallOrderInfo.getOrderNo(), + "直推奖", + "直推奖", + mallMember.getId(), + 1, + FlowTypeEnum.BALANCE.getValue(), + 2); + parentUpAmount = amountActual; + } + + /** + * 拿下一级(直推的)收入的百分之五十 + */ + if(ObjectUtil.isNotEmpty(mallMemberParent.getReferrerId())){ + String referrerIdParentUp = mallMemberParent.getReferrerId(); + MallMember mallMemberParentUp = memberMapper.selectInfoByInviteId(referrerIdParentUp); + Long idParentUp = mallMemberParentUp.getId(); + MallMoneyFlow mallMoneyFlowParentUp = mallMoneyFlowMapper.selectOneByOrderNoAndMemberIdAndRtMemberId(mallOrderInfo.getOrderNo() + , idParentUp + , id); + if(ObjectUtil.isEmpty(mallMoneyFlowParentUp)){ + DataDictionaryCustom returnPercentUpDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + DataDictionaryEnum.MEMBER_RETURN_PERCENT_UP.getType(), + DataDictionaryEnum.MEMBER_RETURN_PERCENT_UP.getCode() + ); + String returnPercentUpStr = StrUtil.isEmpty(returnPercentUpDic.getValue()) ? "50" : returnPercentUpDic.getValue(); + BigDecimal returnPercentUp = new BigDecimal(returnPercentUpStr).divide(new BigDecimal(100), 2, BigDecimal.ROUND_DOWN); + BigDecimal amountActualUp = parentUpAmount.multiply(returnPercentUp).setScale(2, BigDecimal.ROUND_DOWN); + + mallMoneyFlowService.addMoneyFlow( + idParentUp, + amountActualUp, + MoneyFlowTypeEnum.DYNAMIC_ACHIEVE.getValue(), + mallOrderInfo.getOrderNo(), + "直推奖", + "直推奖", + id, + 1, + FlowTypeEnum.BALANCE.getValue(), + 2); + } + } + } + } + for(MallOrderItem mallOrderItem : mallOrderItemList){ + Long goodsId = mallOrderItem.getGoodsId(); + MallGoods mallGoods = mallGoodsMapper.selectById(goodsId); + if(ObjectUtil.isEmpty(mallGoods)){ + break; + } + if(ObjectUtil.isNotEmpty(mallGoods.getIsUnreal()) && 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(),"赠送积分",2); + } + } + } + } + + @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.setClassDec(mallGoods.getGoodsIntrodution()); + mallMemberClass.setClassUrl(mallGoods.getVideoUrl()); + mallMemberClass.setCreateTime(DateUtil.date()); + 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) { + + DateTime offset = DateUtil.date().offset(DateField.HOUR_OF_DAY, 48); + System.out.println(offset); + +// 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