From 79b15889217d9f6d2ef86ccba0c3ace5055a4b66 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Mon, 30 May 2022 11:12:17 +0800
Subject: [PATCH] add transfer

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/BscUsdtContractEvent.java  |   27 ++++++++-----
 src/main/resources/mapper/dapp/DappFundFlowDao.xml                        |    4 ++
 src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java |    3 +
 src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java  |   22 ++++++----
 src/main/java/cc/mrbird/febs/dapp/mapper/DappFundFlowDao.java             |    2 +
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java |    5 ++
 src/main/java/cc/mrbird/febs/dapp/dto/TransferDto.java                    |    9 +++-
 src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java          |   10 +++-
 8 files changed, 55 insertions(+), 27 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java b/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
index d9a052f..69aa854 100644
--- a/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
+++ b/src/main/java/cc/mrbird/febs/dapp/controller/ApiDappMemberController.java
@@ -55,7 +55,8 @@
     @ApiOperation(value = "转账", notes = "转账")
     @PostMapping(value = "/transfer")
     public FebsResponse transfer(@RequestBody TransferDto transferDto) {
-        return null;
+        dappWalletService.transfer(transferDto);
+        return new FebsResponse().success();
     }
 
     @ApiOperation(value = "记录列表", notes = "记录列表")
diff --git a/src/main/java/cc/mrbird/febs/dapp/dto/TransferDto.java b/src/main/java/cc/mrbird/febs/dapp/dto/TransferDto.java
index 0c4c4d7..5b1b227 100644
--- a/src/main/java/cc/mrbird/febs/dapp/dto/TransferDto.java
+++ b/src/main/java/cc/mrbird/febs/dapp/dto/TransferDto.java
@@ -4,6 +4,8 @@
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
 
