From 1ce0aef813257a1c8949371fb1fbf3df7a3e87d7 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Thu, 30 Nov 2023 17:01:49 +0800
Subject: [PATCH] 预约列表

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java |   85 +++++++++++++++++++++++++++++++-----------
 1 files changed, 62 insertions(+), 23 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java
index ad8e578..1f2f630 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java
@@ -89,6 +89,11 @@
          * 预约,验证交易密码、预约产品是否开启状态、该产品是否已经预约、token是否足够
          * 冻结对应的令牌数量、生成预约记录、生成流水记录
          */
+        Boolean aBoolean = operationPermissionMemberFrozen(memberId);
+        if(aBoolean){
+            throw new FebsException("用户已冻结");
+        }
+
         DateTime nowTime = DateUtil.parseTime(DateUtil.formatTime(DateUtil.date()));
         DataDictionaryCustom startTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
                 DataDictionaryEnum.YU_YUE_START_TIME.getType(),
@@ -164,6 +169,11 @@
          * 计算手续费、减少用户的fcm余额
          * 增加流水
          */
+
+        Boolean aBoolean = operationPermissionMemberFrozen(memberId);
+        if(aBoolean){
+            throw new FebsException("用户已冻结");
+        }
         if(!tradePassword.equals(mallMember.getTradePassword())){
             throw new FebsException("请输入正确的交易密码");
         }
@@ -216,8 +226,9 @@
                 FlowTypeNewEnum.FCM_COIN.getValue(),
                 MoneyFlowTypeNewEnum.FCM_OUT_FEE.getDescrition());
 
-        mallMemberAmount.setTrendsNft(mallMemberAmount.getTrendsNft().add(nftCnt));
-        mallMemberAmountMapper.updateTrendsNftById(mallMemberAmount);
+        MallMemberAmount mallMemberAmountNft = mallMemberAmountMapper.selectByMemberId(memberId);
+        mallMemberAmountNft.setTrendsNft(mallMemberAmountNft.getTrendsNft().add(nftCnt));
+        mallMemberAmountMapper.updateTrendsNftById(mallMemberAmountNft);
         String orderNoNFT = MallUtils.getOrderNum("NFT");
         iMallMoneyFlowService.addMoneyFlow(
                 memberId,
@@ -243,6 +254,11 @@
          * 计算手续费、减少动态NFT、增加冻结NFT
          * 增加流水
          */
+
+        Boolean aBoolean = operationPermissionMemberFrozen(memberId);
+        if(aBoolean){
+            throw new FebsException("用户已冻结");
+        }
         if(!tradePassword.equals(mallMember.getTradePassword())){
             throw new FebsException("请输入正确的交易密码");
         }
@@ -265,21 +281,23 @@
         BigDecimal nftFeePercent = ObjectUtil.isEmpty(nftFeeDic) ? new BigDecimal(20) : new BigDecimal(nftFeeDic.getValue());
         nftFeePercent = nftFeePercent.divide(new BigDecimal(100),4,BigDecimal.ROUND_DOWN);
         BigDecimal nftFee = nftCnt.multiply(nftFeePercent);
-        BigDecimal nftCntAva = nftCnt.subtract(nftFee);
-
         DataDictionaryCustom fcmPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
                 DataDictionaryEnum.FCM_PRICE.getType(),
                 DataDictionaryEnum.FCM_PRICE.getCode());
         BigDecimal fcmPrice = ObjectUtil.isEmpty(fcmPriceDic) ? new BigDecimal(2) : new BigDecimal(fcmPriceDic.getValue());
         BigDecimal fcmFeeCnt = nftFee.divide(fcmPrice, 2, BigDecimal.ROUND_DOWN);
+        if(BigDecimal.ZERO.compareTo(mallMemberAmount.getTrendsNft()) >= 0
+            || fcmFeeCnt.compareTo(mallMemberAmount.getFcmCntAva()) > 0){
+            throw new FebsException("手续费不足");
+        }
 
         String orderNo = MallUtils.getOrderNum("NFT");
         MallProductSell mallProductSell = new MallProductSell();
         mallProductSell.setMemberId(memberId);
         mallProductSell.setOrderNo(orderNo);
         mallProductSell.setNftTotal(nftCnt);
-        mallProductSell.setNftCnt(nftCntAva);
-        mallProductSell.setNftCntAva(nftCntAva);
+        mallProductSell.setNftCnt(nftCnt);
+        mallProductSell.setNftCntAva(nftCnt);
         mallProductSell.setNftFee(nftFee);
         mallProductSell.setFcmFee(fcmFeeCnt);
         mallProductSell.setState(ProductEnum.PRODUCT_SELL_ON_GOING.getValue());
