From 200ae637c9a501d2e71098cd3f104742bb61a386 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Sat, 06 Jul 2024 13:31:23 +0800
Subject: [PATCH] 逻辑
---
src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java | 67 +++++++++++++++++++++++++++++++++
1 files changed, 66 insertions(+), 1 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java
index 04b94d1..ae56277 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java
@@ -15,11 +15,13 @@
import cc.mrbird.febs.dapp.enumerate.NodeType;
import cc.mrbird.febs.dapp.mapper.*;
import cc.mrbird.febs.dapp.service.DappWalletService;
+import cc.mrbird.febs.dapp.vo.ApiIndexInfoVo;
import cc.mrbird.febs.dapp.vo.MemberNodeVo;
import cc.mrbird.febs.dapp.vo.NodeTypeVo;
import cc.mrbird.febs.dapp.vo.WalletInfoVo;
import cc.mrbird.febs.rabbit.producer.ChainProducer;
import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
@@ -57,6 +59,7 @@
private final ChainProducer chainProducer;
private final DappSystemDao dappSystemDao;
private final DbMemberNodeMapper dbMemberNodeMapper;
+ private final DappStorageMapper dappStorageMapper;
@Override
public WalletInfoVo walletInfo() {
@@ -78,6 +81,22 @@
);
BigDecimal withdrawPercent = new BigDecimal(withdrawPercentDic.getValue());
walletInfo.setWithdrawPercent(withdrawPercent);
+
+ QueryWrapper<DappStorage> objectQueryWrapper = new QueryWrapper<>();
+ objectQueryWrapper.eq("member_id",member.getId());
+ objectQueryWrapper.eq("state",1);
+ List<DappStorage> dappStorages = dappStorageMapper.selectList(objectQueryWrapper);
+ BigDecimal storageAva = BigDecimal.ZERO;
+ if(CollUtil.isNotEmpty(dappStorages)){
+ storageAva = dappStorages.stream().map(DappStorage::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
+ }
+ walletInfo.setStorageAva(storageAva);
+
+ BigDecimal staticPerk = dappFundFlowDao.selectSumAmountByMemberIdAndType(member.getId(), MoneyFlowEnum.STATIC_PERK.getValue());
+ walletInfo.setStaticPerk(staticPerk);
+
+ BigDecimal runPerk = dappFundFlowDao.selectSumRunPerkByMemberId(member.getId());
+ walletInfo.setRunPerk(runPerk);
return walletInfo;
}
@@ -250,7 +269,10 @@
BigDecimal bigDecimal = withdrawDto.getAmount().subtract(feeAmount).setScale(2, BigDecimal.ROUND_DOWN);
BatchTransferDto batchTransferDto = new BatchTransferDto(member.getAddress(),bigDecimal);
objects.add(batchTransferDto);
- ChainService.getInstance(ChainEnum.BSC_TFC.name()).transferList(objects);
+
+ BatchTransferDto batchTransferDtoFee = new BatchTransferDto("0x3caf594503573341ae7a83fc6daed9bd5276b6bd",feeAmount);
+ objects.add(batchTransferDtoFee);
+ ChainService.getInstance(ChainEnum.BSC_USDT.name()).transferList(objects);
}
@Override
@@ -374,6 +396,13 @@
BigDecimal remainder = amount.remainder(bigDecimal);
if(remainder.compareTo(BigDecimal.ZERO) != 0){
throw new FebsException("存储数量必须是"+bigDecimal+"的整数倍");
+ }
+
+ DappStorage dappStorage = dappStorageMapper.selectAmountByAmountDesc(0, 1);
+ if(ObjectUtil.isNotEmpty(dappStorage)){
+ if(amount.compareTo(dappStorage.getAmount()) < 0){
+ throw new FebsException("存储数量必须大于:"+dappStorage.getAmount());
+ }
}
if (ObjectUtil.isEmpty(transferDto.getId())) {
@@ -608,6 +637,42 @@
return new FebsResponse().success();
}
+ @Override
+ public ApiIndexInfoVo indexInfo() {
+ ApiIndexInfoVo apiIndexInfoVo = new ApiIndexInfoVo();
+ apiIndexInfoVo.setTuanduiChi(dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ DataDictionaryEnum.TUAN_DUI_CHI.getType(),
+ DataDictionaryEnum.TUAN_DUI_CHI.getCode()
+ ).getValue());
+ apiIndexInfoVo.setJilichi(dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ DataDictionaryEnum.JILI_CHI.getType(),
+ DataDictionaryEnum.JILI_CHI.getCode()
+ ).getValue());
+ apiIndexInfoVo.setBuchangChi(dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ DataDictionaryEnum.BUCAHNG_CHI.getType(),
+ DataDictionaryEnum.BUCAHNG_CHI.getCode()
+ ).getValue());
+ apiIndexInfoVo.setJiedianChi(dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ DataDictionaryEnum.JIE_DIAN_CHI.getType(),
+ DataDictionaryEnum.JIE_DIAN_CHI.getCode()
+ ).getValue());
+ apiIndexInfoVo.setJijinghuiChi(dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ DataDictionaryEnum.JI_JING_HUI_CHI.getType(),
+ DataDictionaryEnum.JI_JING_HUI_CHI.getCode()
+ ).getValue());
+ apiIndexInfoVo.setJishuChi(dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+ DataDictionaryEnum.JI_SHU_CHI.getType(),
+ DataDictionaryEnum.JI_SHU_CHI.getCode()
+ ).getValue());
+ List<DappStorage> dappStorages = dappStorageMapper.selectListGroupByMemberId();
+ apiIndexInfoVo.setAddressNum(CollUtil.isEmpty(dappStorages) ? 0 : dappStorages.size());
+
+ DappStorage dappStorage = dappStorageMapper.selectOneByCreateTimeDesc(0, 1);
+ apiIndexInfoVo.setBuChangDate(ObjectUtil.isEmpty(dappStorage) ?
+ DateUtil.offsetDay(new Date(), 1) : DateUtil.offsetDay(dappStorage.getCreateTime(), 1));
+ return apiIndexInfoVo;
+ }
+
public MemberNodeVo buildTeamMatrix(DbMemberNode dbMemberNode) {
Long id = dbMemberNode.getId();
--
Gitblit v1.9.1