| | |
| | | package cc.mrbird.febs.dapp.service.impl; |
| | | |
| | | import cc.mrbird.febs.common.contants.AppContants; |
| | | import cc.mrbird.febs.common.utils.RedisUtils; |
| | | import cc.mrbird.febs.dapp.chain.ChainEnum; |
| | | import cc.mrbird.febs.dapp.chain.ChainService; |
| | | import cc.mrbird.febs.dapp.chain.ContractEventService; |
| | | import cc.mrbird.febs.dapp.chain.EthUsdtContract; |
| | | import cc.mrbird.febs.dapp.entity.DappFundFlowEntity; |
| | | import cc.mrbird.febs.dapp.entity.DappMemberEntity; |
| | | import cc.mrbird.febs.dapp.entity.DappTransferRecordEntity; |
| | | import cc.mrbird.febs.dapp.entity.DappStorage; |
| | | import cc.mrbird.febs.dapp.entity.DataDictionaryCustom; |
| | | import cc.mrbird.febs.dapp.enumerate.DataDictionaryEnum; |
| | | import cc.mrbird.febs.dapp.mapper.DappFundFlowDao; |
| | | import cc.mrbird.febs.dapp.mapper.DappMemberDao; |
| | | import cc.mrbird.febs.dapp.mapper.DappStorageMapper; |
| | | import cc.mrbird.febs.dapp.mapper.DataDictionaryCustomMapper; |
| | | import cc.mrbird.febs.dapp.service.DappMemberService; |
| | | import cc.mrbird.febs.dapp.service.DappWalletService; |
| | | import cc.mrbird.febs.dapp.utils.OnlineTransferUtil; |
| | | import cn.hutool.core.collection.CollUtil; |
| | | import cc.mrbird.febs.rabbit.producer.ChainProducer; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | |
| | | import java.math.BigDecimal; |
| | | import java.math.BigInteger; |
| | | import java.math.RoundingMode; |
| | | import java.util.List; |
| | | |
| | | @Slf4j |
| | | @Service |
| | |
| | | |
| | | @Resource |
| | | private DappMemberService dappMemberService; |
| | | |
| | | @Resource |
| | | private DappFundFlowDao dappFundFlowDao; |
| | | |
| | | @Resource |
| | | private RedisUtils redisUtils; |
| | | |
| | | private DappMemberDao dappMemberDao; |
| | | @Resource |
| | | private DappWalletService dappWalletService; |
| | | private DataDictionaryCustomMapper dataDictionaryCustomMapper; |
| | | @Resource |
| | | private DappStorageMapper dappStorageMapper; |
| | | @Resource |
| | | private ChainProducer chainProducer; |
| | | |
| | | public static void main(String[] args) { |
| | | System.out.println(Numeric.toBigInt("0x12e4e85")); |
| | |
| | | @Transactional(rollbackFor = Exception.class) |
| | | @Override |
| | | public void compile(EthUsdtContract.TransferEventResponse e) { |
| | | if (e.to != null && e.to.equals(ChainEnum.BSC_TFC.getAddress().toLowerCase())) { |
| | | log.info("触发TFC监听"); |
| | | |
| | | // try { |
| | | // Thread.sleep(5000); |
| | | // } catch (InterruptedException ex) { |
| | | // ex.printStackTrace(); |
| | | // } |
| | | redisUtils.set(AppContants.REDIS_KEY_BLOCK_COIN_NUM, e.log.getBlockNumber()); |
| | | redisUtils.set(AppContants.REDIS_KEY_BLOCK_ETH_INCREMENT_NUM, e.log.getBlockNumber()); |
| | | int decimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals(); |
| | | |
| | | // 更新余额 |
| | | DappMemberEntity fromMember = dappMemberService.findByAddress(e.from, null); |
| | | if (fromMember == null) { |
| | | return; |
| | | } |
| | | |
| | | BigInteger tokens = e.tokens; |
| | | BigDecimal amount = new BigDecimal(tokens.toString()).divide(BigDecimal.TEN.pow(decimals), decimals, RoundingMode.HALF_DOWN); |
| | | |
| | | // 卖币 |
| | | DappFundFlowEntity fundFlow = dappFundFlowDao.selectByFromHash(e.log.getTransactionHash(), null); |
| | | if (fundFlow != null && fundFlow.getStatus() != 1) { |
| | | return; |
| | | } |
| | | |
| | | if (fundFlow == null) { |
| | | List<DappFundFlowEntity> flows = dappFundFlowDao.selectFundFlowListByAddress(e.from, 1); |
| | | if (CollUtil.isEmpty(flows)) { |
| | | OnlineTransferUtil.addTransferRecord(e.from, e.to, amount, e.log.getTransactionHash(), DappTransferRecordEntity.TRANSFER_SOURCE_FLAG_ONLINE, AppContants.SYMBOL_COIN); |
| | | log.info("本地无交易:{}", e.log.getTransactionHash()); |
| | | return; |
| | | } |
| | | |
| | | for (DappFundFlowEntity flow : flows) { |
| | | if (flow.getStatus() == 1) { |
| | | if (amount.compareTo(flow.getAmount()) == 0) { |
| | | fundFlow = flow; |
| | | fundFlow.setFromHash(e.log.getTransactionHash()); |
| | | break; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | if (fundFlow == null) { |
| | | return; |
| | | } |
| | | |
| | | // 更改状态为已同步 |
| | | fundFlow.setStatus(2); |
| | | dappFundFlowDao.updateById(fundFlow); |
| | | |
| | | dappWalletService.updateWalletMineWithLock(amount, fromMember.getId(), 1); |
| | | } |
| | | return; |
| | | } |
| | | |
| | | @Override |
| | | public void sdmUSDT(EthUsdtContract.TransferEventResponse e) { |
| | | return; |
| | | } |
| | | |
| | | @Override |
| | | public void receivePeopleEvent(EthUsdtContract.ReceivePeopleEventResponse e) { |
| | | |
| | | if (e.from == null) { |
| | | return; |
| | | } |
| | | |
| | | if (e.regFlow == null) { |
| | | return; |
| | | } |
| | | |
| | | Long flowId = Long.parseLong(e.regFlow); |
| | | |
| | | // int decimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals(); |
| | | int decimals = 18; |
| | | BigInteger tokens = e.tokens; |
| | | BigDecimal amount = new BigDecimal(tokens.toString()).divide(BigDecimal.TEN.pow(decimals), decimals, RoundingMode.HALF_DOWN).setScale(2,BigDecimal.ROUND_DOWN); |
| | | log.info("触发用户存储:{},金额:{},流水ID:{}",e.from,amount,flowId); |
| | | // 账户是否已经注册 |
| | | DappMemberEntity fromMember = dappMemberService.findByAddress(e.from, null); |
| | | if (fromMember == null) { |
| | | return; |
| | | } |
| | | // 判断是否已经同步过了 |
| | | DappFundFlowEntity fundFlow = dappFundFlowDao.selectById(flowId); |
| | | if (fundFlow != null && fundFlow.getStatus() != 1) { |
| | | return; |
| | | } |
| | | // 更改状态为已同步 |
| | | fundFlow.setStatus(2); |
| | | dappFundFlowDao.updateById(fundFlow); |
| | | |
| | | log.info("产生用户存储:{},金额:{},流水ID:{}",e.from,amount,flowId); |
| | | |
| | | /** |
| | | * 新增一条记录 |
| | | */ |
| | | DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.RELEASE_PERCENT.getType(), |
| | | DataDictionaryEnum.RELEASE_PERCENT.getCode() |
| | | ); |
| | | BigDecimal releasePercent = new BigDecimal(dataDictionaryCustom.getValue()); |
| | | DappStorage dappStorage = new DappStorage(); |
| | | dappStorage.setState(1); |
| | | dappStorage.setMemberId(fromMember.getId()); |
| | | dappStorage.setAmount(amount); |
| | | dappStorage.setReleasePercent(releasePercent); |
| | | BigDecimal releaseAmount = amount.multiply(releasePercent).setScale(2, BigDecimal.ROUND_DOWN); |
| | | dappStorage.setReleaseAmount(releaseAmount); |
| | | dappStorageMapper.insert(dappStorage); |
| | | |
| | | DataDictionaryCustom usdtBalanceTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.USDT_BALANCE_TIME.getType(), |
| | | DataDictionaryEnum.USDT_BALANCE_TIME.getCode() |
| | | ); |
| | | BigDecimal usdtBalanceTime = new BigDecimal(usdtBalanceTimeDic.getValue()); |
| | | BigDecimal multiply = usdtBalanceTime.multiply(amount); |
| | | BigDecimal bigDecimal = fromMember.getUsdtBalance().add(multiply).setScale(2, BigDecimal.ROUND_DOWN); |
| | | fromMember.setUsdtBalance(bigDecimal); |
| | | fromMember.setActiveStatus(1); |
| | | dappMemberDao.updateById(fromMember); |
| | | |
| | | Long id = fundFlow.getId(); |
| | | Long memberId = fromMember.getId(); |
| | | /** |
| | | * 发送直推8% |
| | | */ |
| | | chainProducer.sendDirectPerkMsg(id); |
| | | /** |
| | | * DAO成员动态: |
| | | * * 1.直推1个拿2代,直推10个拿20代,直推15个拿30代,最高30代 |
| | | */ |
| | | chainProducer.sendMemberDynamicPerkMsg(id); |
| | | /** |
| | | * |
| | | * * 六、永动补偿池2% |
| | | * * 五、DAO永动激励池:6% |
| | | * * 四、DAO联盟委员会 : 5% (50名全球DAO委员) |
| | | */ |
| | | chainProducer.sendNodePerkMsg(id); |
| | | /** |
| | | * |
| | | * 3. DAO成员团队奖:5%加权分红(people数量) |
| | | * DAO1: 加权分红50% |
| | | * DAO2:加权分红30% |
| | | * DAO3:加权分红20% |
| | | */ |
| | | chainProducer.sendTeamPerk(id); |
| | | /** |
| | | *3. 成员升级 |
| | | * * DAO1:小区业绩30万/币 |
| | | * * DAO2:小区业绩100万/币 |
| | | * * DAO3:小区业绩500万/币 |
| | | */ |
| | | chainProducer.sendMemberLevel(memberId); |
| | | |
| | | } |
| | | } |