From 67ba5e44eca82c301dcd2a8d3c0909ac080a804c Mon Sep 17 00:00:00 2001 From: jeff <113397187+cyberhorsey@users.noreply.github.com> Date: Fri, 7 Jul 2023 14:51:38 -0700 Subject: [PATCH] feat(eventindexer): store swap sender correctly, plus check min amt (#14128) --- .../eventindexer/indexer/save_swap_event.go | 25 ++++++++++++++++--- packages/eventindexer/indexer/subscribe.go | 2 -- 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/packages/eventindexer/indexer/save_swap_event.go b/packages/eventindexer/indexer/save_swap_event.go index 297bd9a7652..bc994b79d26 100644 --- a/packages/eventindexer/indexer/save_swap_event.go +++ b/packages/eventindexer/indexer/save_swap_event.go @@ -3,14 +3,20 @@ package indexer import ( "context" "encoding/json" + "fmt" "math/big" + "github.com/ethereum/go-ethereum/common" "github.com/pkg/errors" log "github.com/sirupsen/logrus" "github.com/taikoxyz/taiko-mono/packages/eventindexer" "github.com/taikoxyz/taiko-mono/packages/eventindexer/contracts/swap" ) +var ( + minTradeAmount = big.NewInt(10000000000000000) +) + func (svc *Service) saveSwapEvents( ctx context.Context, chainID *big.Int, @@ -24,8 +30,6 @@ func (svc *Service) saveSwapEvents( for { event := events.Event - log.Infof("new Swap event for sender: %v", event.Sender.Hex()) - if err := svc.saveSwapEvent(ctx, chainID, event); err != nil { eventindexer.SwapEventsProcessedError.Inc() @@ -43,6 +47,21 @@ func (svc *Service) saveSwapEvent( chainID *big.Int, event *swap.SwapSwap, ) error { + log.Infof("swap event for sender 0x%v, amount: %v", + common.Bytes2Hex(event.Raw.Topics[2].Bytes()[12:]), + event.Amount0In.String(), + ) + + // we only want events with > 0.1 ETH swap + if event.Amount0In.Cmp(minTradeAmount) <= 0 && event.Amount1Out.Cmp(minTradeAmount) <= 0 { + log.Infof("skipping skip event, min trade too low. amountIn: %v, amountOut: %v", + event.Amount0In.String(), + event.Amount1Out.String(), + ) + + return nil + } + marshaled, err := json.Marshal(event) if err != nil { return errors.Wrap(err, "json.Marshal(event)") @@ -53,7 +72,7 @@ func (svc *Service) saveSwapEvent( Data: string(marshaled), ChainID: chainID, Event: eventindexer.EventNameSwap, - Address: event.Sender.Hex(), + Address: fmt.Sprintf("0x%v", common.Bytes2Hex(event.Raw.Topics[2].Bytes()[12:])), }) if err != nil { return errors.Wrap(err, "svc.eventRepo.Save") diff --git a/packages/eventindexer/indexer/subscribe.go b/packages/eventindexer/indexer/subscribe.go index 23dd4fb9042..9b181a79aae 100644 --- a/packages/eventindexer/indexer/subscribe.go +++ b/packages/eventindexer/indexer/subscribe.go @@ -332,8 +332,6 @@ func (svc *Service) subscribeSwap(ctx context.Context, chainID *big.Int, errChan errChan <- errors.Wrap(err, "sub.Err()") case event := <-sink: go func() { - log.Infof("swap event for sender %v", event.Sender.Hex()) - if err := svc.saveSwapEvent(ctx, chainID, event); err != nil { eventindexer.SwapEventsProcessedError.Inc()