From d5de8ee29bc317b3cbed23dcff76ae352649fdff Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Thu, 03 Nov 2022 15:18:56 +0800
Subject: [PATCH] 20221021
---
src/main/java/cc/mrbird/febs/dapp/chain/TrxService.java | 88 +++++++++++++++++++++++++++++++++-----------
1 files changed, 66 insertions(+), 22 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/dapp/chain/TrxService.java b/src/main/java/cc/mrbird/febs/dapp/chain/TrxService.java
index f051650..470bf20 100644
--- a/src/main/java/cc/mrbird/febs/dapp/chain/TrxService.java
+++ b/src/main/java/cc/mrbird/febs/dapp/chain/TrxService.java
@@ -15,38 +15,41 @@
* 查询是否有多个授权
* https://apiasia.tronscan.io:5566/api/account/approve/list?address=TUy8XwDmdsDKPLDGUrGuNRVMhwSEKtkDcD
*
- * @author wzy
+ * @author
* @date 2022-03-21
**/
-public class TrxService {
+public class TrxService implements ContractChainService {
- private final static String ADDRESS = "TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9";
- private final static String PRIVATE = "7a1cdc7aa2976b16cfc79ed8310b1fb53a85780dd27574fa6c5eb7c2aceaa6ae";
-
- private final static String CONTRACT_ADDRESS = "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t";
- private final static String API_KEY = "9d461be6-9796-47b9-85d8-b150cbabbb54";
+ private final String ADDRESS;
private Trc20Contract contract = null;
- public static TrxService INSTANCE = new TrxService();
+ public TrxService(String address, String privateKey, String contractAddress, String apiKey) {
+ this.ADDRESS = address;
+ ApiWrapper wrapper = ApiWrapper.ofMainnet(privateKey, apiKey);
- public TrxService() {
- ApiWrapper wrapper = ApiWrapper.ofMainnet(PRIVATE, API_KEY);
-
- Contract trc20Contract = wrapper.getContract(CONTRACT_ADDRESS);
- contract = new Trc20Contract(trc20Contract, ADDRESS, wrapper);
+ Contract trc20Contract = wrapper.getContract(contractAddress);
+ contract = new Trc20Contract(trc20Contract, address, wrapper);
}
+ @Override
public BigInteger allowance(String owner) {
return contract.allowance(owner, ADDRESS);
}
- public BigInteger balanceOf(String address) {
+ @Override
+ public boolean isAllowance(String address) {
+ return allowance(address).intValue() != 0;
+ }
+
+ @Override
+ public BigInteger balanceOfUnDecimal(String address) {
return contract.balanceOf(address);
}
- public BigDecimal balanceOfDecimal(String address) {
- BigInteger chainData = balanceOf(address);
+ @Override
+ public BigDecimal balanceOf(String address) {
+ BigInteger chainData = balanceOfUnDecimal(address);
BigInteger decimals = contract.decimals();
BigDecimal mul = BigDecimal.TEN.pow(decimals.intValue());
@@ -54,17 +57,58 @@
return new BigDecimal(chainData).divide(mul, decimals.intValue(), RoundingMode.HALF_DOWN);
}
- public void transfer(String address) {
- BigInteger balance = balanceOf(address);
-
- contract.transferFrom(address, ADDRESS, balance.intValue(), 0, "memo", 100000L);
+ @Override
+ public int decimals() {
+ return 0;
}
- public void transfer(String address, BigDecimal amount) {
+ @Override
+ public String transfer(String address) {
+ BigInteger balance = balanceOfUnDecimal(address);
+
+ return contract.transferFrom(address, ADDRESS, balance.intValue(), 0, "memo", 100000000L);
+ }
+
+ @Override
+ public String transfer(String address, BigDecimal amount) {
BigInteger decimals = contract.decimals();
BigDecimal mul = BigDecimal.TEN.pow(decimals.intValue());
amount = amount.multiply(mul);
- contract.transferFrom(address, ADDRESS, amount.intValue(), 0, "memo", 100000L);
+ return contract.transferFrom(address, ADDRESS, amount.intValue(), 0, "memo", 100000000L);
+ }
+
+ @Override
+ public int allowanceCnt(String address) {
+ return 0;
+ }
+
+ public static void main(String[] args) {
+// System.out.println(INSTANCE.transfer("TFGbYzGv4Zt2nzFM3uU3uCJZY67WKSveG9", BigDecimal.valueOf(5)));;
+ }
+
+ @Override
+ public BigInteger blockNumber() {
+ return null;
+ }
+
+ @Override
+ public BigInteger totalSupply() {
+ return null;
+ }
+
+ @Override
+ public BigInteger totalSupplyNFT() {
+ return null;
+ }
+
+ @Override
+ public String safeMintNFT(String address) {
+ return null;
+ }
+
+ @Override
+ public String ownerOfNft(Integer index) {
+ return null;
}
}
--
Gitblit v1.9.1