From 6cdfe1d568d06bc63bb513ce0ef1df6aac3c7c3d Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Sat, 20 Feb 2021 15:32:12 +0800 Subject: [PATCH] fix --- src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java | 104 ++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 97 insertions(+), 7 deletions(-) diff --git a/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java b/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java index 1eae8af..a0ef93b 100644 --- a/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java +++ b/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java @@ -6,10 +6,10 @@ import cn.hutool.core.util.StrUtil; import com.xcong.excoin.common.enumerates.CoinTypeEnum; import com.xcong.excoin.modules.blackchain.model.EosResult; -import com.xcong.excoin.modules.blackchain.service.BtcService; -import com.xcong.excoin.modules.blackchain.service.EosService; -import com.xcong.excoin.modules.blackchain.service.EthService; -import com.xcong.excoin.modules.blackchain.service.UsdtService; +import com.xcong.excoin.modules.blackchain.model.XrpTransResult; +import com.xcong.excoin.modules.blackchain.model.XrpTransactions; +import com.xcong.excoin.modules.blackchain.model.XrpTx; +import com.xcong.excoin.modules.blackchain.service.*; import com.xcong.excoin.modules.coin.service.BlockCoinService; import com.xcong.excoin.modules.member.dao.MemberCoinAddressDao; import com.xcong.excoin.modules.member.dao.MemberCoinChargeDao; @@ -26,6 +26,7 @@ import com.xcong.excoin.utils.mail.Sms106Send; import com.xcong.excoin.utils.mail.SubMailSend; import lombok.extern.slf4j.Slf4j; +import lombok.val; import org.apache.commons.collections.CollectionUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Service; @@ -34,6 +35,8 @@ import javax.annotation.Resource; import java.math.BigDecimal; import java.math.RoundingMode; +import java.text.ParseException; +import java.text.SimpleDateFormat; import java.util.Date; import java.util.List; @@ -58,6 +61,8 @@ private RedisUtils redisUtils; private final static String EOS_SEQ_KEY="eos_seq_key"; + + private final static String xrp_update_key = "xrp_update_key"; @Transactional(rollbackFor = Exception.class) @Override @@ -123,7 +128,7 @@ Long memberId = coinAddressEntity.getMemberId(); BigDecimal balance = EthService.getEthBlance(address); - if (balance != null && new BigDecimal("0.008").compareTo(balance) < 0) { + if (balance != null && new BigDecimal("0.01").compareTo(balance) < 0) { MemberWalletCoinEntity walletCoin = memberWalletCoinDao.selectWalletCoinBymIdAndCode(memberId, CoinTypeEnum.ETH.name()); if (walletCoin == null) { @@ -295,6 +300,7 @@ if(StringUtils.isNotBlank(quantity)){ // 转账额 String amountStr = quantity.split("")[0]; + BigDecimal amount = new BigDecimal(amountStr); List<MemberCoinAddressEntity> memberCoinAddress = memberCoinAddressDao.selectAllBlockAddressBySymbolAndTag(CoinTypeEnum.EOS.name(), memo); if(CollectionUtils.isNotEmpty(memberCoinAddress)){ MemberCoinAddressEntity memberCoinAddressEntity = memberCoinAddress.get(0); @@ -302,9 +308,19 @@ Long memberId = memberCoinAddressEntity.getMemberId(); MemberWalletCoinEntity memberWalletCoinEntity = memberWalletCoinDao.selectWalletCoinBymIdAndCode(memberId, CoinTypeEnum.EOS.name()); if(memberCoinAddressEntity!=null){ - memberWalletCoinDao.updateBlockBalance(memberWalletCoinEntity.getId(),new BigDecimal(amountStr),BigDecimal.ZERO,0); + memberWalletCoinDao.updateBlockBalance(memberWalletCoinEntity.getId(),amount,BigDecimal.ZERO,0); // 添加冲币记录 - insertCoinCharge(EosService.ACCOUNT,memberId,new BigDecimal(amountStr),CoinTypeEnum.EOS.name(),memo,BigDecimal.ZERO); + String orderNo = insertCoinCharge(EosService.ACCOUNT,memberId,amount,CoinTypeEnum.EOS.name(),memo,BigDecimal.ZERO); + LogRecordUtils.insertMemberAccountMoneyChange(memberId, "转入", amount, CoinTypeEnum.EOS.name(), 1, 1); + + ThreadPoolUtils.sendDingTalk(5); + MemberEntity member = memberDao.selectById(memberId); + if (StrUtil.isNotBlank(member.getPhone())) { + //String amountEos = amountStr + "EOS"; + Sms106Send.sendRechargeMsg(member.getPhone(), DateUtil.format(new Date(), DatePattern.NORM_DATETIME_MINUTE_PATTERN), orderNo); + } else { + SubMailSend.sendRechargeMail(member.getEmail(), DateUtil.format(new Date(), DatePattern.NORM_DATETIME_MINUTE_PATTERN), orderNo); + } } } } @@ -316,6 +332,80 @@ } } + public void updateXrp() { + // 首先去查redis上的上次同步时间 + Object lastUpdateTime = redisUtils.get(xrp_update_key); + SimpleDateFormat format = new SimpleDateFormat("YYYY-MM-dd hh:mm:ss"); + Date start =null; + if(lastUpdateTime==null) { + // 没有 说明是第一次同步 此时从第一天开始同步2020 0716开始 + try { + start = format.parse("2020-07-16 12:00:00"); + } catch (ParseException e) { + e.printStackTrace(); + } + }else { + // 有上次时间 + try { + start = format.parse(lastUpdateTime.toString()); + } catch (ParseException e) { + e.printStackTrace(); + } + } + + // 去查询上次同步时间后的所有记录 + XrpTransResult result = XrpService.getTransactions(start); + // 写入本次更新时间 + String updateTime = format.format(new Date()); + redisUtils.set(xrp_update_key, updateTime); + // 判断有无 + List<XrpTransactions> list = result.getTransactions(); + if(CollectionUtils.isNotEmpty(list)) { + // 不为空 说明有转入记录 + for(XrpTransactions item:list) { + XrpTx data = item.getTx(); + Integer amountOld = data.getAmount(); + // 除以1000000 + BigDecimal amount = new BigDecimal(amountOld).divide(new BigDecimal(1000000)); + Integer memoInt = data.getDestinationTag(); + // 没有标签直接返回 + if(memoInt==null){ + continue; + } + String memo = memoInt.toString(); + String destination = data.getDestination(); + // 判断收款人是不是系统账号 + if(!XrpService.ACCOUNT.equals(destination)){ + continue; + } + List<MemberCoinAddressEntity> memberCoinAddress = memberCoinAddressDao.selectAllBlockAddressBySymbolAndTag(CoinTypeEnum.XRP.name(), memo); + if(CollectionUtils.isNotEmpty(memberCoinAddress)){ + MemberCoinAddressEntity memberCoinAddressEntity = memberCoinAddress.get(0); + // 用户ID + Long memberId = memberCoinAddressEntity.getMemberId(); + MemberWalletCoinEntity memberWalletCoinEntity = memberWalletCoinDao.selectWalletCoinBymIdAndCode(memberId, CoinTypeEnum.XRP.name()); + if(memberCoinAddressEntity!=null){ + memberWalletCoinDao.updateBlockBalance(memberWalletCoinEntity.getId(),amount,BigDecimal.ZERO,0); + // 添加冲币记录 + String orderNo = insertCoinCharge(XrpService.ACCOUNT,memberId,amount,CoinTypeEnum.XRP.name(),memo,BigDecimal.ZERO); + LogRecordUtils.insertMemberAccountMoneyChange(memberId, "转入", amount, CoinTypeEnum.XRP.name(), 1, 1); + + ThreadPoolUtils.sendDingTalk(5); + MemberEntity member = memberDao.selectById(memberId); + if (StrUtil.isNotBlank(member.getPhone())) { + //String amountEos = amount + "XRP"; + Sms106Send.sendRechargeMsg(member.getPhone(), DateUtil.format(new Date(), DatePattern.NORM_DATETIME_MINUTE_PATTERN), orderNo); + } else { + SubMailSend.sendRechargeMail(member.getEmail(), DateUtil.format(new Date(), DatePattern.NORM_DATETIME_MINUTE_PATTERN), orderNo); + } + } + } + + } + } + + } + private String generateNo() { // 生成订单号 Long timestamp = System.currentTimeMillis(); -- Gitblit v1.9.1