fix: send erc20
This commit is contained in:
parent
f4fc0ea324
commit
cd03dd949e
|
@ -1,23 +1,30 @@
|
||||||
package bridge
|
package bridge
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"math/big"
|
"math/big"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/ethereum/go-ethereum"
|
||||||
|
"github.com/ethereum/go-ethereum/accounts/abi"
|
||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
ethTypes "github.com/ethereum/go-ethereum/core/types"
|
ethTypes "github.com/ethereum/go-ethereum/core/types"
|
||||||
"github.com/status-im/status-go/account"
|
"github.com/status-im/status-go/account"
|
||||||
|
"github.com/status-im/status-go/contracts/ierc20"
|
||||||
"github.com/status-im/status-go/eth-node/types"
|
"github.com/status-im/status-go/eth-node/types"
|
||||||
"github.com/status-im/status-go/params"
|
"github.com/status-im/status-go/params"
|
||||||
|
"github.com/status-im/status-go/rpc"
|
||||||
"github.com/status-im/status-go/services/wallet/token"
|
"github.com/status-im/status-go/services/wallet/token"
|
||||||
"github.com/status-im/status-go/transactions"
|
"github.com/status-im/status-go/transactions"
|
||||||
)
|
)
|
||||||
|
|
||||||
type TransferBridge struct {
|
type TransferBridge struct {
|
||||||
|
rpcClient *rpc.Client
|
||||||
transactor *transactions.Transactor
|
transactor *transactions.Transactor
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewTransferBridge(transactor *transactions.Transactor) *TransferBridge {
|
func NewTransferBridge(rpcClient *rpc.Client, transactor *transactions.Transactor) *TransferBridge {
|
||||||
return &TransferBridge{transactor: transactor}
|
return &TransferBridge{rpcClient: rpcClient, transactor: transactor}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *TransferBridge) Name() string {
|
func (s *TransferBridge) Name() string {
|
||||||
|
@ -33,11 +40,46 @@ func (s *TransferBridge) CalculateFees(from, to *params.Network, token *token.To
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *TransferBridge) EstimateGas(fromNetwork *params.Network, toNetwork *params.Network, from common.Address, to common.Address, token *token.Token, amountIn *big.Int) (uint64, error) {
|
func (s *TransferBridge) EstimateGas(fromNetwork *params.Network, toNetwork *params.Network, from common.Address, to common.Address, token *token.Token, amountIn *big.Int) (uint64, error) {
|
||||||
// TODO fix for ERC20
|
estimation := uint64(0)
|
||||||
estimation, err := s.transactor.EstimateGas(fromNetwork, from, to, amountIn, []byte("eth_sendRawTransaction"))
|
var err error
|
||||||
|
if token.Symbol == "ETH" {
|
||||||
|
estimation, err = s.transactor.EstimateGas(fromNetwork, from, to, amountIn, []byte("eth_sendRawTransaction"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
ethClient, err := s.rpcClient.EthClient(fromNetwork.ChainID)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
abi, err := abi.JSON(strings.NewReader(ierc20.IERC20ABI))
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
input, err := abi.Pack("transfer",
|
||||||
|
to,
|
||||||
|
amountIn,
|
||||||
|
)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
msg := ethereum.CallMsg{
|
||||||
|
From: from,
|
||||||
|
To: &token.Address,
|
||||||
|
Data: input,
|
||||||
|
}
|
||||||
|
|
||||||
|
estimation, err = ethClient.EstimateGas(ctx, msg)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
increasedEstimation := float64(estimation) * IncreaseEstimatedGasFactor
|
increasedEstimation := float64(estimation) * IncreaseEstimatedGasFactor
|
||||||
return uint64(increasedEstimation), nil
|
return uint64(increasedEstimation), nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -406,7 +406,7 @@ func newSuggestedRoutes(
|
||||||
|
|
||||||
func NewRouter(s *Service) *Router {
|
func NewRouter(s *Service) *Router {
|
||||||
bridges := make(map[string]bridge.Bridge)
|
bridges := make(map[string]bridge.Bridge)
|
||||||
transfer := bridge.NewTransferBridge(s.transactor)
|
transfer := bridge.NewTransferBridge(s.rpcClient, s.transactor)
|
||||||
erc721Transfer := bridge.NewERC721TransferBridge(s.rpcClient, s.transactor)
|
erc721Transfer := bridge.NewERC721TransferBridge(s.rpcClient, s.transactor)
|
||||||
cbridge := bridge.NewCbridge(s.rpcClient, s.transactor, s.tokenManager)
|
cbridge := bridge.NewCbridge(s.rpcClient, s.transactor, s.tokenManager)
|
||||||
hop := bridge.NewHopBridge(s.rpcClient, s.transactor, s.tokenManager)
|
hop := bridge.NewHopBridge(s.rpcClient, s.transactor, s.tokenManager)
|
||||||
|
@ -648,6 +648,7 @@ func (r *Router) suggestedRoutes(
|
||||||
} else {
|
} else {
|
||||||
gasLimit = sendType.EstimateGas(r.s, network, addrFrom, tokenID)
|
gasLimit = sendType.EstimateGas(r.s, network, addrFrom, tokenID)
|
||||||
}
|
}
|
||||||
|
|
||||||
requiredNativeBalance := new(big.Int).Mul(gweiToWei(maxFees), big.NewInt(int64(gasLimit)))
|
requiredNativeBalance := new(big.Int).Mul(gweiToWei(maxFees), big.NewInt(int64(gasLimit)))
|
||||||
// Removed the required fees from maxAMount in case of native token tx
|
// Removed the required fees from maxAMount in case of native token tx
|
||||||
if token.IsNative() {
|
if token.IsNative() {
|
||||||
|
|
Loading…
Reference in New Issue