From 46e65fb48af4fda3c8fd32abb948365fd1cbaa3a Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Mon, 27 Nov 2023 15:31:12 +0800
Subject: [PATCH] 匹配

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java |  257 +++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 247 insertions(+), 10 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 c2750fd..2d4a298 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
@@ -8,17 +8,20 @@
 import cc.mrbird.febs.common.exception.FebsException;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.MallUtils;
-import cc.mrbird.febs.mall.dto.ApiCreateNFTDto;
-import cc.mrbird.febs.mall.dto.ApiOutFcmDto;
-import cc.mrbird.febs.mall.dto.ApiOutNFTDto;
+import cc.mrbird.febs.mall.dto.*;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.IApiMallProductService;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
-import cc.mrbird.febs.mall.vo.ApiMallProductNftVo;
+import cc.mrbird.febs.mall.vo.*;
 import cc.mrbird.febs.rabbit.producter.AgentProducer;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateTime;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.crypto.SecureUtil;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
@@ -26,6 +29,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
+import java.util.ArrayList;
 import java.util.List;
 
 @Slf4j
@@ -41,10 +45,36 @@
     private final AgentProducer agentProducer;
     private final MallProductSellMapper mallProductSellMapper;
     private final MallProductSellRecordMapper mallProductSellRecordMapper;
+    private final MallProductBuyRecordMapper mallProductBuyRecordMapper;
 
     @Override
     public List<ApiMallProductNftVo> productNFTList() {
+
+        DateTime nowTime = DateUtil.parseTime(DateUtil.formatTime(DateUtil.date()));
+        DataDictionaryCustom startTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_START_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_START_TIME.getCode()
+        );
+        DateTime startTime = DateUtil.parseTime(startTimeDic.getValue());
+        DataDictionaryCustom endTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_END_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_END_TIME.getCode()
+        );
+        DateTime endTime = DateUtil.parseTime(endTimeDic.getValue());
         List<ApiMallProductNftVo> list = this.baseMapper.selectByState(ProductEnum.PRODUCT_NFT_OPEN.getValue());
+        if(CollUtil.isNotEmpty(list)){
+            for(ApiMallProductNftVo apiMallProductNftVo : list){
+                if(nowTime.compareTo(startTime) < 0){
+                    apiMallProductNftVo.setYuYueState(1);
+                }
+                if(nowTime.compareTo(startTime) >= 0 && nowTime.compareTo(endTime) <= 0){
+                    apiMallProductNftVo.setYuYueState(2);
+                }
+                if(nowTime.compareTo(endTime) > 0){
+                    apiMallProductNftVo.setYuYueState(3);
+                }
+            }
+        }
         return list;
     }
 
@@ -59,6 +89,20 @@
          * 预约,验证交易密码、预约产品是否开启状态、该产品是否已经预约、token是否足够
          * 冻结对应的令牌数量、生成预约记录、生成流水记录
          */
+        DateTime nowTime = DateUtil.parseTime(DateUtil.formatTime(DateUtil.date()));
+        DataDictionaryCustom startTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_START_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_START_TIME.getCode()
+        );
+        DateTime startTime = DateUtil.parseTime(startTimeDic.getValue());
+        DataDictionaryCustom endTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_END_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_END_TIME.getCode()
+        );
+        DateTime endTime = DateUtil.parseTime(endTimeDic.getValue());
+        if(!(nowTime.compareTo(startTime) >= 0 && nowTime.compareTo(endTime) <= 0)){
+            throw new FebsException("预约未开始");
+        }
         if(!tradePassword.equals(mallMember.getTradePassword())){
             throw new FebsException("请输入正确的交易密码");
         }
@@ -70,7 +114,7 @@
             throw new FebsException("预约超时");
         }
         MallProductBuy mallProductBuy = mallProductBuyMapper.selectMemberIdAndNFTIdAndStateAndMateState(
-                memberId,productNFTId,ProductEnum.PRODUCT_BUY_ON_GOING.getValue(),null);
+                memberId,productNFTId,ProductEnum.PRODUCT_BUY_ON_GOING.getValue(),ProductEnum.PRODUCT_BUY_MATE_STATE_FAIL.getValue());
         if(ObjectUtil.isNotEmpty(mallProductBuy)){
             throw new FebsException("不可重复预约");
         }
@@ -81,20 +125,22 @@
          || priceToken.compareTo(mallMemberAmount.getTokenAva()) > 0){
             throw new FebsException("余额不足");
         }
