From d3875ba523d8457b31cad39799aeeb29af224c74 Mon Sep 17 00:00:00 2001 From: Leo Date: Thu, 22 Oct 2020 12:20:13 +0200 Subject: [PATCH] bridge: do not log errors for duplicate VAA submissions No functional change, just nicer log output. ghstack-source-id: f946cbe71dca976b97d35d9c4b4615f2ceac5a32 Pull Request resolved: https://github.com/certusone/wormhole/pull/52 --- bridge/pkg/solana/watcher.go | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/bridge/pkg/solana/watcher.go b/bridge/pkg/solana/watcher.go index 7ba9347f..ed78bd67 100644 --- a/bridge/pkg/solana/watcher.go +++ b/bridge/pkg/solana/watcher.go @@ -5,6 +5,7 @@ import ( "encoding/hex" "fmt" "math/big" + "strings" "time" eth_common "github.com/ethereum/go-ethereum/common" @@ -111,8 +112,6 @@ func (e *SolanaBridgeWatcher) Run(ctx context.Context) error { res, err := c.SubmitVAA(timeout, &agentv1.SubmitVAARequest{Vaa: vaaBytes}) cancel() if err != nil { - logger.Error("failed to submit VAA", zap.Error(err), zap.String("digest", h)) - st, ok := status.FromError(err) if !ok { panic("err not a status") @@ -128,13 +127,25 @@ func (e *SolanaBridgeWatcher) Run(ctx context.Context) error { codes.Unavailable, codes.Aborted: - logger.Error("requeuing VAA", zap.Error(err), zap.String("digest", h)) + logger.Error("transient error, requeuing VAA", zap.Error(err), zap.String("digest", h)) // Tombstone goroutine go func(v *vaa.VAA) { time.Sleep(10 * time.Second) e.vaaChan <- v }(v) + + case codes.Internal: + // This VAA has already been executed on chain, successfully or not. + // TODO: dissect InstructionError in agent and convert this to the proper gRPC code + if strings.Contains(st.Message(), "custom program error: 0xb") { // AlreadyExists + logger.Info("VAA already submitted on-chain, ignoring", zap.Error(err), zap.String("digest", h)) + break + } + + fallthrough + default: + logger.Error("error submitting VAA", zap.Error(err), zap.String("digest", h)) } break