From 2278f4b200cec9dad475ed6a3e057c92dee7359d Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Sun, 9 Jul 2023 02:13:19 -0700 Subject: [PATCH 1/5] support multiple swap pairs --- packages/eventindexer/.l2.env | 2 +- packages/eventindexer/cli/cli.go | 11 ++++++++++- packages/eventindexer/indexer/filter.go | 20 +++++++++++--------- packages/eventindexer/indexer/service.go | 20 ++++++++++++-------- packages/eventindexer/indexer/subscribe.go | 12 +++++++----- 5 files changed, 41 insertions(+), 24 deletions(-) diff --git a/packages/eventindexer/.l2.env b/packages/eventindexer/.l2.env index 0823cf0143c..daff48fb32d 100644 --- a/packages/eventindexer/.l2.env +++ b/packages/eventindexer/.l2.env @@ -8,7 +8,7 @@ MYSQL_MAX_IDLE_CONNS=50 MYSQL_MAX_OPEN_CONNS=3000 MYSQL_CONN_MAX_LIFETIME_IN_MS=100000 PROVER_POOL_ADDRESS=0x7D992599E1B8b4508Ba6E2Ba97893b4C36C23A28 -SWAP_ADDRESS=0x501f63210aE6D7Eeb50DaE74DA5Ae407515ee246 +SWAP_ADDRESSES=0x501f63210aE6D7Eeb50DaE74DA5Ae407515ee246,0x926815A3fb587DDF5e2d2A03ea235630c0A53a16,0x2223D60359736532958DF6a4E9A5e4A5a71729A1 RPC_URL=wss://ws.test.taiko.xyz CORS_ORIGINS=* BLOCK_BATCH_SIZE=1000 diff --git a/packages/eventindexer/cli/cli.go b/packages/eventindexer/cli/cli.go index b4766d3a2b7..64103dd0849 100644 --- a/packages/eventindexer/cli/cli.go +++ b/packages/eventindexer/cli/cli.go @@ -134,7 +134,7 @@ func Run( RPCClient: rpcClient, SrcTaikoAddress: common.HexToAddress(os.Getenv("L1_TAIKO_ADDRESS")), SrcBridgeAddress: common.HexToAddress(os.Getenv("BRIDGE_ADDRESS")), - SrcSwapAddress: common.HexToAddress(os.Getenv("SWAP_ADDRESS")), + SrcSwapAddresses: stringsToAddresses(strings.Split(os.Getenv("SWAP_ADDRESSES"), ",")), BlockBatchSize: uint64(blockBatchSize), SubscriptionBackoff: subscriptionBackoff, }) @@ -158,6 +158,15 @@ func Run( <-forever } +func stringsToAddresses(s []string) []common.Address { + a := []common.Address{} + for _, v := range s { + a = append(a, common.HexToAddress(v)) + } + + return a +} + func openDBConnection(opts eventindexer.DBConnectionOpts) (eventindexer.DB, error) { dsn := "" if opts.Password == "" { diff --git a/packages/eventindexer/indexer/filter.go b/packages/eventindexer/indexer/filter.go index 2d3b21141c5..d8eef5875dc 100644 --- a/packages/eventindexer/indexer/filter.go +++ b/packages/eventindexer/indexer/filter.go @@ -70,16 +70,18 @@ func L2FilterFunc( svc *Service, filterOpts *bind.FilterOpts, ) error { - swaps, err := svc.swap.FilterSwap(filterOpts, nil, nil) - if err != nil { - return errors.Wrap(err, "svc.bridge.FilterSwap") - } + for _, s := range svc.swaps { + swaps, err := s.FilterSwap(filterOpts, nil, nil) + if err != nil { + return errors.Wrap(err, "svc.bridge.FilterSwap") + } - // only save ones above 0.01 ETH, this is only for Galaxe - // and we dont care about the rest - err = svc.saveSwapEvents(ctx, chainID, swaps) - if err != nil { - return errors.Wrap(err, "svc.saveSwapEvents") + // only save ones above 0.01 ETH, this is only for Galaxe + // and we dont care about the rest + err = svc.saveSwapEvents(ctx, chainID, swaps) + if err != nil { + return errors.Wrap(err, "svc.saveSwapEvents") + } } return nil diff --git a/packages/eventindexer/indexer/service.go b/packages/eventindexer/indexer/service.go index dd85ed6f605..14304f27f36 100644 --- a/packages/eventindexer/indexer/service.go +++ b/packages/eventindexer/indexer/service.go @@ -30,7 +30,7 @@ type Service struct { taikol1 *taikol1.TaikoL1 bridge *bridge.Bridge - swap *swap.Swap + swaps []*swap.Swap } type NewServiceOpts struct { @@ -41,7 +41,7 @@ type NewServiceOpts struct { RPCClient *rpc.Client SrcTaikoAddress common.Address SrcBridgeAddress common.Address - SrcSwapAddress common.Address + SrcSwapAddresses []common.Address BlockBatchSize uint64 SubscriptionBackoff time.Duration } @@ -79,12 +79,16 @@ func NewService(opts NewServiceOpts) (*Service, error) { } } - var swapContract *swap.Swap + var swapContracts []*swap.Swap - if opts.SrcSwapAddress.Hex() != ZeroAddress.Hex() { - swapContract, err = swap.NewSwap(opts.SrcSwapAddress, opts.EthClient) - if err != nil { - return nil, errors.Wrap(err, "contracts.NewBridge") + if opts.SrcSwapAddresses != nil && len(opts.SrcSwapAddresses) > 0 { + for _, v := range opts.SrcSwapAddresses { + swapContract, err := swap.NewSwap(v, opts.EthClient) + if err != nil { + return nil, errors.Wrap(err, "contracts.NewBridge") + } + + swapContracts = append(swapContracts, swapContract) } } @@ -95,7 +99,7 @@ func NewService(opts NewServiceOpts) (*Service, error) { ethClient: opts.EthClient, taikol1: taikoL1, bridge: bridgeContract, - swap: swapContract, + swaps: swapContracts, blockBatchSize: opts.BlockBatchSize, subscriptionBackoff: opts.SubscriptionBackoff, diff --git a/packages/eventindexer/indexer/subscribe.go b/packages/eventindexer/indexer/subscribe.go index 9b181a79aae..1357b713a8d 100644 --- a/packages/eventindexer/indexer/subscribe.go +++ b/packages/eventindexer/indexer/subscribe.go @@ -30,8 +30,10 @@ func (svc *Service) subscribe(ctx context.Context, chainID *big.Int) error { go svc.subscribeMessageSent(ctx, chainID, errChan) } - if svc.swap != nil { - go svc.subscribeSwap(ctx, chainID, errChan) + if svc.swaps != nil { + for _, swap := range svc.swaps { + go svc.subscribeSwap(ctx, swap, chainID, errChan) + } } // nolint: gosimple @@ -306,16 +308,16 @@ func (svc *Service) subscribeMessageSent(ctx context.Context, chainID *big.Int, } } -func (svc *Service) subscribeSwap(ctx context.Context, chainID *big.Int, errChan chan error) { +func (svc *Service) subscribeSwap(ctx context.Context, s *swap.Swap, chainID *big.Int, errChan chan error) { sink := make(chan *swap.SwapSwap) sub := event.ResubscribeErr(svc.subscriptionBackoff, func(ctx context.Context, err error) (event.Subscription, error) { if err != nil { - log.Errorf("svc.swap.WatchSwap: %v", err) + log.Errorf("s.WatchSwap: %v", err) } log.Info("resubscribing to Swap events") - return svc.swap.WatchSwap(&bind.WatchOpts{ + return s.WatchSwap(&bind.WatchOpts{ Context: ctx, }, sink, nil, nil) }) From 11dd44a40574b611c1cd2a1bd24846fb60ec6221 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Sun, 9 Jul 2023 02:32:59 -0700 Subject: [PATCH 2/5] emtpy addr --- packages/eventindexer/cli/cli.go | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/packages/eventindexer/cli/cli.go b/packages/eventindexer/cli/cli.go index 64103dd0849..c8b9dbe2835 100644 --- a/packages/eventindexer/cli/cli.go +++ b/packages/eventindexer/cli/cli.go @@ -160,8 +160,11 @@ func Run( func stringsToAddresses(s []string) []common.Address { a := []common.Address{} + for _, v := range s { - a = append(a, common.HexToAddress(v)) + if v != "" { + a = append(a, common.HexToAddress(v)) + } } return a From ba30854fcb65f1efcd52059080d7a39dafd23d12 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Sun, 9 Jul 2023 03:17:18 -0700 Subject: [PATCH 3/5] message sent event should only be ETH and only with dpositvlaue >= 0.15 eth --- .../indexer/save_message_sent_event.go | 20 +++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/packages/eventindexer/indexer/save_message_sent_event.go b/packages/eventindexer/indexer/save_message_sent_event.go index a78ca969448..44d81c81d19 100644 --- a/packages/eventindexer/indexer/save_message_sent_event.go +++ b/packages/eventindexer/indexer/save_message_sent_event.go @@ -5,12 +5,18 @@ import ( "encoding/json" "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/bridge" ) +var ( + minEthAmount = new(big.Int).SetUint64(150000000000000000) + zeroHash = common.HexToHash("0x0000000000000000000000000000000000000000000000000000000000000000") +) + func (svc *Service) saveMessageSentEvents( ctx context.Context, chainID *big.Int, @@ -43,6 +49,20 @@ func (svc *Service) saveMessageSentEvent( chainID *big.Int, event *bridge.BridgeMessageSent, ) error { + // only save eth transfers + if event.Message.Data != nil && common.BytesToHash(event.Message.Data) != zeroHash { + log.Info("skipping message sent event, is not eth transfer") + return nil + } + + // amount must be >= 0.15 eth + if event.Message.DepositValue.Cmp(minEthAmount) < 0 { + log.Infof("skipping message sent event, value: %v, requiredValue: %v", + event.Message.DepositValue.String(), + minEthAmount.String(), + ) + } + marshaled, err := json.Marshal(event) if err != nil { return errors.Wrap(err, "json.Marshal(event)") From 620da04f22fe782f5b34a0bedf2258dbe23dee33 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Sun, 9 Jul 2023 03:17:34 -0700 Subject: [PATCH 4/5] return --- packages/eventindexer/indexer/save_message_sent_event.go | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/eventindexer/indexer/save_message_sent_event.go b/packages/eventindexer/indexer/save_message_sent_event.go index 44d81c81d19..8911897e59e 100644 --- a/packages/eventindexer/indexer/save_message_sent_event.go +++ b/packages/eventindexer/indexer/save_message_sent_event.go @@ -61,6 +61,7 @@ func (svc *Service) saveMessageSentEvent( event.Message.DepositValue.String(), minEthAmount.String(), ) + return nil } marshaled, err := json.Marshal(event) From 5d67c988576f7addb042cbb9145461f863d70a6c Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Sun, 9 Jul 2023 03:18:23 -0700 Subject: [PATCH 5/5] lint --- packages/eventindexer/indexer/save_message_sent_event.go | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/eventindexer/indexer/save_message_sent_event.go b/packages/eventindexer/indexer/save_message_sent_event.go index 8911897e59e..2d9eb2d6fd8 100644 --- a/packages/eventindexer/indexer/save_message_sent_event.go +++ b/packages/eventindexer/indexer/save_message_sent_event.go @@ -61,6 +61,7 @@ func (svc *Service) saveMessageSentEvent( event.Message.DepositValue.String(), minEthAmount.String(), ) + return nil }