From 8ee62bd0751b5ba3e084fb09538979dfe104ac3e Mon Sep 17 00:00:00 2001 From: Tudor Malene Date: Tue, 13 Aug 2024 10:09:03 +0100 Subject: [PATCH] improve deadline error --- tools/walletextension/rpcapi/transaction_api.go | 4 ++-- tools/walletextension/rpcapi/utils.go | 16 ++++++++++++++-- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/tools/walletextension/rpcapi/transaction_api.go b/tools/walletextension/rpcapi/transaction_api.go index 3833db0e77..82fe13bc44 100644 --- a/tools/walletextension/rpcapi/transaction_api.go +++ b/tools/walletextension/rpcapi/transaction_api.go @@ -101,7 +101,7 @@ func (s *TransactionAPI) GetTransactionReceipt(ctx context.Context, hash common. } func (s *TransactionAPI) SendTransaction(ctx context.Context, args gethapi.TransactionArgs) (common.Hash, error) { - txRec, err := ExecAuthRPC[common.Hash](ctx, s.we, &ExecCfg{account: args.From}, "eth_sendTransaction", args) + txRec, err := ExecAuthRPC[common.Hash](ctx, s.we, &ExecCfg{account: args.From, deadline: sendTransactionDuration}, "eth_sendTransaction", args) if err != nil { return common.Hash{}, err } @@ -131,7 +131,7 @@ func (s *TransactionAPI) FillTransaction(ctx context.Context, args gethapi.Trans } func (s *TransactionAPI) SendRawTransaction(ctx context.Context, input hexutil.Bytes) (common.Hash, error) { - txRec, err := ExecAuthRPC[common.Hash](ctx, s.we, &ExecCfg{tryAll: true}, "eth_sendRawTransaction", input) + txRec, err := ExecAuthRPC[common.Hash](ctx, s.we, &ExecCfg{tryAll: true, deadline: sendTransactionDuration}, "eth_sendRawTransaction", input) if err != nil { return common.Hash{}, err } diff --git a/tools/walletextension/rpcapi/utils.go b/tools/walletextension/rpcapi/utils.go index a90eacb810..caf326b85d 100644 --- a/tools/walletextension/rpcapi/utils.go +++ b/tools/walletextension/rpcapi/utils.go @@ -34,13 +34,15 @@ const ( ethCallAddrPadding = "000000000000000000000000" notAuthorised = "not authorised" + serverBusy = "server busy. please retry later" longCacheTTL = 5 * time.Hour shortCacheTTL = 1 * time.Minute // hardcoding the maximum time for an RPC request // this value will be propagated to the node and enclave and all the operations - maximumRPCCallDuration = 5 * time.Second + maximumRPCCallDuration = 5 * time.Second + sendTransactionDuration = 20 * time.Second ) var rpcNotImplemented = fmt.Errorf("rpc endpoint not implemented") @@ -52,6 +54,7 @@ type ExecCfg struct { tryUntilAuthorised bool adjustArgs func(acct *GWAccount) []any cacheCfg *CacheCfg + deadline time.Duration } type CacheStrategy uint8 @@ -136,10 +139,19 @@ func ExecAuthRPC[R any](ctx context.Context, w *Services, cfg *ExecCfg, method s } // wrap the context with a timeout to prevent long executions - timeoutContext, cancelCtx := context.WithTimeout(ctx, maximumRPCCallDuration) + deadline := cfg.deadline + // if not set, use default + if deadline == 0 { + deadline = maximumRPCCallDuration + } + timeoutContext, cancelCtx := context.WithTimeout(ctx, deadline) defer cancelCtx() err := rpcClient.CallContext(timeoutContext, &result, method, adjustedArgs...) + // return a friendly error to the user + if err != nil && errors.Is(err, context.DeadlineExceeded) { + return nil, fmt.Errorf(serverBusy) + } return result, err }) if err != nil {