+
+        String orderNo = MallUtils.getOrderNum("YY");
         mallProductBuy = new MallProductBuy();
         mallProductBuy.setMemberId(memberId);
+        mallProductBuy.setOrderNo(orderNo);
         mallProductBuy.setProductNftId(mallProductNft.getId());
         mallProductBuy.setState(ProductEnum.PRODUCT_BUY_ON_GOING.getValue());
-        mallProductBuy.setMateState(ProductEnum.PRODUCT_MATE_STATE_ON_GOING.getValue());
+        mallProductBuy.setMateState(ProductEnum.PRODUCT_BUY_MATE_STATE_FAIL.getValue());
         mallProductBuy.setNftTotal(mallProductNft.getPriceNft());
-        mallProductBuy.setNftAva(BigDecimal.ZERO);
+        mallProductBuy.setNftAva(mallProductNft.getPriceNft());
+//        mallProductBuy.setNftAva(BigDecimal.ZERO);
         mallProductBuyMapper.insert(mallProductBuy);
         //令牌 可用减少,冻结增加
         mallMemberAmount.setTokenAva(mallMemberAmount.getTokenAva().subtract(priceToken));
         mallMemberAmount.setTokenFrozen(mallMemberAmount.getTokenFrozen().add(priceToken));
         mallMemberAmountMapper.updateTokenAvaAndTokenFrozenById(mallMemberAmount);
