fix: send erc20

This commit is contained in:
Anthony Laibe 2023-11-16 11:12:01 +01:00
parent f4fc0ea324
commit cd03dd949e
2 changed files with 50 additions and 7 deletions

View File

@ -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
} }

View File

@ -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() {