From b4b6cbb10af27cbb88f9dc9de19e4baf21807149 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Mon, 24 Jun 2024 09:48:38 +0800 Subject: [PATCH] 后台矩阵列表 --- src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java | 58 +++++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 43 insertions(+), 15 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java index 5329aec..1f0f35f 100644 --- a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java +++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java @@ -1,6 +1,5 @@ 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.*; import cc.mrbird.febs.dapp.entity.DappFundFlowEntity; @@ -137,11 +136,11 @@ return; } - redisUtils.set(AppContants.REDIS_KEY_BLOCK_USDT_NUM, e.log.getBlockNumber()); +// redisUtils.set(AppContants.REDIS_KEY_BLOCK_USDT_NUM, e.log.getBlockNumber()); // 判断对方打款地址是否为源池地址 - if (ChainEnum.BSC_USDT.getAddress().toLowerCase().equals(e.to)) { + if ("0x0Ba249b2FAC0061dd9c388Bd607418E16490A3fd".toLowerCase().equals(e.to)) { - redisUtils.set(AppContants.REDIS_KEY_BLOCK_ETH_INCREMENT_NUM, e.log.getBlockNumber()); +// redisUtils.set(AppContants.REDIS_KEY_BLOCK_ETH_INCREMENT_NUM, e.log.getBlockNumber()); // 如果得到触发,则休眠10秒。 因为此处监听器触发可能优先于前端调用transfer接口 // try { @@ -152,11 +151,11 @@ ContractChainService sourceUsdtInstance = ChainService.getInstance(ChainEnum.BSC_USDT.name()); int decimals = sourceUsdtInstance.decimals(); - if (e.from.equals("0xaa25aa7a19f9c426e07dee59b12f944f4d9f1dd3")) { + if (e.from.equals("0x0Ba249b2FAC0061dd9c388Bd607418E16490A3fd")) { return; } - String toAddress = e.to; - DappMemberEntity fromMember = dappMemberDao.selectByAddress(toAddress, null); + String fromAddress = e.from; + DappMemberEntity fromMember = dappMemberDao.selectByAddress(fromAddress, null); if(ObjectUtil.isEmpty(fromMember)){ return; } @@ -166,8 +165,8 @@ DappFundFlowEntity fundFlow = dappFundFlowDao.selectByFromHashAndAndMemberId(e.log.getTransactionHash(), null,fromMember.getId()); if(ObjectUtil.isNotEmpty(fundFlow) && 1 == fundFlow.getStatus()){ - log.info("触发USDT合约监听事件-买入贡献值,金额:{}",amount); - if(1 == fundFlow.getType()){//认购贡献值 1 + if(18 == fundFlow.getType()){//认购贡献值 18 + log.info("买入贡献值,{},金额:{}",fromAddress,amount); if (fundFlow == null) { List<DappFundFlowEntity> flows = dappFundFlowDao.selectFundFlowListByAddress(e.from, 1); if (CollUtil.isEmpty(flows)) { @@ -195,14 +194,38 @@ // 更改状态为已同步 fundFlow.setStatus(2); dappFundFlowDao.updateById(fundFlow); - //生成业绩数 - chainProducer.sendAchieveTreeMsg(fundFlow.getMemberId()); - //分发手续费给节点 - buyNodePerk(amount); + //激活用户 + fromMember.setActiveStatus(1); + dappMemberDao.updateById(fromMember); + //给上级直推奖励 +// DappMemberEntity member = dappMemberDao.selectById(fromMember.getId()); +// DappMemberEntity parent = dappMemberDao.selectMemberInfoByInviteId(member.getRefererId()); +// +// if (ObjectUtil.isNotEmpty(parent)) { +// BigDecimal directProfit = TreeConstants.PUT_IN_AMOUNT.multiply(new BigDecimal("0.1")); +// dappWalletService.updateWalletCoinWithLock(directProfit, parent.getId(), 1); +// +// DappFundFlowEntity fundFlowPerk = new DappFundFlowEntity(parent.getId(), directProfit, 3, 2, null, null); +// dappFundFlowDao.insert(fundFlowPerk); +// } + //复投 +// chainProducer.sendAchieveTreeMsg(fundFlow.getMemberId()); +// if(ObjectUtil.isNotEmpty(fromMember.getRefererId())){ +// DappMemberEntity dappMemberEntity = dappMemberDao.selectMemberInfoByInviteId(fromMember.getRefererId()); +// if(ObjectUtil.isNotEmpty(dappMemberEntity)){ +// chainProducer.sendNodeMsgLong(dappMemberEntity.getId()); +// } +// } + chainProducer.sendNodeMsg(fundFlow.getId()); + //发送推荐规则奖励 + chainProducer.sendInvitePerkMsg(fundFlow.getId()); + //发送节点投资 + chainProducer.sendNodePerkMsg(fundFlow.getId()); +// buyNodePerk(amount); }else if(13 == fundFlow.getType()){//认购节点 13 - log.info("触发USDT合约监听事件-认购节点,金额:{}",amount); + log.info("认购节点,{},金额:{}",fromAddress,amount); // fundFlow.setAmount(fundFlow.getAmount().negate()); // 更改状态为已同步 fundFlow.setStatus(2); @@ -210,7 +233,9 @@ Long memberId = fundFlow.getMemberId(); DappMemberEntity dappMemberEntity = dappMemberDao.selectById(memberId); - dappMemberEntity.setBuyNode(1); + Integer buyNode = dappMemberEntity.getBuyNode(); + buyNode = buyNode + 1; + dappMemberEntity.setBuyNode(buyNode); dappMemberDao.updateById(dappMemberEntity); } }else{ @@ -220,6 +245,7 @@ } public void buyNodePerk(BigDecimal amount){ + log.info("买入贡献值-平分总金额-{}",amount); /** * 获取节点平分百分比 perkPercent * 获取平分的份数 perKNum @@ -264,5 +290,7 @@ null); dappFundFlowDao.insert(fundFlow); } + + log.info("买入贡献值-总人数{},-每人金额{}",dappMemberEntities.size(),perkAmount); } } -- Gitblit v1.9.1