@@ -288,11 +306,13 @@
         mallMemberAmount.setTrendsNft(mallMemberAmount.getTrendsNft().subtract(nftCnt));
         mallMemberAmountMapper.updateTrendsNftById(mallMemberAmount);
 
-        mallMemberAmount.setFcmCntAva(mallMemberAmount.getFcmCntAva().subtract(fcmFeeCnt));
-        mallMemberAmountMapper.updateFcmCntAvaById(mallMemberAmount);
+        MallMemberAmount mallMemberAmountFcm = mallMemberAmountMapper.selectByMemberId(memberId);
+        mallMemberAmountFcm.setFcmCntAva(mallMemberAmountFcm.getFcmCntAva().subtract(fcmFeeCnt));
+        mallMemberAmountMapper.updateFcmCntAvaById(mallMemberAmountFcm);
 
-        mallMemberAmount.setFrozenNft(mallMemberAmount.getFrozenNft().add(nftCntAva));
-        mallMemberAmountMapper.updateFrozenNftById(mallMemberAmount);
+        MallMemberAmount mallMemberAmountFrozenNFT = mallMemberAmountMapper.selectByMemberId(memberId);
+        mallMemberAmountFrozenNFT.setFrozenNft(mallMemberAmountFrozenNFT.getFrozenNft().add(nftCnt));
+        mallMemberAmountMapper.updateFrozenNftById(mallMemberAmountFrozenNFT);
         iMallMoneyFlowService.addMoneyFlow(
                 memberId,
                 nftCnt.negate(),
@@ -303,21 +323,12 @@
                 MoneyFlowTypeNewEnum.NFT_OUT.getDescrition());
         iMallMoneyFlowService.addMoneyFlow(
                 memberId,
-                nftFee.negate(),
-                MoneyFlowTypeNewEnum.NFT_OUT_FEE.getValue(),
+                fcmFeeCnt.negate(),
+                MoneyFlowTypeNewEnum.NFT_OUT_FEE_FCM.getValue(),
                 orderNo,
                 mallMember.getId(),
-                FlowTypeNewEnum.NFT.getValue(),
-                MoneyFlowTypeNewEnum.NFT_OUT_FEE.getDescrition());
-        iMallMoneyFlowService.addMoneyFlow(
-                memberId,
-                nftFee.negate(),
-                MoneyFlowTypeNewEnum.NFT_OUT_FEE.getValue(),
-                orderNo,
-                mallMember.getId(),
-                FlowTypeNewEnum.NFT.getValue(),
-                MoneyFlowTypeNewEnum.NFT_OUT_FEE.getDescrition());
-
+                FlowTypeNewEnum.FCM_COIN.getValue(),
+                MoneyFlowTypeNewEnum.NFT_OUT_FEE_FCM.getDescrition());
         agentProducer.sendFcmNFTExchangeMsg(fcmFeeCnt.toString());
         return new FebsResponse().success();
     }
@@ -420,6 +431,11 @@
          * 更新卖单状态
          * 生成流水信息
          */
+
+        Boolean aBoolean = operationPermissionMemberFrozen(memberId);
+        if(aBoolean){
+            throw new FebsException("用户已冻结");
+        }
         if(!tradePassword.equals(mallMember.getTradePassword())){
             throw new FebsException("请输入正确的交易密码");
         }
@@ -478,6 +494,11 @@
          * 更新卖单状态
          * 生成流水信息
          */
+
+        Boolean aBoolean = operationPermissionMemberFrozen(memberId);
+        if(aBoolean){
+            throw new FebsException("用户已冻结");
+        }
         if(!tradePassword.equals(mallMember.getTradePassword())){
             throw new FebsException("请输入正确的交易密码");
         }
@@ -508,4 +529,22 @@
         agentProducer.sendFcmOrderSellInsureMsg(sellRecordId);
         return new FebsResponse().success();
     }
+
+    @Override
+    public FebsResponse orderBuyList(ApiOrderBuyDto apiOrderBuyDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        IPage<ApiOrderBuyVo> page = new Page<>(apiOrderBuyDto.getPageNum(), apiOrderBuyDto.getPageSize());
+        apiOrderBuyDto.setMemberId(memberId);
+        IPage<ApiOrderBuyVo> apiOrderBuyVoIPage = mallProductBuyMapper.selectBuyListInPage(page, apiOrderBuyDto);
+        return new FebsResponse().success().data(apiOrderBuyVoIPage);
+    }
+
+    @Override
+    public Boolean operationPermissionMemberFrozen(Long memberId) {
+        MallMember mallMember = memberMapper.selectById(memberId);
+        if(ProductEnum.MEMBER_FROZEN.getValue() == mallMember.getIsFrozen()){
+            return true;
+        }
+        return false;
+    }
 }

--
Gitblit v1.9.1