-
-        String orderNo = MallUtils.getOrderNum("YY");
         iMallMoneyFlowService.addMoneyFlow(
                 memberId,
                 priceToken.negate(),
@@ -227,8 +273,10 @@
         BigDecimal fcmPrice = ObjectUtil.isEmpty(fcmPriceDic) ? new BigDecimal(2) : new BigDecimal(fcmPriceDic.getValue());
         BigDecimal fcmFeeCnt = nftFee.divide(fcmPrice, 2, BigDecimal.ROUND_DOWN);
 
+        String orderNo = MallUtils.getOrderNum("NFT");
         MallProductSell mallProductSell = new MallProductSell();
         mallProductSell.setMemberId(memberId);
+        mallProductSell.setOrderNo(orderNo);
         mallProductSell.setNftTotal(nftCnt);
         mallProductSell.setNftCnt(nftCntAva);
         mallProductSell.setNftCntAva(nftCntAva);
@@ -240,9 +288,11 @@
         mallMemberAmount.setTrendsNft(mallMemberAmount.getTrendsNft().subtract(nftCnt));
         mallMemberAmountMapper.updateTrendsNftById(mallMemberAmount);
 
+        mallMemberAmount.setFcmCntAva(mallMemberAmount.getFcmCntAva().subtract(fcmFeeCnt));
+        mallMemberAmountMapper.updateFcmCntAvaById(mallMemberAmount);
+
         mallMemberAmount.setFrozenNft(mallMemberAmount.getFrozenNft().add(nftCntAva));
         mallMemberAmountMapper.updateFrozenNftById(mallMemberAmount);
-        String orderNo = MallUtils.getOrderNum("NFT");
         iMallMoneyFlowService.addMoneyFlow(
                 memberId,
                 nftCnt.negate(),
@@ -263,4 +313,191 @@
         agentProducer.sendFcmNFTExchangeMsg(fcmFeeCnt.toString());
         return new FebsResponse().success();
     }
+
+    public static void main(String[] args) {
+        DateTime dateTime = DateUtil.parseTime("15:00:00");
+        DateTime dateTime2 = DateUtil.parseTime("19:00:00");
+        DateTime dateTime1 = DateUtil.parseTime(DateUtil.formatTime(DateUtil.date()));
+        System.out.println(dateTime);
+        System.out.println(dateTime1);
+        System.out.println(dateTime1.compareTo(dateTime));
+        System.out.println(dateTime1.compareTo(dateTime2));
+        System.out.println(dateTime1.compareTo(dateTime) >= 0 && dateTime1.compareTo(dateTime2) <= 0);
+    }
+
+    @Override
+    public FebsResponse orderList(ApiOrderListDto apiOrderListDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        List<ApiOrderListVo> objects = new ArrayList<>();
+        Integer orderType = apiOrderListDto.getOrderType();
+        apiOrderListDto.setMemberId(memberId);
+        DateTime nowTime = DateUtil.parseTime(DateUtil.formatTime(DateUtil.date()));
+        DataDictionaryCustom startTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_START_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_START_TIME.getCode()
+        );
+        DateTime startTime = DateUtil.parseTime(startTimeDic.getValue());
+        DataDictionaryCustom endTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.YU_YUE_END_TIME.getType(),
+                DataDictionaryEnum.YU_YUE_END_TIME.getCode()
+        );
+        DateTime endTime = DateUtil.parseTime(endTimeDic.getValue());
+        if(nowTime.compareTo(startTime) >= 0 && nowTime.compareTo(endTime) <= 0){
+            //买单
+            if(2 == orderType){
+                IPage<ApiOrderListVo> page = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+                IPage<ApiOrderListVo> apiOrderListVoIPageBuy = mallProductBuyMapper.selectListInPage(page, apiOrderListDto);
+                if(CollUtil.isNotEmpty(apiOrderListVoIPageBuy.getRecords())){
+                    for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageBuy.getRecords()){
+                        objects.add(apiOrderListVo);
+                    }
+                }
+            }
+            //卖单
+            if(1 == orderType){
+                IPage<ApiOrderListVo> page = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize());
+                IPage<ApiOrderListVo> apiOrderListVoIPageSell = mallProductSellMapper.selectListInPage(page, apiOrderListDto);
+                if(CollUtil.isNotEmpty(apiOrderListVoIPageSell.getRecords())){
+                    for(ApiOrderListVo apiOrderListVo : apiOrderListVoIPageSell.getRecords()){
+                        objects.add(apiOrderListVo);
+                    }
+                }
+            }
+        }
+
+        return new FebsResponse().success().data(objects);
+    }
+
+    @Override
+    public FebsResponse orderSell(ApiOrderSellInfoDto apiOrderSellInfoDto) {
+        Long productSellId = apiOrderSellInfoDto.getId();
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        ApiOrderSellInfoVo apiOrderSellInfoVo = mallProductSellMapper.selectSellInfoById(productSellId);
+        if(ObjectUtil.isEmpty(apiOrderSellInfoVo)){
+            throw new FebsException("记录不存在");
+        }
+        List<ApiOrderSellRecordInfoVo> apiOrderSellRecordInfoVos = mallProductSellRecordMapper.selectBySellId(productSellId);
+        if(CollUtil.isNotEmpty(apiOrderSellRecordInfoVos)){
+            apiOrderSellInfoVo.setApiOrderSellRecordInfoVos(apiOrderSellRecordInfoVos);
+        }
+        return new FebsResponse().success().data(apiOrderSellInfoVo);
+    }
+
+    @Override
+    public FebsResponse orderBuy(ApiOrderBuyInfoDto apiOrderBuyInfoDto) {
+        Long productBuyId = apiOrderBuyInfoDto.getId();
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        ApiOrderBuyInfoVo apiOrderBuyInfoVo = mallProductBuyMapper.selectBuyById(productBuyId);
+        if(ObjectUtil.isEmpty(apiOrderBuyInfoVo)){
+            throw new FebsException("记录不存在");
+        }
+        List<ApiOrderBuyRecordInfoVo> apiOrderBuyRecordInfoVos = mallProductBuyRecordMapper.selectByBuyId(productBuyId);
+        if(CollUtil.isNotEmpty(apiOrderBuyRecordInfoVos)){
+            apiOrderBuyInfoVo.setApiOrderBuyRecordInfoVos(apiOrderBuyRecordInfoVos);
+        }
+        return new FebsResponse().success().data(apiOrderBuyInfoVo);
+    }
+
+    @Override
+    public FebsResponse orderBuyInsure(ApiOrderBuyInsureDto apiOrderBuyInsureDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        MallMember mallMember = memberMapper.selectById(memberId);
+        Long buyRecordId = apiOrderBuyInsureDto.getBuyRecordId();
+        String nftImg = apiOrderBuyInsureDto.getNftImg();
+        Integer type = apiOrderBuyInsureDto.getType();
+        String tradePassword = SecureUtil.md5(apiOrderBuyInsureDto.getTradePassword());
+        /**
+         * 验证订单是否存在
+         * 更新买单状态
+         * 更新卖单状态
+         * 生成流水信息
+         */
+        if(!tradePassword.equals(mallMember.getTradePassword())){
+            throw new FebsException("请输入正确的交易密码");
+        }
+        MallProductBuyRecord mallProductBuyRecord = mallProductBuyRecordMapper.selectById(buyRecordId);
+        if(ObjectUtil.isEmpty(mallProductBuyRecord)){
+            throw new FebsException("记录不存在");
+        }
+        Integer state = mallProductBuyRecord.getState();
+        if(ProductEnum.PRODUCT_MATE_STATE_WAIT_PAY.getValue() != state){
+            throw new FebsException("记录不是待支付状态");
+        }
+
+        MallProductSellRecord mallProductSellRecord = mallProductSellRecordMapper.selectById(mallProductBuyRecord.getSellRecordId());
+        if(ObjectUtil.isEmpty(mallProductSellRecord)){
+            throw new FebsException("记录不存在");
+        }
+        Integer stateSell = mallProductSellRecord.getState();
+        if(ProductEnum.PRODUCT_MATE_STATE_WAIT_PAY.getValue() != stateSell){
+            throw new FebsException("记录不是待支付状态");
+        }
+
+        DateTime payTime = DateUtil.date();
+        mallProductBuyRecord.setState(ProductEnum.PRODUCT_MATE_STATE_PAY.getValue());
+        mallProductBuyRecord.setPayTime(payTime);
+        mallProductBuyRecord.setNftImg(nftImg);
+        mallProductBuyRecord.setType(type);
+        mallProductBuyRecordMapper.updateById(mallProductBuyRecord);
+
+        mallProductSellRecord.setState(ProductEnum.PRODUCT_MATE_STATE_PAY.getValue());
+        mallProductSellRecord.setPayTime(payTime);
+        mallProductSellRecord.setNftImg(nftImg);
+        mallProductSellRecord.setType(type);
+        mallProductSellRecordMapper.updateById(mallProductSellRecord);
+
+        String orderNo = MallUtils.getOrderNum("ZF");
+        iMallMoneyFlowService.addMoneyFlow(
+                memberId,
+                mallProductBuyRecord.getPickNftCnt(),
+                MoneyFlowTypeNewEnum.PAY.getValue(),
+                orderNo,
+                mallMember.getId(),
+                FlowTypeNewEnum.NFT.getValue(),
+                MoneyFlowTypeNewEnum.PAY.getDescrition());
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse orderSellInsure(ApiOrderSellInsureDto apiOrderSellInsureDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        MallMember mallMember = memberMapper.selectById(memberId);
+        String tradePassword = SecureUtil.md5(apiOrderSellInsureDto.getTradePassword());
+        Long sellRecordId = apiOrderSellInsureDto.getSellRecordId();
+        /**
+         * 验证订单是否存在
+         * 更新买单状态
+         * 更新卖单状态
+         * 生成流水信息
+         */
+        if(!tradePassword.equals(mallMember.getTradePassword())){
+            throw new FebsException("请输入正确的交易密码");
+        }
+        MallProductSellRecord mallProductSellRecord = mallProductSellRecordMapper.selectById(sellRecordId);
+        if(ObjectUtil.isEmpty(mallProductSellRecord)){
+            throw new FebsException("记录不存在");
+        }
+        Integer stateSell = mallProductSellRecord.getState();
+        if(ProductEnum.PRODUCT_MATE_STATE_PAY.getValue() != stateSell){
+            throw new FebsException("记录不是已支付状态");
+        }
+
+        MallProductBuyRecord mallProductBuyRecord = mallProductBuyRecordMapper.selectById(mallProductSellRecord.getBuyRecordId());
+        if(ObjectUtil.isEmpty(mallProductBuyRecord)){
+            throw new FebsException("记录不存在");
+        }
+        Integer state = mallProductBuyRecord.getState();
+        if(ProductEnum.PRODUCT_MATE_STATE_PAY.getValue() != state){
+            throw new FebsException("记录不是已支付状态");
+        }
+
+        mallProductBuyRecord.setState(ProductEnum.PRODUCT_MATE_STATE_CONFIRM.getValue());
+        mallProductBuyRecordMapper.updateById(mallProductBuyRecord);
+
+        mallProductSellRecord.setState(ProductEnum.PRODUCT_MATE_STATE_CONFIRM.getValue());
+        mallProductSellRecordMapper.updateById(mallProductSellRecord);
+
+        agentProducer.sendFcmOrderSellInsureMsg(sellRecordId);
+        return new FebsResponse().success();
+    }
 }

--
Gitblit v1.9.1