+import java.math.BigDecimal;
+
 /**
  * @author wzy
  * @date 2022-05-27
@@ -18,6 +20,9 @@
     @ApiModelProperty(value = "交易hash", example = "123")
     private String txHash;
 
-    @ApiModelProperty(value = "地址", example = "0x123")
-    private String address;
+    @ApiModelProperty(value = "金额", example = "1")
+    private BigDecimal amount;
+
+    @ApiModelProperty(value = "手续费", example = "1")
+    private BigDecimal fee;
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java b/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java
index 265d5f9..a1198ff 100644
--- a/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java
+++ b/src/main/java/cc/mrbird/febs/dapp/entity/DappFundFlowEntity.java
@@ -21,11 +21,11 @@
 
     public DappFundFlowEntity() {}
 
-    public DappFundFlowEntity(Long memberId, BigDecimal amount, Integer type, Integer status, Integer fee) {
+    public DappFundFlowEntity(Long memberId, BigDecimal amount, Integer type, Integer status, BigDecimal fee) {
         new DappFundFlowEntity(memberId, amount, type, status, fee, null);
     }
 
-    public DappFundFlowEntity(Long memberId, BigDecimal amount, Integer type, Integer status, Integer fee, String fromHash) {
+    public DappFundFlowEntity(Long memberId, BigDecimal amount, Integer type, Integer status, BigDecimal fee, String fromHash) {
         this.memberId = memberId;
         this.amount = amount;
         this.type = type;
@@ -51,9 +51,13 @@
     @TableField(exist = false)
     private String address;
 
-    private Integer fee;
+    private BigDecimal fee;
 
     private String toHash;
 
     private String fromHash;
+
+    private BigDecimal newestPrice;
+
+    private BigDecimal targetAmount;
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/mapper/DappFundFlowDao.java b/src/main/java/cc/mrbird/febs/dapp/mapper/DappFundFlowDao.java
index f49f3f9..9285f48 100644
--- a/src/main/java/cc/mrbird/febs/dapp/mapper/DappFundFlowDao.java
+++ b/src/main/java/cc/mrbird/febs/dapp/mapper/DappFundFlowDao.java
@@ -16,4 +16,6 @@
     List<DappFundFlowEntity> selectListForMemberAndDay(@Param("memberId") Long memberId, @Param("type") int type);
 
     DappFundFlowEntity selectMineFundFlowByMemberIdAndTime(@Param("time") Long memberId, @Param("time") Date time);
+
+    DappFundFlowEntity selectByFromHash(@Param("txHash") String txHash, @Param("status") Integer status);
 }
diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
index bb60950..79fdc1d 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/BscCoinContractEvent.java
@@ -34,11 +34,11 @@
     private DappFundFlowDao dappFundFlowDao;
 
     private final String ADDRESS = "0x977a9ddfb965a9a3416fa72ca7f91c4949c18f25";
-    int decimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals();
 
     @Transactional(rollbackFor = Exception.class)
     @Override
     public void compile(EthUsdtContract.TransferEventResponse e) {
+        int decimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals();
         if (e.to != null) {
             if ("0x0000000000000000000000000000000000000000".equals(e.from)) {
                 return;
@@ -49,6 +49,7 @@
                 fromMember = dappMemberService.insertMember(e.from, null);
             }
 
+            // 如果转账对象地址不为源池地址,则创建用户
             if (!e.to.equals(ADDRESS)) {
                 DappMemberEntity toMember = dappMemberDao.selectByAddress(e.to, null);
                 if (toMember == null) {
@@ -56,23 +57,26 @@
                 }
             }
 
-            //
             // 卖币
             if (e.to.equals(ADDRESS)) {
                 BigInteger tokens = e.tokens;
-
-                BigDecimal amount = BigDecimal.valueOf(tokens.intValue()).divide(BigDecimal.TEN.pow(4), decimals, RoundingMode.HALF_DOWN);
-
-                DappFundFlowEntity fundFlow = new DappFundFlowEntity(fromMember.getId(), amount, 2, null, null, e.log.getTransactionHash());
-                dappFundFlowDao.insert(fundFlow);
+                BigDecimal amount = BigDecimal.valueOf(tokens.intValue()).divide(BigDecimal.TEN.pow(decimals), decimals, RoundingMode.HALF_DOWN);
+                DappFundFlowEntity fundFlow = dappFundFlowDao.selectByFromHash(e.log.getTransactionHash(), 1);
 
                 // TODO price
                 BigDecimal newPrice = BigDecimal.valueOf(1);
 
                 BigDecimal transferAmount = amount.multiply(newPrice);
-                String hash = ChainService.getInstance(ChainEnum.BSC_USDT.name()).transfer(e.from, transferAmount);
-                fundFlow.setToHash(hash);
+                fundFlow.setNewestPrice(newPrice);
+                // 更改状态为已同步
+                fundFlow.setStatus(2);
+                fundFlow.setTargetAmount(transferAmount);
                 dappFundFlowDao.updateById(fundFlow);
+
+                //TODO 自动转账
+//                String hash = ChainService.getInstance(ChainEnum.BSC_USDT.name()).transfer(e.from, transferAmount);
+//                fundFlow.setToHash(hash);
+//                dappFundFlowDao.updateById(fundFlow);
             }
 
         }
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 3fd1bce..2cdc9c8 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
@@ -32,26 +32,31 @@
     private DappFundFlowDao dappFundFlowDao;
 
     private final String ADDRESS = "0x977a9ddfb965a9a3416fa72ca7f91c4949c18f25";
-    int decimals = ChainService.getInstance(ChainEnum.BSC_USDT.name()).decimals();
-    int tfcDecimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals();
 
     @Override
     public void compile(EthUsdtContract.TransferEventResponse e) {
+        int decimals = ChainService.getInstance(ChainEnum.BSC_USDT.name()).decimals();
+        int tfcDecimals = ChainService.getInstance(ChainEnum.BSC_TFC.name()).decimals();
         if (ADDRESS.equals(e.to)) {
             DappMemberEntity fromMember = dappMemberService.findByAddress(e.from, null);
             if (fromMember == null) {
                 fromMember = dappMemberService.insertMember(e.from, null);
             }
 
-//            BigInteger tokens = e.tokens;
-//            BigDecimal amount = BigDecimal.valueOf(tokens.intValue()).divide(BigDecimal.TEN.pow(decimals), decimals, RoundingMode.HALF_DOWN);
-//
-//            DappFundFlowEntity fundFlow = new DappFundFlowEntity(fromMember.getId(), amount, 2, null, null, e.log.getTransactionHash());
-//            dappFundFlowDao.insert(fundFlow);
-//
-//            // TODO price
-//            BigDecimal newPrice = BigDecimal.valueOf(1);
-//
+            BigInteger tokens = e.tokens;
+            BigDecimal amount = BigDecimal.valueOf(tokens.intValue()).divide(BigDecimal.TEN.pow(decimals), decimals, RoundingMode.HALF_DOWN);
+            DappFundFlowEntity fundFlow = dappFundFlowDao.selectByFromHash(e.log.getTransactionHash(), 1);
+
+            // TODO price
+            BigDecimal newPrice = BigDecimal.valueOf(1);
+
+            BigDecimal transferAmount = amount.divide(newPrice, tfcDecimals, RoundingMode.HALF_DOWN);
+            fundFlow.setNewestPrice(newPrice);
+            // 更改状态为已同步
+            fundFlow.setStatus(2);
+            fundFlow.setTargetAmount(transferAmount);
+            dappFundFlowDao.updateById(fundFlow);
+
 //            BigDecimal transferAmount = amount.multiply(newPrice);
 //            String hash = ChainService.getInstance(ChainEnum.BSC_TFC.name()).transfer(e.from, transferAmount);
 //            fundFlow.setToHash(hash);
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 802720c..9483f16 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
@@ -117,7 +117,7 @@
         walletCoin.setFrozenAmount(walletCoin.getFrozenAmount().add(walletOperateDto.getAmount()));
         dappWalletCoinDao.updateById(walletCoin);
 
-        DappFundFlowEntity fund = new DappFundFlowEntity(member.getId(), walletOperateDto.getAmount(), AppContants.MONEY_TYPE_WITHDRAWAL, 1, fee);
+        DappFundFlowEntity fund = new DappFundFlowEntity(member.getId(), walletOperateDto.getAmount(), AppContants.MONEY_TYPE_WITHDRAWAL, 1, new BigDecimal(fee));
         dappFundFlowDao.insert(fund);
 
         DappAccountMoneyChangeEntity usdtChange = new DappAccountMoneyChangeEntity(member.getId(), preAmount, walletOperateDto.getAmount(), walletCoin.getAvailableAmount(), "USDT申请提现", AppContants.MONEY_TYPE_WITHDRAWAL);
@@ -193,6 +193,9 @@
 
     @Override
     public void transfer(TransferDto transferDto) {
+        DappMemberEntity member = LoginUserUtil.getAppUser();
 
+        DappFundFlowEntity fundFlow = new DappFundFlowEntity(member.getId(), transferDto.getAmount(), transferDto.getType(), 1, transferDto.getFee(), transferDto.getTxHash());
+        dappFundFlowDao.insert(fundFlow);
     }
 }
diff --git a/src/main/resources/mapper/dapp/DappFundFlowDao.xml b/src/main/resources/mapper/dapp/DappFundFlowDao.xml
index 1b1987f..ed422ab 100644
--- a/src/main/resources/mapper/dapp/DappFundFlowDao.xml
+++ b/src/main/resources/mapper/dapp/DappFundFlowDao.xml
@@ -34,4 +34,8 @@
           </if>
     </select>
 
+    <select id="selectByFromHash" resultType="cc.mrbird.febs.dapp.entity.DappFundFlowEntity">
+        select * from dapp_fund_flow
+        where from_hash=#{txHash} and status=#{status}
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.1