|  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @author wzy | 
|---|
|  |  |  | 
|---|
|  |  |  | public void withdrawal(WithdrawalDto withdrawalDto) { | 
|---|
|  |  |  | Long memberId = LoginUserUtil.getLoginUser().getId(); | 
|---|
|  |  |  | MallMember mallMember = mallMemberService.getById(memberId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer outsideWith = mallMember.getOutsideWith() == null ? 2 :mallMember.getOutsideWith(); | 
|---|
|  |  |  | if (1 != outsideWith) { | 
|---|
|  |  |  | throw new FebsException("功能升级中"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (StrUtil.isBlank(mallMember.getTradePassword())) { | 
|---|
|  |  |  | throw new FebsException("未设置支付密码"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.CASHOUT_SETTING.getType(), DataDictionaryEnum.CASHOUT_SETTING.getCode()); | 
|---|
|  |  |  | if (dic != null) { | 
|---|
|  |  |  | 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) { | 
|---|
|  |  |  | 
|---|
|  |  |  | if(ObjectUtil.isEmpty(mallMemberBank.getSubbranchName())){ | 
|---|
|  |  |  | throw new FebsException("请填写所属支行"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(ObjectUtil.isEmpty(mallMemberBank.getDigitalNo())){ | 
|---|
|  |  |  | throw new FebsException("请填写数字货币账号"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        if(ObjectUtil.isEmpty(mallMemberBank.getDigitalNo())){ | 
|---|
|  |  |  | //            throw new FebsException("请填写数字货币账号"); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(memberId); | 
|---|
|  |  |  | // 可提现 | 
|---|