Open ybensacq opened 3 weeks ago
@kariy would have any pointer on that one?
Hi, can I get assigned to this?
This seemed to be caused by the messaging service not having context of where to start the message processing.
For gathering the messages from the L1, we have an item in the configuration that may be used for that. However, as we're using a database, this block number may be different if Katana stops without graceful shutdown.
Currently, on the providers traits we have, there's no trait to store messaging information (last block gathered, last block sent messages). @kariy does it sound reasonable to add a provider trait to store such information and allow Katana to restart from an existing database being aware of which blocks must be processed for L1 <> L2 messaging?
@StarkFishinator are you feeling confident to dive into that? Or do you have an other strategy to propose?
Describe the bug When running Katana with the command
katana --messaging anvil.messaging.json --db-dir ./database
previously sent messages to L2 are resent to L1 upon restarting Katana.To Reproduce Steps to reproduce the behavior:
katana --messaging anvil.messaging.json --db-dir ./database
katana --messaging anvil.messaging.json --db-dir ./database
(wait for a few seconds)Expected behavior Messages should not be resent to L1 upon restarting Katana; the state should persist correctly between restarts.