From cbb77ae195e98d097a7d488ec07930c761529961 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Mon, 17 Apr 2023 18:02:36 +0800 Subject: [PATCH] 提现,限额 --- src/main/java/cc/mrbird/febs/mall/service/impl/MallMemberWithdrawServiceImpl.java | 17 +++++++++++++++++ src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml | 7 +++++++ src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java | 6 ++++++ 3 files changed, 30 insertions(+), 0 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java index 32cd998..95488b8 100644 --- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java +++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java @@ -3,5 +3,11 @@ import cc.mrbird.febs.mall.entity.MallMemberWithdraw; import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import java.util.Date; +import java.util.List; + public interface MallMemberWithdrawMapper extends BaseMapper<MallMemberWithdraw> { + + List<MallMemberWithdraw> selectListByMemberIdAndDate(Long memberId, Date date); + } diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/MallMemberWithdrawServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/MallMemberWithdrawServiceImpl.java index 7359cfc..fea85cd 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/MallMemberWithdrawServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/MallMemberWithdrawServiceImpl.java @@ -17,6 +17,7 @@ import cc.mrbird.febs.mall.service.IMallMemberWithdrawService; import cc.mrbird.febs.mall.service.MallMemberService; import cc.mrbird.febs.mall.vo.CashOutSettingVo; +import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import cn.hutool.crypto.SecureUtil; @@ -28,6 +29,8 @@ import org.springframework.transaction.annotation.Transactional; import java.math.BigDecimal; +import java.util.Date; +import java.util.List; /** * @author wzy @@ -65,6 +68,20 @@ cashOutSettingVo = JSONObject.parseObject(dic.getValue(), CashOutSettingVo.class); } + //每日提现额度上限 + BigDecimal allCashOut = cashOutSettingVo.getAllCashOut(); + if(withdrawalDto.getAmount().compareTo(allCashOut) > 0){ + throw new FebsException("限额:"+cashOutSettingVo.getAllCashOut().setScale(2,BigDecimal.ROUND_DOWN)); + } + List<MallMemberWithdraw> mallMemberWithdrawListDone = this.baseMapper.selectListByMemberIdAndDate(memberId,new Date()); + if(CollUtil.isNotEmpty(mallMemberWithdrawListDone)){ + BigDecimal amountTCAll = mallMemberWithdrawListDone.stream().map(MallMemberWithdraw::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add); + amountTCAll = amountTCAll.add(withdrawalDto.getAmount()); + if (amountTCAll.compareTo(allCashOut) > 0) { + throw new FebsException("限额:"+cashOutSettingVo.getAllCashOut().setScale(2,BigDecimal.ROUND_DOWN)); + } + } + if (withdrawalDto.getAmount().compareTo(cashOutSettingVo.getMinCashOut()) < 0) { throw new FebsException("最小提现金额为"+cashOutSettingVo.getMinCashOut().setScale(2,BigDecimal.ROUND_DOWN)); } diff --git a/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml b/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml index 69b88ee..d780db7 100644 --- a/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml +++ b/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml @@ -1,5 +1,12 @@ <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="cc.mrbird.febs.mall.mapper.MallMemberWithdrawMapper"> + <select id="selectListByMemberIdAndDate" resultType="cc.mrbird.febs.mall.entity.MallMemberWithdraw"> + select + a.* + from mall_member_withdraw a + where a.member_id = #{memberId} + and date_format(a.CREATED_TIME, '%Y-%m-%d') = date_format(#{date}, '%Y-%m-%d') + </select> </mapper> \ No newline at end of file -- Gitblit v1.9.1