fix_: browser connect - send transaction command
This commit is contained in:
parent
385933a60d
commit
8ddde51445
|
@ -76,6 +76,9 @@ type ClientInterface interface {
|
||||||
EthClient(chainID uint64) (chain.ClientInterface, error)
|
EthClient(chainID uint64) (chain.ClientInterface, error)
|
||||||
EthClients(chainIDs []uint64) (map[uint64]chain.ClientInterface, error)
|
EthClients(chainIDs []uint64) (map[uint64]chain.ClientInterface, error)
|
||||||
CallContext(context context.Context, result interface{}, chainID uint64, method string, args ...interface{}) error
|
CallContext(context context.Context, result interface{}, chainID uint64, method string, args ...interface{}) error
|
||||||
|
Call(result interface{}, chainID uint64, method string, args ...interface{}) error
|
||||||
|
CallRaw(body string) string
|
||||||
|
GetNetworkManager() *network.Manager
|
||||||
}
|
}
|
||||||
|
|
||||||
// Client represents RPC client with custom routing
|
// Client represents RPC client with custom routing
|
||||||
|
@ -177,6 +180,10 @@ func NewClient(client *gethrpc.Client, upstreamChainID uint64, upstream params.U
|
||||||
return &c, nil
|
return &c, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) GetNetworkManager() *network.Manager {
|
||||||
|
return c.NetworkManager
|
||||||
|
}
|
||||||
|
|
||||||
func (c *Client) SetWalletNotifier(notifier func(chainID uint64, message string)) {
|
func (c *Client) SetWalletNotifier(notifier func(chainID uint64, message string)) {
|
||||||
c.walletNotifier = notifier
|
c.walletNotifier = notifier
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +1,5 @@
|
||||||
// Code generated by MockGen. DO NOT EDIT.
|
// Code generated by MockGen. DO NOT EDIT.
|
||||||
// Source: rpc/client.go
|
// Source: rpc/client.go
|
||||||
//
|
|
||||||
// Generated by this command:
|
|
||||||
//
|
|
||||||
// mockgen -package=mock_rpcclient -destination=rpc/mock/client/client.go -source=rpc/client.go
|
|
||||||
//
|
|
||||||
|
|
||||||
// Package mock_rpcclient is a generated GoMock package.
|
// Package mock_rpcclient is a generated GoMock package.
|
||||||
package mock_rpcclient
|
package mock_rpcclient
|
||||||
|
@ -14,6 +9,7 @@ import (
|
||||||
reflect "reflect"
|
reflect "reflect"
|
||||||
|
|
||||||
chain "github.com/status-im/status-go/rpc/chain"
|
chain "github.com/status-im/status-go/rpc/chain"
|
||||||
|
network "github.com/status-im/status-go/rpc/network"
|
||||||
common "github.com/status-im/status-go/services/wallet/common"
|
common "github.com/status-im/status-go/services/wallet/common"
|
||||||
gomock "go.uber.org/mock/gomock"
|
gomock "go.uber.org/mock/gomock"
|
||||||
)
|
)
|
||||||
|
@ -51,15 +47,34 @@ func (m *MockClientInterface) AbstractEthClient(chainID common.ChainID) (chain.B
|
||||||
}
|
}
|
||||||
|
|
||||||
// AbstractEthClient indicates an expected call of AbstractEthClient.
|
// AbstractEthClient indicates an expected call of AbstractEthClient.
|
||||||
func (mr *MockClientInterfaceMockRecorder) AbstractEthClient(chainID any) *gomock.Call {
|
func (mr *MockClientInterfaceMockRecorder) AbstractEthClient(chainID interface{}) *gomock.Call {
|
||||||
mr.mock.ctrl.T.Helper()
|
mr.mock.ctrl.T.Helper()
|
||||||
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "AbstractEthClient", reflect.TypeOf((*MockClientInterface)(nil).AbstractEthClient), chainID)
|
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "AbstractEthClient", reflect.TypeOf((*MockClientInterface)(nil).AbstractEthClient), chainID)
|
||||||
}
|
}
|
||||||
|
|
||||||
// CallContext mocks base method.
|
// Call mocks base method.
|
||||||
func (m *MockClientInterface) CallContext(context context.Context, result any, chainID uint64, method string, args ...any) error {
|
func (m *MockClientInterface) Call(result interface{}, chainID uint64, method string, args ...interface{}) error {
|
||||||
m.ctrl.T.Helper()
|
m.ctrl.T.Helper()
|
||||||
varargs := []any{context, result, chainID, method}
|
varargs := []interface{}{result, chainID, method}
|
||||||
|
for _, a := range args {
|
||||||
|
varargs = append(varargs, a)
|
||||||
|
}
|
||||||
|
ret := m.ctrl.Call(m, "Call", varargs...)
|
||||||
|
ret0, _ := ret[0].(error)
|
||||||
|
return ret0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Call indicates an expected call of Call.
|
||||||
|
func (mr *MockClientInterfaceMockRecorder) Call(result, chainID, method interface{}, args ...interface{}) *gomock.Call {
|
||||||
|
mr.mock.ctrl.T.Helper()
|
||||||
|
varargs := append([]interface{}{result, chainID, method}, args...)
|
||||||
|
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "Call", reflect.TypeOf((*MockClientInterface)(nil).Call), varargs...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// CallContext mocks base method.
|
||||||
|
func (m *MockClientInterface) CallContext(context context.Context, result interface{}, chainID uint64, method string, args ...interface{}) error {
|
||||||
|
m.ctrl.T.Helper()
|
||||||
|
varargs := []interface{}{context, result, chainID, method}
|
||||||
for _, a := range args {
|
for _, a := range args {
|
||||||
varargs = append(varargs, a)
|
varargs = append(varargs, a)
|
||||||
}
|
}
|
||||||
|
@ -69,12 +84,26 @@ func (m *MockClientInterface) CallContext(context context.Context, result any, c
|
||||||
}
|
}
|
||||||
|
|
||||||
// CallContext indicates an expected call of CallContext.
|
// CallContext indicates an expected call of CallContext.
|
||||||
func (mr *MockClientInterfaceMockRecorder) CallContext(context, result, chainID, method any, args ...any) *gomock.Call {
|
func (mr *MockClientInterfaceMockRecorder) CallContext(context, result, chainID, method interface{}, args ...interface{}) *gomock.Call {
|
||||||
mr.mock.ctrl.T.Helper()
|
mr.mock.ctrl.T.Helper()
|
||||||
varargs := append([]any{context, result, chainID, method}, args...)
|
varargs := append([]interface{}{context, result, chainID, method}, args...)
|
||||||
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "CallContext", reflect.TypeOf((*MockClientInterface)(nil).CallContext), varargs...)
|
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "CallContext", reflect.TypeOf((*MockClientInterface)(nil).CallContext), varargs...)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// CallRaw mocks base method.
|
||||||
|
func (m *MockClientInterface) CallRaw(body string) string {
|
||||||
|
m.ctrl.T.Helper()
|
||||||
|
ret := m.ctrl.Call(m, "CallRaw", body)
|
||||||
|
ret0, _ := ret[0].(string)
|
||||||
|
return ret0
|
||||||
|
}
|
||||||
|
|
||||||
|
// CallRaw indicates an expected call of CallRaw.
|
||||||
|
func (mr *MockClientInterfaceMockRecorder) CallRaw(body interface{}) *gomock.Call {
|
||||||
|
mr.mock.ctrl.T.Helper()
|
||||||
|
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "CallRaw", reflect.TypeOf((*MockClientInterface)(nil).CallRaw), body)
|
||||||
|
}
|
||||||
|
|
||||||
// EthClient mocks base method.
|
// EthClient mocks base method.
|
||||||
func (m *MockClientInterface) EthClient(chainID uint64) (chain.ClientInterface, error) {
|
func (m *MockClientInterface) EthClient(chainID uint64) (chain.ClientInterface, error) {
|
||||||
m.ctrl.T.Helper()
|
m.ctrl.T.Helper()
|
||||||
|
@ -85,7 +114,7 @@ func (m *MockClientInterface) EthClient(chainID uint64) (chain.ClientInterface,
|
||||||
}
|
}
|
||||||
|
|
||||||
// EthClient indicates an expected call of EthClient.
|
// EthClient indicates an expected call of EthClient.
|
||||||
func (mr *MockClientInterfaceMockRecorder) EthClient(chainID any) *gomock.Call {
|
func (mr *MockClientInterfaceMockRecorder) EthClient(chainID interface{}) *gomock.Call {
|
||||||
mr.mock.ctrl.T.Helper()
|
mr.mock.ctrl.T.Helper()
|
||||||
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "EthClient", reflect.TypeOf((*MockClientInterface)(nil).EthClient), chainID)
|
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "EthClient", reflect.TypeOf((*MockClientInterface)(nil).EthClient), chainID)
|
||||||
}
|
}
|
||||||
|
@ -100,7 +129,21 @@ func (m *MockClientInterface) EthClients(chainIDs []uint64) (map[uint64]chain.Cl
|
||||||
}
|
}
|
||||||
|
|
||||||
// EthClients indicates an expected call of EthClients.
|
// EthClients indicates an expected call of EthClients.
|
||||||
func (mr *MockClientInterfaceMockRecorder) EthClients(chainIDs any) *gomock.Call {
|
func (mr *MockClientInterfaceMockRecorder) EthClients(chainIDs interface{}) *gomock.Call {
|
||||||
mr.mock.ctrl.T.Helper()
|
mr.mock.ctrl.T.Helper()
|
||||||
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "EthClients", reflect.TypeOf((*MockClientInterface)(nil).EthClients), chainIDs)
|
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "EthClients", reflect.TypeOf((*MockClientInterface)(nil).EthClients), chainIDs)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetNetworkManager mocks base method.
|
||||||
|
func (m *MockClientInterface) GetNetworkManager() *network.Manager {
|
||||||
|
m.ctrl.T.Helper()
|
||||||
|
ret := m.ctrl.Call(m, "GetNetworkManager")
|
||||||
|
ret0, _ := ret[0].(*network.Manager)
|
||||||
|
return ret0
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetNetworkManager indicates an expected call of GetNetworkManager.
|
||||||
|
func (mr *MockClientInterfaceMockRecorder) GetNetworkManager() *gomock.Call {
|
||||||
|
mr.mock.ctrl.T.Helper()
|
||||||
|
return mr.mock.ctrl.RecordCallWithMethodType(mr.mock, "GetNetworkManager", reflect.TypeOf((*MockClientInterface)(nil).GetNetworkManager))
|
||||||
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package connector
|
package connector
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
@ -25,6 +26,7 @@ func NewAPI(s *Service) *API {
|
||||||
|
|
||||||
// Transactions and signing
|
// Transactions and signing
|
||||||
r.Register("eth_sendTransaction", &commands.SendTransactionCommand{
|
r.Register("eth_sendTransaction", &commands.SendTransactionCommand{
|
||||||
|
RpcClient: s.rpc,
|
||||||
Db: s.db,
|
Db: s.db,
|
||||||
ClientHandler: c,
|
ClientHandler: c,
|
||||||
})
|
})
|
||||||
|
@ -65,7 +67,7 @@ func NewAPI(s *Service) *API {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (api *API) forwardRPC(URL string, inputJSON string) (interface{}, error) {
|
func (api *API) forwardRPC(URL string, request commands.RPCRequest) (interface{}, error) {
|
||||||
dApp, err := persistence.SelectDAppByUrl(api.s.db, URL)
|
dApp, err := persistence.SelectDAppByUrl(api.s.db, URL)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
@ -75,8 +77,17 @@ func (api *API) forwardRPC(URL string, inputJSON string) (interface{}, error) {
|
||||||
return "", commands.ErrDAppIsNotPermittedByUser
|
return "", commands.ErrDAppIsNotPermittedByUser
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if request.ChainID != dApp.ChainID {
|
||||||
|
request.ChainID = dApp.ChainID
|
||||||
|
}
|
||||||
|
|
||||||
var response map[string]interface{}
|
var response map[string]interface{}
|
||||||
rawResponse := api.s.rpc.CallRaw(inputJSON)
|
byteRequest, err := json.Marshal(request)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
rawResponse := api.s.rpc.CallRaw(string(byteRequest))
|
||||||
if err := json.Unmarshal([]byte(rawResponse), &response); err != nil {
|
if err := json.Unmarshal([]byte(rawResponse), &response); err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
@ -95,17 +106,17 @@ func (api *API) forwardRPC(URL string, inputJSON string) (interface{}, error) {
|
||||||
return nil, ErrInvalidResponseFromForwardedRpc
|
return nil, ErrInvalidResponseFromForwardedRpc
|
||||||
}
|
}
|
||||||
|
|
||||||
func (api *API) CallRPC(inputJSON string) (interface{}, error) {
|
func (api *API) CallRPC(ctx context.Context, inputJSON string) (interface{}, error) {
|
||||||
request, err := commands.RPCRequestFromJSON(inputJSON)
|
request, err := commands.RPCRequestFromJSON(inputJSON)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
if command, exists := api.r.GetCommand(request.Method); exists {
|
if command, exists := api.r.GetCommand(request.Method); exists {
|
||||||
return command.Execute(request)
|
return command.Execute(ctx, request)
|
||||||
}
|
}
|
||||||
|
|
||||||
return api.forwardRPC(request.URL, inputJSON)
|
return api.forwardRPC(request.URL, request)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (api *API) RecallDAppPermission(origin string) error {
|
func (api *API) RecallDAppPermission(origin string) error {
|
||||||
|
|
|
@ -5,20 +5,16 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
"github.com/status-im/status-go/params"
|
"github.com/status-im/status-go/rpc/network"
|
||||||
)
|
)
|
||||||
|
|
||||||
type NetworkManagerInterface interface {
|
|
||||||
GetActiveNetworks() ([]*params.Network, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
var (
|
var (
|
||||||
ErrNoActiveNetworks = errors.New("no active networks available")
|
ErrNoActiveNetworks = errors.New("no active networks available")
|
||||||
ErrUnsupportedNetwork = errors.New("unsupported network")
|
ErrUnsupportedNetwork = errors.New("unsupported network")
|
||||||
)
|
)
|
||||||
|
|
||||||
// GetSupportedChainIDs retrieves the chain IDs from the provided NetworkManager.
|
// GetSupportedChainIDs retrieves the chain IDs from the provided NetworkManager.
|
||||||
func GetSupportedChainIDs(networkManager NetworkManagerInterface) ([]uint64, error) {
|
func GetSupportedChainIDs(networkManager *network.Manager) ([]uint64, error) {
|
||||||
activeNetworks, err := networkManager.GetActiveNetworks()
|
activeNetworks, err := networkManager.GetActiveNetworks()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -36,7 +32,7 @@ func GetSupportedChainIDs(networkManager NetworkManagerInterface) ([]uint64, err
|
||||||
return chainIDs, nil
|
return chainIDs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetDefaultChainID(networkManager NetworkManagerInterface) (uint64, error) {
|
func GetDefaultChainID(networkManager *network.Manager) (uint64, error) {
|
||||||
chainIDs, err := GetSupportedChainIDs(networkManager)
|
chainIDs, err := GetSupportedChainIDs(networkManager)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -16,7 +17,7 @@ func FormatAccountAddressToResponse(address types.Address) []string {
|
||||||
return []string{strings.ToLower(address.Hex())}
|
return []string{strings.ToLower(address.Hex())}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *AccountsCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *AccountsCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
|
|
@ -1,19 +1,21 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
|
|
||||||
|
"github.com/status-im/status-go/rpc/network"
|
||||||
"github.com/status-im/status-go/services/connector/chainutils"
|
"github.com/status-im/status-go/services/connector/chainutils"
|
||||||
persistence "github.com/status-im/status-go/services/connector/database"
|
persistence "github.com/status-im/status-go/services/connector/database"
|
||||||
walletCommon "github.com/status-im/status-go/services/wallet/common"
|
walletCommon "github.com/status-im/status-go/services/wallet/common"
|
||||||
)
|
)
|
||||||
|
|
||||||
type ChainIDCommand struct {
|
type ChainIDCommand struct {
|
||||||
NetworkManager NetworkManagerInterface
|
NetworkManager *network.Manager
|
||||||
Db *sql.DB
|
Db *sql.DB
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ChainIDCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *ChainIDCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
@ -51,7 +52,7 @@ func (r *RPCRequest) getPersonalSignParams() (*PersonalSignParams, error) {
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *PersonalSignCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *PersonalSignCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"errors"
|
"errors"
|
||||||
|
|
||||||
|
@ -26,7 +27,7 @@ type RawAccountsResponse struct {
|
||||||
Result []accounts.Account `json:"result"`
|
Result []accounts.Account `json:"result"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *RequestAccountsCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *RequestAccountsCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"time"
|
"time"
|
||||||
|
@ -51,7 +52,7 @@ func (c *RequestPermissionsCommand) getPermissionResponse(methodName string) Per
|
||||||
return response
|
return response
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *RequestPermissionsCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *RequestPermissionsCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
|
|
||||||
persistence "github.com/status-im/status-go/services/connector/database"
|
persistence "github.com/status-im/status-go/services/connector/database"
|
||||||
|
@ -11,7 +12,7 @@ type RevokePermissionsCommand struct {
|
||||||
Db *sql.DB
|
Db *sql.DB
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *RevokePermissionsCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *RevokePermissionsCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
@ -11,6 +12,17 @@ import (
|
||||||
"github.com/status-im/status-go/transactions"
|
"github.com/status-im/status-go/transactions"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
Method_EthAccounts = "eth_accounts"
|
||||||
|
Method_EthRequestAccounts = "eth_requestAccounts"
|
||||||
|
Method_EthChainId = "eth_chainId"
|
||||||
|
Method_PersonalSign = "personal_sign"
|
||||||
|
Method_EthSendTransaction = "eth_sendTransaction"
|
||||||
|
Method_RequestPermissions = "wallet_requestPermissions"
|
||||||
|
Method_RevokePermissions = "wallet_revokePermissions"
|
||||||
|
Method_SwitchEthereumChain = "wallet_switchEthereumChain"
|
||||||
|
)
|
||||||
|
|
||||||
// errors
|
// errors
|
||||||
var (
|
var (
|
||||||
ErrRequestMissingDAppData = errors.New("request missing dApp data")
|
ErrRequestMissingDAppData = errors.New("request missing dApp data")
|
||||||
|
@ -26,10 +38,11 @@ type RPCRequest struct {
|
||||||
URL string `json:"url"`
|
URL string `json:"url"`
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
IconURL string `json:"iconUrl"`
|
IconURL string `json:"iconUrl"`
|
||||||
|
ChainID uint64 `json:"chainId"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type RPCCommand interface {
|
type RPCCommand interface {
|
||||||
Execute(request RPCRequest) (interface{}, error)
|
Execute(ctx context.Context, request RPCRequest) (interface{}, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type RequestAccountsAcceptedArgs struct {
|
type RequestAccountsAcceptedArgs struct {
|
||||||
|
|
|
@ -1,12 +1,18 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"math/big"
|
||||||
|
|
||||||
|
"github.com/ethereum/go-ethereum/common"
|
||||||
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
||||||
|
"github.com/status-im/status-go/rpc"
|
||||||
persistence "github.com/status-im/status-go/services/connector/database"
|
persistence "github.com/status-im/status-go/services/connector/database"
|
||||||
|
"github.com/status-im/status-go/services/wallet/router/fees"
|
||||||
"github.com/status-im/status-go/signal"
|
"github.com/status-im/status-go/signal"
|
||||||
"github.com/status-im/status-go/transactions"
|
"github.com/status-im/status-go/transactions"
|
||||||
)
|
)
|
||||||
|
@ -14,9 +20,11 @@ import (
|
||||||
var (
|
var (
|
||||||
ErrParamsFromAddressIsNotShared = errors.New("from parameter address is not dApp's shared account")
|
ErrParamsFromAddressIsNotShared = errors.New("from parameter address is not dApp's shared account")
|
||||||
ErrNoTransactionParamsFound = errors.New("no transaction in params found")
|
ErrNoTransactionParamsFound = errors.New("no transaction in params found")
|
||||||
|
ErrSendingParamsInvalid = errors.New("sending params are invalid")
|
||||||
)
|
)
|
||||||
|
|
||||||
type SendTransactionCommand struct {
|
type SendTransactionCommand struct {
|
||||||
|
RpcClient rpc.ClientInterface
|
||||||
Db *sql.DB
|
Db *sql.DB
|
||||||
ClientHandler ClientSideHandlerInterface
|
ClientHandler ClientSideHandlerInterface
|
||||||
}
|
}
|
||||||
|
@ -45,7 +53,7 @@ func (r *RPCRequest) getSendTransactionParams() (*transactions.SendTxArgs, error
|
||||||
return &sendTxArgs, nil
|
return &sendTxArgs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *SendTransactionCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *SendTransactionCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
@ -65,10 +73,49 @@ func (c *SendTransactionCommand) Execute(request RPCRequest) (interface{}, error
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if !params.Valid() {
|
||||||
|
return "", ErrSendingParamsInvalid
|
||||||
|
}
|
||||||
|
|
||||||
if params.From != dApp.SharedAccount {
|
if params.From != dApp.SharedAccount {
|
||||||
return "", ErrParamsFromAddressIsNotShared
|
return "", ErrParamsFromAddressIsNotShared
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if params.Value == nil {
|
||||||
|
params.Value = (*hexutil.Big)(big.NewInt(0))
|
||||||
|
}
|
||||||
|
|
||||||
|
if params.GasPrice == nil || (params.MaxFeePerGas == nil && params.MaxPriorityFeePerGas == nil) {
|
||||||
|
feeManager := &fees.FeeManager{
|
||||||
|
RPCClient: c.RpcClient,
|
||||||
|
}
|
||||||
|
fetchedFees, err := feeManager.SuggestedFees(ctx, dApp.ChainID)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
if !fetchedFees.EIP1559Enabled {
|
||||||
|
params.GasPrice = (*hexutil.Big)(fetchedFees.GasPrice)
|
||||||
|
} else {
|
||||||
|
params.MaxFeePerGas = (*hexutil.Big)(fetchedFees.FeeFor(fees.GasFeeMedium))
|
||||||
|
params.MaxPriorityFeePerGas = (*hexutil.Big)(fetchedFees.MaxPriorityFeePerGas)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if params.Nonce == nil {
|
||||||
|
ethClient, err := c.RpcClient.EthClient(dApp.ChainID)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
nonce, err := ethClient.PendingNonceAt(ctx, common.Address(dApp.SharedAccount))
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
params.Nonce = (*hexutil.Uint64)(&nonce)
|
||||||
|
}
|
||||||
|
|
||||||
hash, err := c.ClientHandler.RequestSendTransaction(signal.ConnectorDApp{
|
hash, err := c.ClientHandler.RequestSendTransaction(signal.ConnectorDApp{
|
||||||
URL: request.URL,
|
URL: request.URL,
|
||||||
Name: request.Name,
|
Name: request.Name,
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"errors"
|
"errors"
|
||||||
"slices"
|
"slices"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
|
"github.com/status-im/status-go/rpc/network"
|
||||||
"github.com/status-im/status-go/services/connector/chainutils"
|
"github.com/status-im/status-go/services/connector/chainutils"
|
||||||
persistence "github.com/status-im/status-go/services/connector/database"
|
persistence "github.com/status-im/status-go/services/connector/database"
|
||||||
walletCommon "github.com/status-im/status-go/services/wallet/common"
|
walletCommon "github.com/status-im/status-go/services/wallet/common"
|
||||||
|
@ -20,7 +22,7 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
type SwitchEthereumChainCommand struct {
|
type SwitchEthereumChainCommand struct {
|
||||||
NetworkManager NetworkManagerInterface
|
NetworkManager *network.Manager
|
||||||
Db *sql.DB
|
Db *sql.DB
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,7 +55,7 @@ func (c *SwitchEthereumChainCommand) getSupportedChainIDs() ([]uint64, error) {
|
||||||
return chainutils.GetSupportedChainIDs(c.NetworkManager)
|
return chainutils.GetSupportedChainIDs(c.NetworkManager)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *SwitchEthereumChainCommand) Execute(request RPCRequest) (interface{}, error) {
|
func (c *SwitchEthereumChainCommand) Execute(ctx context.Context, request RPCRequest) (interface{}, error) {
|
||||||
err := request.Validate()
|
err := request.Validate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
|
|
@ -6,10 +6,11 @@ import (
|
||||||
"github.com/ethereum/go-ethereum/p2p"
|
"github.com/ethereum/go-ethereum/p2p"
|
||||||
|
|
||||||
gethrpc "github.com/ethereum/go-ethereum/rpc"
|
gethrpc "github.com/ethereum/go-ethereum/rpc"
|
||||||
"github.com/status-im/status-go/services/connector/commands"
|
"github.com/status-im/status-go/rpc"
|
||||||
|
"github.com/status-im/status-go/rpc/network"
|
||||||
)
|
)
|
||||||
|
|
||||||
func NewService(db *sql.DB, rpc commands.RPCClientInterface, nm commands.NetworkManagerInterface) *Service {
|
func NewService(db *sql.DB, rpc rpc.ClientInterface, nm *network.Manager) *Service {
|
||||||
return &Service{
|
return &Service{
|
||||||
db: db,
|
db: db,
|
||||||
rpc: rpc,
|
rpc: rpc,
|
||||||
|
@ -19,8 +20,8 @@ func NewService(db *sql.DB, rpc commands.RPCClientInterface, nm commands.Network
|
||||||
|
|
||||||
type Service struct {
|
type Service struct {
|
||||||
db *sql.DB
|
db *sql.DB
|
||||||
rpc commands.RPCClientInterface
|
rpc rpc.ClientInterface
|
||||||
nm commands.NetworkManagerInterface
|
nm *network.Manager
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Service) Start() error {
|
func (s *Service) Start() error {
|
||||||
|
|
|
@ -87,7 +87,7 @@ type FeeHistory struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type FeeManager struct {
|
type FeeManager struct {
|
||||||
RPCClient *rpc.Client
|
RPCClient rpc.ClientInterface
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *FeeManager) SuggestedFees(ctx context.Context, chainID uint64) (*SuggestedFees, error) {
|
func (f *FeeManager) SuggestedFees(ctx context.Context, chainID uint64) (*SuggestedFees, error) {
|
||||||
|
|
Loading…
Reference in New Issue