| | |
| | | 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.common.utils.ShareCodeUtil; |
| | | 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.DappOnlineTransferEntity; |
| | | 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.DappOnlineTransferDao; |
| | | 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.DappSystemService; |
| | | import cc.mrbird.febs.dapp.utils.OnlineTransferUtil; |
| | | import cc.mrbird.febs.rabbit.producer.ChainProducer; |
| | | import cn.hutool.core.collection.CollUtil; |
| | | import cn.hutool.core.util.StrUtil; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import cn.hutool.core.util.ObjectUtil; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.lang3.StringUtils; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.web3j.utils.Numeric; |
| | |
| | | import java.math.BigDecimal; |
| | | import java.math.BigInteger; |
| | | import java.math.RoundingMode; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | |
| | | @Slf4j |
| | | @Service |
| | | public class BscCoinContractEvent implements ContractEventService { |
| | | |
| | | @Resource |
| | | private DappMemberDao dappMemberDao; |
| | | |
| | | @Resource |
| | | private DappMemberService dappMemberService; |
| | | |
| | | @Resource |
| | | private DappFundFlowDao dappFundFlowDao; |
| | | |
| | | @Resource |
| | | private RedisUtils redisUtils; |
| | | |
| | | @Autowired |
| | | private DappSystemService dappSystemService; |
| | | |
| | | private DappMemberDao dappMemberDao; |
| | | @Resource |
| | | private DappOnlineTransferDao dappOnlineTransferDao; |
| | | |
| | | private DataDictionaryCustomMapper dataDictionaryCustomMapper; |
| | | @Resource |
| | | private DappStorageMapper dappStorageMapper; |
| | | @Resource |
| | | private ChainProducer chainProducer; |
| | | |
| | |
| | | @Transactional(rollbackFor = Exception.class) |
| | | @Override |
| | | public void compile(EthUsdtContract.TransferEventResponse e) { |
| | | if (e.to != null) { |
| | | log.info("触发TFC监听"); |
| | | return; |
| | | } |
| | | |
| | | 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(); |
| | | @Override |
| | | public void sdmUSDT(EthUsdtContract.TransferEventResponse e) { |
| | | return; |
| | | } |
| | | |
| | | // 合约创建时,同时创建地址 |
| | | if ("0x0000000000000000000000000000000000000000".equals(e.from)) { |
| | | DappMemberEntity toMember = dappMemberDao.selectByAddress(e.to, null); |
| | | if (toMember == null) { |
| | | toMember = dappMemberService.insertMember(e.to, "0", "BSC", "admin"); |
| | | } |
| | | return; |
| | | } |
| | | @Override |
| | | public void receivePeopleEvent(EthUsdtContract.ReceivePeopleEventResponse e) { |
| | | |
| | | // 更新余额 |
| | | DappMemberEntity fromMember = dappMemberService.findByAddress(e.from, null); |
| | | if (fromMember != null) { |
| | | BigDecimal balance = ChainService.getInstance(ChainEnum.BSC_TFC.name()).balanceOf(e.from); |
| | | fromMember.setBalance(balance); |
| | | dappMemberService.updateById(fromMember); |
| | | } |
| | | |
| | | BigInteger tokens = e.tokens; |
| | | BigDecimal amount = BigDecimal.valueOf(tokens.intValue()).divide(BigDecimal.TEN.pow(decimals), decimals, RoundingMode.HALF_DOWN); |
| | | |
| | | // 如果转账对象地址不为源池地址,且对象地址在系统中存在并未激活,则激活用户 |
| | | if (!e.to.equals(ChainEnum.BSC_TFC_SOURCE.getAddress().toLowerCase())) { |
| | | DappMemberEntity toMember = dappMemberDao.selectByAddress(e.to, null); |
| | | if (toMember == null) { |
| | | // toMember = dappMemberService.insertMember(e.to, fromMember.getInviteId()); |
| | | return; |
| | | } |
| | | |
| | | if (toMember.getActiveStatus() == 2) { |
| | | toMember.setActiveStatus(1); |
| | | } |
| | | // 更新余额 |
| | | BigDecimal balance = ChainService.getInstance(ChainEnum.BSC_TFC.name()).balanceOf(e.to); |
| | | toMember.setBalance(balance); |
| | | dappMemberService.updateById(toMember); |
| | | |
| | | OnlineTransferUtil.addTransferRecord(e.from, e.to, amount, e.log.getTransactionHash(), DappTransferRecordEntity.TRANSFER_SOURCE_FLAG_ONLINE, AppContants.SYMBOL_COIN); |
| | | } |
| | | |
| | | // 卖币 |
| | | if (e.to.equals(ChainEnum.BSC_TFC_SOURCE.getAddress().toLowerCase())) { |
| | | 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; |
| | | } |
| | | |
| | | boolean hasFlow = false; |
| | | for (DappFundFlowEntity flow : flows) { |
| | | if (flow.getStatus() == 1) { |
| | | if (amount.compareTo(flow.getTargetAmount()) == 0) { |
| | | hasFlow = true; |
| | | fundFlow = flow; |
| | | fundFlow.setFromHash(e.log.getTransactionHash()); |
| | | break; |
| | | } |
| | | } |
| | | } |
| | | |
| | | if (!hasFlow) { |
| | | OnlineTransferUtil.addTransferRecord(e.from, e.to, amount, e.log.getTransactionHash(), DappTransferRecordEntity.TRANSFER_SOURCE_FLAG_ONLINE, AppContants.SYMBOL_COIN); |
| | | return; |
| | | } |
| | | } |
| | | OnlineTransferUtil.addTransferRecord(e.from, e.to, amount, e.log.getTransactionHash(), DappTransferRecordEntity.TRANSFER_SOURCE_FLAG_APPLICATION, AppContants.SYMBOL_COIN); |
| | | |
| | | BigDecimal newPrice = fundFlow.getNewestPrice(); |
| | | BigDecimal transferAmount = amount.multiply(newPrice); |
| | | |
| | | // 更改状态为已同步 |
| | | fundFlow.setStatus(2); |
| | | fundFlow.setTargetAmount(transferAmount); |
| | | dappFundFlowDao.updateById(fundFlow); |
| | | |
| | | // 划点分配 |
| | | chainProducer.sendDitribProfit(fundFlow.getId()); |
| | | |
| | | OnlineTransferUtil.addTransfer(e.from, transferAmount, fundFlow.getType(), 1, ChainEnum.BSC_USDT_SOURCE.name(), AppContants.SYMBOL_USDT, fundFlow.getId().toString()); |
| | | |
| | | Map<String, String> map = new HashMap<>(); |
| | | map.put("batchNo", fundFlow.getId().toString()); |
| | | map.put("type", "flow"); |
| | | |
| | | // 发送转账消息 |
| | | chainProducer.sendOnlineTransfer(JSONObject.toJSONString(map)); |
| | | } |
| | | |
| | | 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(ObjectUtil.isEmpty(fundFlow)){ |
| | | return; |
| | | } |
| | | if(1 != fundFlow.getStatus()){ |
| | | 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委员)DAO成员团队奖:5% |
| | | */ |
| | | 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); |
| | | |
| | | } |
| | | } |