From d3ef26884b9da797e030af6b349ec1d0cb377d80 Mon Sep 17 00:00:00 2001 From: dwasse Date: Sun, 23 Jun 2024 12:42:10 -0500 Subject: [PATCH] RFQ Relayer: check for db status mismatch (#2769) * Feat: check for status mismatch * [goreleaser] --------- Co-authored-by: Trajan0x --- services/rfq/relayer/service/statushandler.go | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/services/rfq/relayer/service/statushandler.go b/services/rfq/relayer/service/statushandler.go index 4f8b9bbdc2..3034f9174e 100644 --- a/services/rfq/relayer/service/statushandler.go +++ b/services/rfq/relayer/service/statushandler.go @@ -109,6 +109,20 @@ func (r *Relayer) mutexMiddleware(next func(ctx context.Context, span trace.Span } defer unlocker.Unlock() + // make sure the status has not changed since we last saw it + dbReq, err := r.db.GetQuoteRequestByID(ctx, req.TransactionID) + if err != nil { + return fmt.Errorf("could not get request: %w", err) + } + if dbReq.Status != req.Status { + span.SetAttributes( + attribute.Bool("status_changed", true), + attribute.String("db_status", dbReq.Status.String()), + attribute.String("handler_status", req.Status.String()), + ) + return nil + } + return next(ctx, span, req) } }