From 86cc20a154707c8ebc3d26b090d43ec01d550e61 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 03 Jan 2025 14:23:28 +0800
Subject: [PATCH] feat(mall): 添加会员权益升级功能
---
src/main/java/cc/mrbird/febs/mall/controller/ApiRunVipController.java | 26 +++
src/main/java/cc/mrbird/febs/mall/dto/ApiGrowBuyDto.java | 25 +++
src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java | 3
src/main/java/cc/mrbird/febs/mall/service/impl/RunVipServiceImpl.java | 306 ++++++++++++++++++++++++++++++++++++-
src/main/java/cc/mrbird/febs/mall/mapper/RunVipGrowMapper.java | 7
src/main/java/cc/mrbird/febs/common/enumerates/RunVipMoneyFlowTypeEnum.java | 5
src/main/java/cc/mrbird/febs/mall/dto/ApiGrowChargeDto.java | 28 +++
src/main/java/cc/mrbird/febs/mall/service/IRunVipService.java | 6
src/main/java/cc/mrbird/febs/mall/vo/ApiGrowInfoVo.java | 21 ++
src/main/java/cc/mrbird/febs/mall/entity/RunVipGrow.java | 28 +++
src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java | 1
11 files changed, 445 insertions(+), 11 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/RunVipMoneyFlowTypeEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/RunVipMoneyFlowTypeEnum.java
index 5c776f5..94848ad 100644
--- a/src/main/java/cc/mrbird/febs/common/enumerates/RunVipMoneyFlowTypeEnum.java
+++ b/src/main/java/cc/mrbird/febs/common/enumerates/RunVipMoneyFlowTypeEnum.java
@@ -8,6 +8,11 @@
/**
* 碳币兑换USDT
*/
+ COMMISSION_PAY_GROW(17,"升级权益,APP支付{}","升级权益,APP支付"),
+
+ /**
+ * 碳币兑换USDT
+ */
COMMISSION_PAY(16,"购买会员,APP支付{}","购买会员,APP支付"),
/**
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/ApiRunVipController.java b/src/main/java/cc/mrbird/febs/mall/controller/ApiRunVipController.java
index bf8caa8..5a15e00 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/ApiRunVipController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/ApiRunVipController.java
@@ -72,6 +72,32 @@
return new FebsResponse().success().data(iRunVipService.getChargeList(apiChargeListDto));
}
+ @ApiOperation(value = "【权益升级】权益升级详情", notes = "【权益升级】权益升级详情")
+ @ApiResponses({
+ @ApiResponse(code = 200, message = "success", response = ApiGrowInfoVo.class)
+ })
+ @PostMapping(value = "/growInfo")
+ public FebsResponse growInfo() {
+ return iRunVipService.growInfo();
+ }
+
+ @ApiOperation(value = "【权益升级】APP支付", notes = "【权益升级】APP支付")
+ @PostMapping(value = "/growBuy")
+ @SubmitRepeat
+ public FebsResponse growBuy(@RequestBody @Valid ApiGrowBuyDto apiGrowBuyDto) {
+ return iRunVipService.growBuy(apiGrowBuyDto);
+ }
+
+ @ApiOperation(value = "【权益升级】立即购买", notes = "【权益升级】立即购买")
+ @ApiResponses({
+ @ApiResponse(code = 200, message = "success", response = ApiGoChargeVo.class)
+ })
+ @PostMapping(value = "/growCharge")
+ @SubmitRepeat
+ public FebsResponse growCharge(@RequestBody @Valid ApiGrowChargeDto apiGrowChargeDto) {
+ return iRunVipService.growCharge(apiGrowChargeDto);
+ }
+
@ApiOperation(value = "【购买VIP】APP支付", notes = "【购买VIP】APP支付")
@PostMapping(value = "/balanceBuy")
@SubmitRepeat
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/ApiGrowBuyDto.java b/src/main/java/cc/mrbird/febs/mall/dto/ApiGrowBuyDto.java
new file mode 100644
index 0000000..7ee1640
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/ApiGrowBuyDto.java
@@ -0,0 +1,25 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+
+@Data
+@ApiModel(value = "ApiGrowBuyDto", description = "API信息参数接收类")
+public class ApiGrowBuyDto {
+
+ @NotNull(message = "请输入下一个等级")
+ @ApiModelProperty(value = "下一个等级", example = "123456")
+ private String levelNext;
+
+ @ApiModelProperty(value = "支付金额", example = "123456")
+ private BigDecimal amount;
+
+ @NotNull(message = "请输入资金密码")
+ @ApiModelProperty(value = "资金密码", example = "123456")
+ private String tradeWord;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/ApiGrowChargeDto.java b/src/main/java/cc/mrbird/febs/mall/dto/ApiGrowChargeDto.java
new file mode 100644
index 0000000..f951839
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/ApiGrowChargeDto.java
@@ -0,0 +1,28 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import javax.validation.constraints.NotNull;
+import java.math.BigDecimal;
+
+@Data
+@ApiModel(value = "ApiGrowChargeDto", description = "API信息参数接收类")
+public class ApiGrowChargeDto {
+
+ @NotNull(message = "请输入下一个等级")
+ @ApiModelProperty(value = "下一个等级", example = "123456")
+ private String levelNext;
+
+ @ApiModelProperty(value = "支付金额", example = "123456")
+ private BigDecimal amount;
+
+ @NotNull(message = "请输入资金密码")
+ @ApiModelProperty(value = "资金密码", example = "123456")
+ private String tradeWord;
+
+ @NotNull(message = "请选择地址")
+ @ApiModelProperty(value = "地址ID", example = "123456")
+ private Long addressId;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/RunVipGrow.java b/src/main/java/cc/mrbird/febs/mall/entity/RunVipGrow.java
new file mode 100644
index 0000000..2aa40a0
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/entity/RunVipGrow.java
@@ -0,0 +1,28 @@
+package cc.mrbird.febs.mall.entity;
+
+import cc.mrbird.febs.common.entity.BaseEntity;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ *
+ `member_id` bigint(20) DEFAULT NULL,
+ `level_now` varchar(100) DEFAULT NULL COMMENT '当前等级',
+ `level_next` varchar(100) DEFAULT NULL COMMENT '下一个级别',
+ `amount` decimal(20,2) DEFAULT NULL COMMENT '本次升级金额',
+ `amount_all` decimal(20,2) DEFAULT NULL COMMENT '升级下一个等级需要总金额',
+ `amount_now` decimal(20,2) DEFAULT NULL COMMENT '当前已投入升级的金额',
+ */
+@Data
+@TableName("run_vip_grow")
+public class RunVipGrow extends BaseEntity {
+
+ private Long memberId;
+ private String levelNow;
+ private String levelNext;
+ private BigDecimal amount;
+ private BigDecimal amountAll;
+ private BigDecimal amountNow;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/RunVipGrowMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/RunVipGrowMapper.java
new file mode 100644
index 0000000..61bccaf
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/RunVipGrowMapper.java
@@ -0,0 +1,7 @@
+package cc.mrbird.febs.mall.mapper;
+
+import cc.mrbird.febs.mall.entity.RunVipGrow;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+public interface RunVipGrowMapper extends BaseMapper<RunVipGrow> {
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/service/IRunVipService.java b/src/main/java/cc/mrbird/febs/mall/service/IRunVipService.java
index 28ef69a..fa2ae09 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/IRunVipService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/IRunVipService.java
@@ -24,4 +24,10 @@
ApiRunDataVo runData();
ApiRunHealthVo runHealth();
+
+ FebsResponse growInfo();
+
+ FebsResponse growBuy(ApiGrowBuyDto apiGrowBuyDto);
+
+ FebsResponse growCharge(ApiGrowChargeDto apiGrowChargeDto);
}
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 af1c944..81ac8aa 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
@@ -297,6 +297,7 @@
mallMemberVo.setWithdrawState(runVip.getWithdrawState());
mallMemberVo.setInsideState(runVip.getInsideState());
mallMemberVo.setCommissionState(runVip.getCommissionState());
+ mallMemberVo.setGrowState(runVip.getGrowState());
MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(mallMemberVo.getId());
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/RunVipServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/RunVipServiceImpl.java
index 635c78d..9912a03 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/RunVipServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/RunVipServiceImpl.java
@@ -30,8 +30,10 @@
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
import java.math.BigDecimal;
+import java.math.RoundingMode;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
@@ -52,6 +54,7 @@
private final MallMemberMapper mallMemberMapper;
private final IApiMallMemberWalletService walletService;
private final IMallMoneyFlowService mallMoneyFlowService;
+ private final RunVipGrowMapper runVipGrowMapper;
@Override
public List<ApiRunVipVo> vipInfo() {
Long memberId = LoginUserUtil.getLoginUser().getId();
@@ -86,12 +89,26 @@
throw new FebsException("资金密码错误");
}
Long runVipId = apiGoChargeDto.getRunVipId();
- RunVip runVip = this.baseMapper.selectById(runVipId);
- if(runVip.getState() != YesOrNoEnum.YES.getValue()){
+ RunVip runVipNext = this.baseMapper.selectById(runVipId);
+ if(runVipNext.getState() != YesOrNoEnum.YES.getValue()){
throw new FebsException("会员套餐已下架");
}
//价格
- BigDecimal presentAmount = runVip.getPresentPrice().multiply(new BigDecimal(apiGoChargeDto.getVipCnt())).setScale(2,BigDecimal.ROUND_DOWN);
+ BigDecimal presentAmount = runVipNext.getPresentPrice().multiply(new BigDecimal(apiGoChargeDto.getVipCnt())).setScale(2,BigDecimal.ROUND_DOWN);
+ //减免价格
+ RunVip runVip = this.baseMapper.selectOne(new LambdaQueryWrapper<RunVip>().eq(RunVip::getVipCode, mallMember.getLevel()));
+ BigDecimal reduceAmount = runVip.getPresentPrice();
+ RunVipGrow runVipGrow = runVipGrowMapper.selectList(
+ new LambdaQueryWrapper<RunVipGrow>()
+ .eq(RunVipGrow::getMemberId, memberId)
+ .eq(RunVipGrow::getLevelNow, mallMember.getLevel())
+ .orderByDesc(RunVipGrow::getId)
+ ).stream().findFirst().orElse(null);
+ if(runVipGrow != null){
+ BigDecimal amountNow = runVipGrow.getAmountNow();
+ reduceAmount = reduceAmount.add(amountNow);
+ }
+ presentAmount = presentAmount.subtract(reduceAmount);
Long addressId = apiGoChargeDto.getAddressId();
MallMemberPayment mallMemberPayment = mallMemberPaymentMapper.selectById(addressId);
@@ -131,8 +148,8 @@
mallCharge.setAmount(presentAmount);
mallCharge.setFailTime(failTime);
mallCharge.setSysAddress(sysAddress);
- mallCharge.setVipCode(runVip.getVipCode());
- mallCharge.setVipName(runVip.getVipName());
+ mallCharge.setVipCode(runVipNext.getVipCode());
+ mallCharge.setVipName(runVipNext.getVipName());
mallCharge.setVipCnt(apiGoChargeDto.getVipCnt());
mallChargeMapper.insert(mallCharge);
@@ -156,6 +173,7 @@
}
@Override
+ @Transactional(rollbackFor = Exception.class)
public FebsResponse balanceBuy(ApiBalanceBuyDto apiBalanceBuyDto) {
Long memberId = LoginUserUtil.getLoginUser().getId();
MallMember mallMember = mallMemberMapper.selectById(memberId);
@@ -167,12 +185,28 @@
throw new FebsException("资金密码错误");
}
Long runVipId = apiBalanceBuyDto.getRunVipId();
- RunVip runVip = this.baseMapper.selectById(runVipId);
- if(runVip.getState() != YesOrNoEnum.YES.getValue()){
+ RunVip runVipNext = this.baseMapper.selectById(runVipId);
+ if(runVipNext.getState() != YesOrNoEnum.YES.getValue()){
throw new FebsException("会员套餐已下架");
}
+
//价格
- BigDecimal presentAmount = runVip.getPresentPrice().setScale(2,BigDecimal.ROUND_DOWN);
+ BigDecimal presentAmount = runVipNext.getPresentPrice().setScale(2,BigDecimal.ROUND_DOWN);
+ //减免价格
+ RunVip runVip = this.baseMapper.selectOne(new LambdaQueryWrapper<RunVip>().eq(RunVip::getVipCode, mallMember.getLevel()));
+ BigDecimal reduceAmount = runVip.getPresentPrice();
+ RunVipGrow runVipGrow = runVipGrowMapper.selectList(
+ new LambdaQueryWrapper<RunVipGrow>()
+ .eq(RunVipGrow::getMemberId, memberId)
+ .eq(RunVipGrow::getLevelNow, mallMember.getLevel())
+ .orderByDesc(RunVipGrow::getId)
+ ).stream().findFirst().orElse(null);
+ if(runVipGrow != null){
+ BigDecimal amountNow = runVipGrow.getAmountNow();
+ reduceAmount = reduceAmount.add(amountNow);
+ }
+ presentAmount = presentAmount.subtract(reduceAmount);
+
MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
if(mallMemberWallet.getCommission().compareTo(BigDecimal.ZERO) <= 0){
throw new FebsException("余额不足");
@@ -189,7 +223,7 @@
orderNo,
FlowTypeEnum.COMMISSION.getValue(),
RunVipMoneyFlowTypeEnum.COMMISSION_PAY.getValue(),
- presentAmount,
+ presentAmount.negate(),
StrUtil.format(RunVipMoneyFlowTypeEnum.COMMISSION_PAY.getDescription(),presentAmount),
YesOrNoEnum.YES.getValue()
);
@@ -201,8 +235,8 @@
mallCharge.setType(StrUtil.format(RunVipMoneyFlowTypeEnum.COMMISSION_PAY.getDescription(),presentAmount));
mallCharge.setAddress(mallMember.getPhone());
mallCharge.setAmount(presentAmount);
- mallCharge.setVipCode(runVip.getVipCode());
- mallCharge.setVipName(runVip.getVipName());
+ mallCharge.setVipCode(runVipNext.getVipCode());
+ mallCharge.setVipName(runVipNext.getVipName());
mallCharge.setVipCnt(apiBalanceBuyDto.getVipCnt());
mallChargeMapper.insert(mallCharge);
@@ -384,4 +418,254 @@
}
return apiRunHealthVo;
}
+
+ @Override
+ public FebsResponse growInfo() {
+ Long memberId = LoginUserUtil.getLoginUser().getId();
+ ApiGrowInfoVo apiGrowInfoVo = new ApiGrowInfoVo();
+ MallMember mallMember = mallMemberMapper.selectById(memberId);
+ String memberLevel = mallMember.getLevel();
+
+ RunVipGrow runVipGrow = runVipGrowMapper.selectOne(
+ new LambdaQueryWrapper<RunVipGrow>()
+ .eq(RunVipGrow::getMemberId, memberId)
+ .orderByDesc(RunVipGrow::getId)
+ .last("limit 1")
+ );
+
+ //有升级权益的记录、当前等级和最新的升级记录是同一个
+ if(runVipGrow != null && memberLevel.equals(runVipGrow.getLevelNow())){
+ apiGrowInfoVo.setLevelNow(runVipGrow.getLevelNow());
+ apiGrowInfoVo.setAmountNow(runVipGrow.getAmountNow());
+ apiGrowInfoVo.setLevelNext(runVipGrow.getLevelNext());
+ apiGrowInfoVo.setAmountAll(runVipGrow.getAmountAll());
+ }else{
+ List<RunVip> runVips = this.baseMapper.selectList(null);
+ Map<String, RunVip> runVipMap = runVips.stream()
+ .collect(Collectors.toMap(RunVip::getVipCode, runVip -> runVip));
+ RunVip runVipNow = runVipMap.get(memberLevel);
+ apiGrowInfoVo.setLevelNow(runVipNow.getVipCode());
+ apiGrowInfoVo.setAmountNow(runVipNow.getPresentPrice());
+
+ //获取runVips中的orderNumber为runVipNow.getOrderNumber() + 1的那个元素
+ RunVip runVipNext = runVips.stream().filter(runVip -> runVip.getOrderNumber() == runVipNow.getOrderNumber() + 1).findFirst().orElse(null);
+ if(runVipNext != null){
+ apiGrowInfoVo.setLevelNext(runVipNext.getVipCode());
+ apiGrowInfoVo.setAmountAll(runVipNext.getPresentPrice());
+ }
+ }
+ return new FebsResponse().success().data(apiGrowInfoVo);
+ }
+
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public FebsResponse growBuy(ApiGrowBuyDto apiGrowBuyDto) {
+ Long memberId = LoginUserUtil.getLoginUser().getId();
+
+ BigDecimal amount = apiGrowBuyDto.getAmount();
+ if(BigDecimal.ZERO.compareTo(amount) >= 0){
+ throw new FebsException("金额异常");
+ }
+
+ MallMember mallMember = mallMemberMapper.selectById(memberId);
+ if (StrUtil.isBlank(mallMember.getTradePassword())) {
+ throw new FebsException("未设置资金密码");
+ }
+
+ if (!mallMember.getTradePassword().equals(SecureUtil.md5(apiGrowBuyDto.getTradeWord()))) {
+ throw new FebsException("资金密码错误");
+ }
+
+ MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
+ if(mallMemberWallet.getCommission().compareTo(amount) < 0){
+ throw new FebsException("余额不足");
+ }
+
+ String memberLevel = mallMember.getLevel();
+ String levelNext = apiGrowBuyDto.getLevelNext();
+
+ List<RunVip> runVips = this.baseMapper.selectList(null);
+ Map<String, RunVip> runVipMap = runVips.stream()
+ .collect(Collectors.toMap(RunVip::getVipCode, runVip -> runVip));
+ RunVip runVip = runVipMap.get(memberLevel);
+ RunVip runVipNext = runVipMap.get(levelNext);
+ if(runVipNext == null){
+ throw new FebsException("无法升级会员权益");
+ }
+ if(runVip.getOrderNumber() < runVipNext.getOrderNumber()){
+ throw new FebsException("用户无法升级");
+ }
+
+ walletService.reduceCommission(amount,memberId);
+ String orderNo = MallUtils.getOrderNum("QY");
+ mallMoneyFlowService.runVipMoneyFlowAdd(
+ memberId,
+ memberId,
+ orderNo,
+ FlowTypeEnum.COMMISSION.getValue(),
+ RunVipMoneyFlowTypeEnum.COMMISSION_PAY_GROW.getValue(),
+ amount.negate(),
+ StrUtil.format(RunVipMoneyFlowTypeEnum.COMMISSION_PAY_GROW.getDescription(),amount),
+ YesOrNoEnum.YES.getValue()
+ );
+
+ RunVipGrow runVipGrow = runVipGrowMapper.selectOne(
+ new LambdaQueryWrapper<RunVipGrow>()
+ .eq(RunVipGrow::getMemberId, memberId)
+ .eq(RunVipGrow::getLevelNow, memberLevel)
+ .eq(RunVipGrow::getLevelNext, levelNext)
+ );
+
+ MallCharge mallCharge = new MallCharge();
+ mallCharge.setMemberId(memberId);
+ mallCharge.setOrderNo(orderNo);
+ mallCharge.setState(YesOrNoEnum.YES.getValue());
+ mallCharge.setType(StrUtil.format(RunVipMoneyFlowTypeEnum.COMMISSION_PAY_GROW.getDescription(),amount));
+ mallCharge.setAddress(mallMember.getPhone());
+ mallCharge.setAmount(amount);
+ mallCharge.setVipCnt(1);
+ mallCharge.setVipName(runVip.getVipName()+"权益");
+ mallCharge.setVipCode(runVip.getVipCode());
+ //有升级权益的记录
+ if(runVipGrow != null){
+ //判断金额是否满足升级条件
+ BigDecimal amountNow = runVipGrow.getAmountNow();
+ BigDecimal amountAll = runVipGrow.getAmountAll();
+ BigDecimal subtract = amountAll.subtract(amountNow);
+
+ if(subtract.compareTo(amount) <= 0){
+ runVipGrow.setAmountNow(amountAll);
+
+ mallCharge.setVipCode(runVipGrow.getLevelNext());
+ }else{
+ runVipGrow.setAmountNow(amountNow.add(amount).setScale(2, RoundingMode.DOWN));
+
+ mallCharge.setVipCode(memberLevel);
+ }
+ runVipGrow.setAmount(amount);
+ runVipGrowMapper.updateById(runVipGrow);
+ }else{
+ runVipGrow = new RunVipGrow();
+ runVipGrow.setMemberId(memberId);
+ runVipGrow.setLevelNow(memberLevel);
+ runVipGrow.setLevelNext(runVipNext.getVipCode());
+ runVipGrow.setAmountAll(runVipNext.getPresentPrice());
+ runVipGrow.setAmount(amount);
+ runVipGrow.setAmountNow(amount);
+ runVipGrowMapper.insert(runVipGrow);
+
+ if(runVipGrow.getAmountAll().compareTo(amount) <= 0){
+ mallCharge.setVipCode(runVipGrow.getLevelNext());
+ }
+ }
+ mallChargeMapper.insert(mallCharge);
+
+ agentProducer.sendBuyVipSuccessMsg(mallCharge.getId());
+
+ return new FebsResponse().success().data("操作成功");
+ }
+
+ @Override
+ public FebsResponse growCharge(ApiGrowChargeDto apiGrowChargeDto) {
+ Long memberId = LoginUserUtil.getLoginUser().getId();
+
+ BigDecimal amount = apiGrowChargeDto.getAmount();
+ if(BigDecimal.ZERO.compareTo(amount) >= 0){
+ throw new FebsException("金额异常");
+ }
+
+ MallMember mallMember = mallMemberMapper.selectById(memberId);
+ if (StrUtil.isBlank(mallMember.getTradePassword())) {
+ throw new FebsException("未设置资金密码");
+ }
+
+ if (!mallMember.getTradePassword().equals(SecureUtil.md5(apiGrowChargeDto.getTradeWord()))) {
+ throw new FebsException("资金密码错误");
+ }
+
+ String memberLevel = mallMember.getLevel();
+ String levelNext = apiGrowChargeDto.getLevelNext();
+
+ List<RunVip> runVips = this.baseMapper.selectList(null);
+ Map<String, RunVip> runVipMap = runVips.stream()
+ .collect(Collectors.toMap(RunVip::getVipCode, runVip -> runVip));
+ RunVip runVip = runVipMap.get(memberLevel);
+ RunVip runVipNext = runVipMap.get(levelNext);
+ if(runVipNext == null){
+ throw new FebsException("无法升级会员权益");
+ }
+ if(runVip.getOrderNumber() < runVipNext.getOrderNumber()){
+ throw new FebsException("用户无法升级");
+ }
+
+ Long addressId = apiGrowChargeDto.getAddressId();
+ MallMemberPayment mallMemberPayment = mallMemberPaymentMapper.selectById(addressId);
+ if(ObjectUtil.isEmpty(mallMemberPayment)){
+ return new FebsResponse().fail().message("请先绑定你的地址");
+ }
+
+ //判断系统的充值地址
+ String trcType = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ RunVipDataDictionaryEnum.CHARGE_TYPE_TRC.getType(),
+ RunVipDataDictionaryEnum.CHARGE_TYPE_TRC.getCode()
+ ).getValue();
+ String sysAddress = "";
+ if(trcType.equals(mallMemberPayment.getBankNo())){
+ sysAddress = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ RunVipDataDictionaryEnum.CHARGE_SYS_ADDRESS_TRC.getType(),
+ RunVipDataDictionaryEnum.CHARGE_SYS_ADDRESS_TRC.getCode()
+ ).getValue();
+ }else{
+ sysAddress = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ RunVipDataDictionaryEnum.CHARGE_SYS_ADDRESS_BSC.getType(),
+ RunVipDataDictionaryEnum.CHARGE_SYS_ADDRESS_BSC.getCode()
+ ).getValue();
+ }
+ String failMinutes = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ RunVipDataDictionaryEnum.CHARGE_SYS_FAIL_TIME.getType(),
+ RunVipDataDictionaryEnum.CHARGE_SYS_FAIL_TIME.getCode()
+ ).getValue();
+ DateTime failTime = DateUtil.offsetMinute(DateUtil.date(), Integer.parseInt(failMinutes));
+
+ MallCharge mallCharge = new MallCharge();
+ String orderNo = MallUtils.getOrderNum("QY");
+ mallCharge.setMemberId(memberId);
+ mallCharge.setOrderNo(orderNo);
+ mallCharge.setState(YesOrNoEnum.ING.getValue());
+ mallCharge.setType(mallMemberPayment.getBankNo());
+ mallCharge.setAddress(mallMemberPayment.getBank());
+ mallCharge.setFailTime(failTime);
+ mallCharge.setSysAddress(sysAddress);
+
+ mallCharge.setAmount(amount);
+ mallCharge.setVipCnt(1);
+ mallCharge.setVipName(runVip.getVipName()+"权益");
+ mallCharge.setVipCode(runVip.getVipCode());
+
+ RunVipGrow runVipGrow = runVipGrowMapper.selectOne(
+ new LambdaQueryWrapper<RunVipGrow>()
+ .eq(RunVipGrow::getMemberId, memberId)
+ .eq(RunVipGrow::getLevelNow, memberLevel)
+ .eq(RunVipGrow::getLevelNext, levelNext)
+ );
+
+ //有升级权益的记录、当前等级和最新的升级记录是同一个
+ if(runVipGrow != null){
+ //判断金额是否满足升级条件
+ BigDecimal amountNow = runVipGrow.getAmountNow();
+ BigDecimal amountAll = runVipGrow.getAmountAll();
+ BigDecimal subtract = amountAll.subtract(amountNow);
+
+ if(subtract.compareTo(amount) <= 0){
+ mallCharge.setVipCode(runVipGrow.getLevelNext());
+ }
+ }else{
+ if(runVipGrow.getAmountAll().compareTo(amount) <= 0){
+ mallCharge.setVipCode(runVipGrow.getLevelNext());
+ }
+ }
+
+ mallChargeMapper.insert(mallCharge);
+ return new FebsResponse().success().data("操作成功");
+ }
}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/ApiGrowInfoVo.java b/src/main/java/cc/mrbird/febs/mall/vo/ApiGrowInfoVo.java
new file mode 100644
index 0000000..af9e25e
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/ApiGrowInfoVo.java
@@ -0,0 +1,21 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+@Data
+@ApiModel(value = "ApiGoChargeVo", description = "基础数据")
+public class ApiGrowInfoVo {
+
+ @ApiModelProperty(value = "当前等级")
+ private String levelNow;
+ @ApiModelProperty(value = "当前已投入升级的金额")
+ private BigDecimal amountNow = BigDecimal.ZERO;
+ @ApiModelProperty(value = "下一个等级")
+ private String levelNext;
+ @ApiModelProperty(value = "升级下一个等级需要总金额")
+ private BigDecimal amountAll = BigDecimal.ZERO;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java b/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java
index 18c9434..20ae176 100644
--- a/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java
+++ b/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java
@@ -42,6 +42,9 @@
@ApiModelProperty(value = "是否允许USDT提现 1是0否")
private Integer commissionState;//是否允许USDT提现 1是0否
+ @ApiModelProperty(value = "是否允许权益升级 1-是0-否")
+ private Integer growState;//是否允许权益升级 1-是0-否
+
@ApiModelProperty(value = "碳币")
private BigDecimal balance = BigDecimal.ZERO;
@ApiModelProperty(value = "碳积分")
--
Gitblit v1.9.1