From cd59cd93b4eceee7b5f948a19d4e78371348fcd0 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Thu, 27 Jun 2024 10:29:27 +0800 Subject: [PATCH] 后台 --- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallProductServiceImpl.java | 187 +++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 183 insertions(+), 4 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 1d12048..5ee5a8c 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 @@ -6,6 +6,7 @@ import cc.mrbird.febs.common.enumerates.MoneyFlowTypeNewEnum; import cc.mrbird.febs.common.enumerates.ProductEnum; import cc.mrbird.febs.common.exception.FebsException; +import cc.mrbird.febs.common.utils.AppContants; import cc.mrbird.febs.common.utils.LoginUserUtil; import cc.mrbird.febs.common.utils.MallUtils; import cc.mrbird.febs.mall.dto.*; @@ -33,6 +34,7 @@ import java.math.BigDecimal; import java.util.ArrayList; import java.util.Date; +import java.util.HashMap; import java.util.List; @Slf4j @@ -126,14 +128,14 @@ MallProductBuy mallProductBuy = mallProductBuyMapper.selectMemberIdAndNFTIdAndStateAndMateState( memberId,productNFTId,ProductEnum.PRODUCT_BUY_ON_GOING.getValue(),ProductEnum.PRODUCT_BUY_MATE_STATE_FAIL.getValue()); if(ObjectUtil.isNotEmpty(mallProductBuy)){ - throw new FebsException("不可重复预约"); + throw new FebsException("不可重复开启"); } QueryWrapper<MallProductBuy> mallProductBuyDone = new QueryWrapper<>(); mallProductBuyDone.like("CREATED_TIME", DateUtil.today()); mallProductBuyDone.eq("member_id",memberId); Integer selectCount = mallProductBuyMapper.selectCount(mallProductBuyDone); if(0 < selectCount){ - throw new FebsException("每日预约一次"); + throw new FebsException("每日开启一次"); } BigDecimal priceToken = mallProductNft.getPriceToken(); @@ -152,6 +154,8 @@ mallProductBuy.setMateState(ProductEnum.PRODUCT_BUY_MATE_STATE_FAIL.getValue()); mallProductBuy.setNftTotal(mallProductNft.getPriceNft()); mallProductBuy.setNftAva(mallProductNft.getPriceNft()); + mallProductBuy.setCycle(mallProductNft.getCycle()); + mallProductBuy.setProfit(mallProductNft.getProfit()); // mallProductBuy.setNftAva(BigDecimal.ZERO); mallProductBuyMapper.insert(mallProductBuy); //令牌 可用减少,冻结增加 @@ -166,7 +170,10 @@ null, FlowTypeNewEnum.TOKEN.getValue(), MoneyFlowTypeNewEnum.TOKEN_BUY_FROZEN.getDescrition()); - return new FebsResponse().success(); + HashMap<String, Long> objectObjectHashMap = new HashMap<>(); + objectObjectHashMap.put("id",productNFTId); + objectObjectHashMap.put("time",5L); + return new FebsResponse().success().data(objectObjectHashMap); } @Override @@ -205,7 +212,7 @@ 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 fcmPrice = ObjectUtil.isEmpty(fcmPriceDic) ? new BigDecimal(8) : new BigDecimal(fcmPriceDic.getValue()); //手续费 DataDictionaryCustom outFcmFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( DataDictionaryEnum.OUT_FCM_FEE.getType(), @@ -275,6 +282,11 @@ throw new FebsException("请输入正确的交易密码"); } BigDecimal nftCnt = outNFTDto.getNftCnt(); + BigDecimal remainder = nftCnt.remainder(BigDecimal.TEN); + if(remainder.compareTo(BigDecimal.ZERO) != 0){ + throw new FebsException("数量需要为10的倍数"); + } + DataDictionaryCustom nftMinDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( DataDictionaryEnum.NFT_MIN.getType(), DataDictionaryEnum.NFT_MIN.getCode()); @@ -564,6 +576,25 @@ mallProductSellRecord.setState(ProductEnum.PRODUCT_MATE_STATE_CONFIRM.getValue()); mallProductSellRecordMapper.updateById(mallProductSellRecord); +// DataDictionaryCustom gsdInDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( +// DataDictionaryEnum.FCM_GSD_IN.getType(), +// DataDictionaryEnum.FCM_GSD_IN.getCode() +// ); +// BigDecimal gsdInPercent = new BigDecimal(gsdInDic.getValue()).multiply(AppContants.BASIC_PERCENT); +// BigDecimal gsdIn = gsdInPercent.multiply(mallProductSellRecord.getNftCnt()).setScale(2,BigDecimal.ROUND_DOWN); +// MallMemberAmount mallMemberAmount = mallMemberAmountMapper.selectByMemberId(memberId); +// mallMemberAmount.setGsd(mallMemberAmount.getGsd().add(gsdIn)); +// mallMemberAmountMapper.updateGsdById(mallMemberAmount); +// +// iMallMoneyFlowService.addMoneyFlow( +// memberId, +// gsdIn, +// MoneyFlowTypeNewEnum.NFT_TRANS_GFD.getValue(), +// null, +// mallMember.getId(), +// FlowTypeNewEnum.GSD.getValue(), +// MoneyFlowTypeNewEnum.NFT_TRANS_GFD.getDescrition()); + agentProducer.sendFcmOrderSellInsureMsg(sellRecordId); return new FebsResponse().success(); } @@ -665,6 +696,14 @@ } } } + +// IPage<ApiOrderRecordListVo> pageBuy = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize()); +// IPage<ApiOrderRecordListVo> apiOrderListVoIPageBuy = mallProductBuyRecordMapper.selectListInPage(pageBuy, apiOrderListDto); +// if(CollUtil.isNotEmpty(apiOrderListVoIPageBuy.getRecords())){ +// for(ApiOrderRecordListVo apiOrderListVo : apiOrderListVoIPageBuy.getRecords()){ +// objects.add(apiOrderListVo); +// } +// } IPage<ApiOrderRecordListVo> pageSell = new Page<>(apiOrderListDto.getPageNum(), apiOrderListDto.getPageSize()); IPage<ApiOrderRecordListVo> apiOrderListVoIPageSell = mallProductSellRecordMapper.selectListInPage(pageSell, apiOrderListDto); if(CollUtil.isNotEmpty(apiOrderListVoIPageSell.getRecords())){ @@ -699,4 +738,144 @@ ApiOrderBuyRecordInfoVo apiOrderBuyRecordInfoVo = mallProductBuyRecordMapper.selectByBuyRecordId(productBuyRecordId); return new FebsResponse().success().data(apiOrderBuyRecordInfoVo); } + + @Override + @Transactional + public FebsResponse transGfd(ApiTransGfdDto transGfdDto) { + Long memberId = LoginUserUtil.getLoginUser().getId(); + BigDecimal cnt = transGfdDto.getCnt();//兑换数量 + + MallMember mallMember = memberMapper.selectById(memberId); + String tradePassword = SecureUtil.md5(transGfdDto.getTradePassword()); + Boolean aBoolean = operationPermissionMemberFrozen(memberId); + if(aBoolean){ + throw new FebsException("用户已冻结"); + } + if(!tradePassword.equals(mallMember.getTradePassword())){ + throw new FebsException("请输入正确的交易密码"); + } + MallMemberAmount mallMemberAmount = mallMemberAmountMapper.selectByMemberId(memberId); + Integer type = transGfdDto.getType(); + String orderNo = MallUtils.getOrderNum("GSD"); + if(1 == type){//NFT兑换GFD + BigDecimal trendsNft = mallMemberAmount.getTrendsNft(); + if(BigDecimal.ZERO.compareTo(trendsNft) >= 0){ + throw new FebsException("NFT不足"); + } + if(cnt.compareTo(trendsNft) > 0){ + throw new FebsException("NFT不足"); + } + mallMemberAmount.setTrendsNft(trendsNft.subtract(cnt)); + mallMemberAmount.setGsd(mallMemberAmount.getGsd().add(cnt)); + mallMemberAmountMapper.updateTrendsNftAndGsdById(mallMemberAmount); + iMallMoneyFlowService.addMoneyFlow( + memberId, + cnt, + MoneyFlowTypeNewEnum.NFT_GSD.getValue(), + orderNo, + mallMember.getId(), + FlowTypeNewEnum.GSD.getValue(), + MoneyFlowTypeNewEnum.NFT_GSD.getDescrition()); + + } + if(2 == type){//GFA兑换GFD + BigDecimal fcmCntAva = mallMemberAmount.getFcmCntAva(); + if(BigDecimal.ZERO.compareTo(fcmCntAva) >= 0){ + throw new FebsException("代币不足"); + } + if(cnt.compareTo(fcmCntAva) > 0){ + throw new FebsException("代币不足"); + } + 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 gsdCnt = fcmPrice.multiply(cnt); + mallMemberAmount.setFcmCntAva(fcmCntAva.subtract(cnt)); + mallMemberAmount.setGsd(mallMemberAmount.getGsd().add(gsdCnt)); + mallMemberAmountMapper.updateFcmCntAvaAndGsdById(mallMemberAmount); + iMallMoneyFlowService.addMoneyFlow( + memberId, + cnt, + MoneyFlowTypeNewEnum.GFA_GSD.getValue(), + orderNo, + mallMember.getId(), + FlowTypeNewEnum.GSD.getValue(), + MoneyFlowTypeNewEnum.GFA_GSD.getDescrition()); + + } + return new FebsResponse().success(); + } + + @Override + @Transactional + public FebsResponse gfdTrans(ApiGfdTransDto transGfdDto) { + Long memberId = LoginUserUtil.getLoginUser().getId(); + BigDecimal cnt = transGfdDto.getCnt();//兑换数量 + + MallMember mallMember = memberMapper.selectById(memberId); + String tradePassword = SecureUtil.md5(transGfdDto.getTradePassword()); + Boolean aBoolean = operationPermissionMemberFrozen(memberId); + if(aBoolean){ + throw new FebsException("用户已冻结"); + } + if(!tradePassword.equals(mallMember.getTradePassword())){ + throw new FebsException("请输入正确的交易密码"); + } + MallMemberAmount mallMemberAmount = mallMemberAmountMapper.selectByMemberId(memberId); + BigDecimal gsd = mallMemberAmount.getGsd(); + if(BigDecimal.ZERO.compareTo(gsd) >= 0){ + throw new FebsException("积分不足"); + } + if(cnt.compareTo(gsd) > 0){ + throw new FebsException("积分不足"); + } + Integer type = transGfdDto.getType(); + String orderNo = MallUtils.getOrderNum("GSD"); + if(1 == type){//GFD兑换NFT + BigDecimal trendsNft = mallMemberAmount.getTrendsNft(); + mallMemberAmount.setTrendsNft(trendsNft.add(cnt)); + mallMemberAmount.setGsd(mallMemberAmount.getGsd().subtract(cnt)); + mallMemberAmountMapper.updateTrendsNftAndGsdById(mallMemberAmount); + iMallMoneyFlowService.addMoneyFlow( + memberId, + cnt, + MoneyFlowTypeNewEnum.GSD_NFT.getValue(), + orderNo, + mallMember.getId(), + FlowTypeNewEnum.GSD.getValue(), + MoneyFlowTypeNewEnum.GSD_NFT.getDescrition()); + + } + if(2 == type){//GFD兑换GFA + BigDecimal fcmCntAva = mallMemberAmount.getFcmCntAva(); + 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 gsdCnt = cnt.divide(fcmPrice,2,BigDecimal.ROUND_DOWN); + mallMemberAmount.setFcmCntAva(fcmCntAva.add(gsdCnt)); + mallMemberAmount.setGsd(mallMemberAmount.getGsd().subtract(cnt)); + mallMemberAmountMapper.updateFcmCntAvaAndGsdById(mallMemberAmount); + iMallMoneyFlowService.addMoneyFlow( + memberId, + cnt, + MoneyFlowTypeNewEnum.GSD_GFA.getValue(), + orderNo, + mallMember.getId(), + FlowTypeNewEnum.GSD.getValue(), + MoneyFlowTypeNewEnum.GSD_GFA.getDescrition()); + + } + return new FebsResponse().success(); + } + + @Override + public FebsResponse orderSellList(ApiOrderSellDto apiOrderBuyDto) { + Long memberId = LoginUserUtil.getLoginUser().getId(); + IPage<ApiOrderSellVo> page = new Page<>(apiOrderBuyDto.getPageNum(), apiOrderBuyDto.getPageSize()); + apiOrderBuyDto.setMemberId(memberId); + IPage<ApiOrderSellVo> apiOrderBuyVoIPage = mallProductBuyMapper.selectSellListInPage(page, apiOrderBuyDto); + return new FebsResponse().success().data(apiOrderBuyVoIPage); + } } -- Gitblit v1.9.1