Skip to content

Commit

Permalink
client/eth: Fix nonce err.
Browse files Browse the repository at this point in the history
  • Loading branch information
martonp authored and JoeGruffins committed Dec 24, 2024
1 parent f964b50 commit 9c5d74b
Showing 1 changed file with 15 additions and 12 deletions.
27 changes: 15 additions & 12 deletions client/asset/eth/eth.go
Original file line number Diff line number Diff line change
Expand Up @@ -1118,26 +1118,28 @@ func (w *assetWallet) withNonce(ctx context.Context, f transactionGenerator) (er
w.log.Trace("Nonce chosen for tx generator =", n)

// Make a first attempt with our best-known nonce.
tx, txType, amt, recipient, err := f(n)
if err != nil && strings.Contains(err.Error(), "nonce too low") {
tx, txType, amt, recipient, submitErr := f(n)
if submitErr != nil && strings.Contains(submitErr.Error(), "nonce too low") {
w.log.Warnf("Too-low nonce detected. Attempting recovery")
confirmedNonceAt, pendingNonceAt, err := w.node.nonce(ctx)
if err != nil {
return fmt.Errorf("error during too-low nonce recovery: %v", err)
}
w.confirmedNonceAt = confirmedNonceAt
w.pendingNonceAt = pendingNonceAt
if newNonce := nonce(); newNonce != n {
n = newNonce
// Try again.
tx, txType, amt, recipient, err = f(n)
if err != nil {
return err
}
w.log.Info("Nonce recovered and transaction broadcast")
} else {
newNonce := nonce()
if newNonce == n {
return fmt.Errorf("best RPC nonce %d not better than our best nonce %d", newNonce, n)
}
n = newNonce
// Try again.
tx, txType, amt, recipient, submitErr = f(n)
if submitErr == nil {
w.log.Info("Nonce recovered and transaction broadcast")
}
}
if submitErr != nil {
return submitErr
}

if tx != nil {
Expand All @@ -1149,7 +1151,8 @@ func (w *assetWallet) withNonce(ctx context.Context, f transactionGenerator) (er
w.emitTransactionNote(et.WalletTransaction, true)
w.log.Tracef("Transaction %s generated for nonce %s", et.ID, n)
}
return err

return nil
}

// nonceIsSane performs sanity checks on pending txs.
Expand Down

0 comments on commit 9c5d74b

Please sign in to comment.