Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement Express Lane Timeboost #2561

Open
wants to merge 328 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
328 commits
Select commit Hold shift + click to select a range
c315dd8
tidy
rauljordan Aug 19, 2024
e6c6def
Merge branch 'express-lane-timeboost' of github.com:OffchainLabs/nitr…
rauljordan Aug 19, 2024
d40cee9
Update timeboost/ticker.go
rauljordan Aug 19, 2024
7b63dc9
condition
rauljordan Aug 19, 2024
1aaf4da
limit bids
rauljordan Aug 19, 2024
6705b06
last second leeway for bid processing
rauljordan Aug 19, 2024
ab55292
resolve wait a second
rauljordan Aug 19, 2024
7a70988
dont hardcode ports
rauljordan Aug 19, 2024
47697ed
Merge branch 'master' into express-lane-timeboost
rauljordan Aug 19, 2024
26f28d4
Merge branch 'master' into express-lane-timeboost
rauljordan Aug 19, 2024
d9307d8
Merge branch 'express-lane-timeboost' of github.com:OffchainLabs/nitr…
rauljordan Aug 19, 2024
e4892b2
geth pin
rauljordan Aug 19, 2024
4dc427a
add in new queue
rauljordan Aug 19, 2024
e2110ab
edits
rauljordan Aug 19, 2024
15e6087
Fix tie breaker and retry resolve bid tx
terencechain Aug 19, 2024
f75f242
edits
rauljordan Aug 20, 2024
ffd0766
commit
rauljordan Aug 20, 2024
a5c8777
rem redundant sig verify
rauljordan Aug 20, 2024
9d53ff7
Merge branch 'master' into express-lane-timeboost
rauljordan Aug 20, 2024
196bdc7
Fix tie breaker and better retry
terencechain Aug 20, 2024
e61c3b2
edit
rauljordan Aug 20, 2024
44c8179
Merge branch 'master' into express-lane-timeboost
rauljordan Aug 20, 2024
981bc6a
Fix duplicated word
terencechain Aug 20, 2024
8db0bd0
Add copyright to express lane service
terencechain Aug 21, 2024
ec185f5
Better popped the auction resolution tx log
terencechain Aug 21, 2024
d15e0c5
Fix auction-contract-address doesnt match the field SequencerEndpoint
terencechain Aug 21, 2024
f28896d
Remove unused conversions
terencechain Aug 21, 2024
3eec686
Fix express lane advantage to 200ms
terencechain Aug 23, 2024
98326dc
Update reserve price
terencechain Aug 21, 2024
3632c66
Filter transfer log
terencechain Aug 23, 2024
8122a49
Tristan's feedback
terencechain Aug 29, 2024
5c03cf0
Tristan's feedback
terencechain Sep 5, 2024
72de9d2
Add timeboosted field to broadcast feed
ganeshvanahalli Sep 24, 2024
fa457b1
Fix autonomous-auctioner cli startup
Tristan-Wilson Oct 1, 2024
97f7c18
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
ganeshvanahalli Oct 2, 2024
1781ae3
change timeboosted byte array calculation
ganeshvanahalli Oct 2, 2024
a713900
address PR comments
ganeshvanahalli Oct 2, 2024
811fd19
define IsTxTimeboosted on the BlockMetadata type
ganeshvanahalli Oct 2, 2024
b67b08b
only write blockMetadata to db when its non-nil, prevents erasing of …
ganeshvanahalli Oct 11, 2024
0ff4f7d
Start rpc stack after creating bid validator
Tristan-Wilson Oct 11, 2024
b8890a1
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 11, 2024
7a2eb14
Plumbing to be able to start timeboost in nitro
Tristan-Wilson Oct 11, 2024
572d4b2
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 11, 2024
5fda4c4
use arbostypes.BlockMetadata return type instead of []byte for BlockM…
ganeshvanahalli Oct 14, 2024
0d3d83d
Publish Timeboost BlockMetadata to Sequencer Coordinator's redis
ganeshvanahalli Oct 14, 2024
d72fd38
Fix various linter and compilation issues
Tristan-Wilson Oct 14, 2024
a5b3eea
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 14, 2024
2cd1ed0
Fix cyclic dependency in test
Tristan-Wilson Oct 14, 2024
13a9e0e
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 14, 2024
9a85c95
Merge branch 'add-timeboosted-broadcastfeedmessage' into publish-bloc…
ganeshvanahalli Oct 14, 2024
f4efcd9
Move where timeboost is started to avoid circ dep
Tristan-Wilson Oct 15, 2024
d3cd8f5
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 15, 2024
651277d
Temp fix for timeboost startup race cond, fix NPE
Tristan-Wilson Oct 15, 2024
a19acb6
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 15, 2024
31ea7be
Retry initial call on express lane contract
Tristan-Wilson Oct 16, 2024
0aa68ef
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 16, 2024
3835dff
Persist Auctioneer Bid DB to S3
ganeshvanahalli Oct 18, 2024
03fa6a4
complete plumbing
ganeshvanahalli Oct 18, 2024
d1890da
Add bidder-client exe for timeboost deposits/bids
Tristan-Wilson Oct 18, 2024
bf8adc5
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Oct 18, 2024
81ab68b
handle empty bids case
ganeshvanahalli Oct 21, 2024
8200213
Enable reading of bids from large sql database in chunks to avoid OOMing
ganeshvanahalli Oct 21, 2024
15ba495
Merge branch 'express-lane-timeboost' into persist-auctioneerbids-s3
ganeshvanahalli Oct 21, 2024
103b395
Clear bidsPerSenderInRound when auction closes
Tristan-Wilson Oct 23, 2024
d60de53
Timeboost Bulk Metadata API
ganeshvanahalli Oct 24, 2024
712b3ad
validate BlockMetadataApiCacheSize
ganeshvanahalli Oct 24, 2024
ee5bfd6
Merge branch 'express-lane-timeboost' into bulk-blockmetadata-api
ganeshvanahalli Oct 24, 2024
86ee92b
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
ganeshvanahalli Oct 24, 2024
3bb87ee
Merge branch 'add-timeboosted-broadcastfeedmessage' into bulk-blockme…
ganeshvanahalli Oct 24, 2024
3431e2c
Use FilterSystem for ContractFilterer in ELS
Tristan-Wilson Oct 24, 2024
952cd37
move BlockMetadataAtCount into ConsensusInfo
ganeshvanahalli Oct 25, 2024
cad5b12
Fix SequenceNumber attribute and decode order
TucksonDev Oct 25, 2024
857823c
update arb_getRawBlockMetadata to accept rpc.BlockNumber inputs inste…
ganeshvanahalli Oct 28, 2024
851d2bd
protect BulkBlockMetadataFetcher's cache with mutex
ganeshvanahalli Oct 28, 2024
4c07677
Enable caching of blockMetadata by default and clear cache when reorg…
ganeshvanahalli Oct 28, 2024
2148c35
address PR comments
ganeshvanahalli Oct 28, 2024
4da2511
Merge branch 'add-timeboosted-broadcastfeedmessage' into publish-bloc…
ganeshvanahalli Oct 28, 2024
b6ea4f5
Fix panic when transferring express lane controller due to race in lr…
amsanghi Oct 28, 2024
18cddc5
address PR comments
ganeshvanahalli Oct 28, 2024
d64ce27
Adapter for ContractFilterer
Tristan-Wilson Oct 28, 2024
4383d52
small fix
ganeshvanahalli Oct 29, 2024
9c9e1b9
Merge pull request #2757 from OffchainLabs/fix_race_lru
Tristan-Wilson Oct 29, 2024
bbab516
Add a boolean field to tx receipt object indicating if the tx was tim…
ganeshvanahalli Oct 29, 2024
1cb9731
Update execution/gethexec/express_lane_service.go
Tristan-Wilson Oct 29, 2024
fe0f243
Merge branch 'express-lane-timeboost' into express-lane-fix-sequence-…
Tristan-Wilson Oct 29, 2024
1d7a645
Merge pull request #2756 from TucksonDev/express-lane-fix-sequence-nu…
Tristan-Wilson Oct 29, 2024
0ae3c89
Merge remote-tracking branch 'origin/express-lane-timeboost' into exp…
Tristan-Wilson Oct 29, 2024
d299eea
Remove timeboost sequencer url config opt
Tristan-Wilson Oct 29, 2024
4567b0a
Fix typo causing panic
amsanghi Oct 30, 2024
d20c821
Merge pull request #2763 from OffchainLabs/fix_panic
Tristan-Wilson Oct 30, 2024
1ad12ca
Fix timeboost auction resolution queue handling
Tristan-Wilson Oct 30, 2024
181932e
Merge remote-tracking branch 'origin/master' into express-lane-timeboost
Tristan-Wilson Nov 1, 2024
2c1e0e5
Bulk sync missing blockMetadata
ganeshvanahalli Nov 1, 2024
aaf051f
Post merge fixes, mostly stricter linter from 1.23
Tristan-Wilson Nov 4, 2024
f653c95
Allow wider range of RoundTimingInfo + validation
Tristan-Wilson Nov 4, 2024
47ff5ee
Fix auction closed test
Tristan-Wilson Nov 5, 2024
f8e8aa9
Fix max bids OBOE
Tristan-Wilson Nov 5, 2024
71c8c84
Bind AuthPort to random number to avoid collision
Tristan-Wilson Nov 5, 2024
06dc0ab
Fix OBOE in validator in a better way, fix test
Tristan-Wilson Nov 5, 2024
c4f4316
delete affected missing blockMetadata trackers from ArbDB in case of …
ganeshvanahalli Nov 6, 2024
4722102
add plumbing to allow starting BlockMetadataRebuilder
ganeshvanahalli Nov 6, 2024
df96876
test bulk syncing of missing blockMetadata
ganeshvanahalli Nov 6, 2024
87af748
address PR comments
ganeshvanahalli Nov 7, 2024
c0acac1
rename reorgEventsReader to reorgEventsNotifier
ganeshvanahalli Nov 7, 2024
8b7182d
Merge remote-tracking branch 'origin/master' into express-lane-timeboost
Tristan-Wilson Nov 7, 2024
31c950f
Merge branch 'express-lane-timeboost' into express-lane-timeboost-inp…
Tristan-Wilson Nov 7, 2024
d8137ec
minor bug fixes and improvements
ganeshvanahalli Nov 8, 2024
7219c33
Set dep of arbitrator/langs/bf to match master
Tristan-Wilson Nov 8, 2024
75acee8
Merge branch 'express-lane-timeboost' into express-lane-timeboost-inp…
Tristan-Wilson Nov 8, 2024
fa93c2c
Forgot to commit RoundTimingInfo validation
Tristan-Wilson Nov 8, 2024
7f9e5b6
Reorder express lane tx validation
Tristan-Wilson Nov 8, 2024
feaf306
address PR comments
ganeshvanahalli Nov 12, 2024
dfe0c51
address PR comments
ganeshvanahalli Nov 12, 2024
b031d13
Merge branch 'bulk-blockmetadata-api' into bulksyncing-missing-blockm…
ganeshvanahalli Nov 12, 2024
41d7436
merge express-lane-timeboost and resolve conflicts
ganeshvanahalli Nov 12, 2024
b7d1b06
Rename delay param to isExpressLaneController
Tristan-Wilson Nov 12, 2024
436f831
Use ptr to sequencer instead of member fn for ES
Tristan-Wilson Nov 12, 2024
b991d76
Change log level for future EL sequence number
Tristan-Wilson Nov 12, 2024
bab0157
address PR comments
ganeshvanahalli Nov 13, 2024
a5f248d
make flag description clearer
ganeshvanahalli Nov 13, 2024
f5ca4bf
Use interface instead of ptr to seq for tests
Tristan-Wilson Nov 13, 2024
a8a6369
Add early timeboost submission grace period
Tristan-Wilson Nov 13, 2024
3c491aa
update geth pin
ganeshvanahalli Nov 14, 2024
23869a2
Fix reversed boolean condition
Tristan-Wilson Nov 15, 2024
71f9c5a
address PR comments
ganeshvanahalli Nov 18, 2024
b865417
address PR comments and track last delete failure from sqlDB to preve…
ganeshvanahalli Nov 20, 2024
7dfe40d
Merge remote-tracking branch 'origin/express-lane-timeboost' into exp…
Tristan-Wilson Nov 20, 2024
b13c89a
Merge pull request #2762 from OffchainLabs/express-lane-timeboost-rem…
Tristan-Wilson Nov 20, 2024
a812410
Merge branch 'express-lane-timeboost' into express-lane-timeboost-fix…
Tristan-Wilson Nov 20, 2024
6933b94
Merge pull request #2764 from OffchainLabs/express-lane-timeboost-fix…
Tristan-Wilson Nov 20, 2024
287f74a
Merge pull request #2775 from OffchainLabs/express-lane-timeboost-inp…
Tristan-Wilson Nov 20, 2024
066ff17
Merge remote-tracking branch 'origin/express-lane-timeboost' into exp…
Tristan-Wilson Nov 20, 2024
dc65eef
Merge remote-tracking branch 'origin/expres-lane-timeboost-fix-pr-com…
Tristan-Wilson Nov 20, 2024
969dc1d
Refactor stubPublisher
Tristan-Wilson Nov 20, 2024
5a02894
Change transactionPublisher interface
Tristan-Wilson Nov 20, 2024
5e450cd
Merge remote-tracking branch 'origin/expres-lane-timeboost-fix-pr-com…
Tristan-Wilson Nov 20, 2024
2bea5ca
Loop for round check
Tristan-Wilson Nov 20, 2024
cc75bf2
Remove uncessary locking
Tristan-Wilson Nov 21, 2024
9bf924f
Merge remote-tracking branch 'origin/master' into express-lane-timeboost
Tristan-Wilson Nov 21, 2024
7356aaf
Automatic import cleanup
Tristan-Wilson Nov 21, 2024
3b67813
Merge branch 'express-lane-timeboost' into expres-lane-timeboost-fix-…
Tristan-Wilson Nov 21, 2024
cee611d
Merge pull request #2787 from OffchainLabs/expres-lane-timeboost-fix-…
Tristan-Wilson Nov 21, 2024
bc93214
address PR comments
ganeshvanahalli Nov 21, 2024
06b94b0
merge upstream and resolve conflicts
ganeshvanahalli Nov 21, 2024
0178eb7
clear blockMetadata if there's a mismatch between feed's blockhash an…
ganeshvanahalli Nov 21, 2024
fbbc94e
Merge branch 'express-lane-timeboost' into express-lane-timeboost-ear…
Tristan-Wilson Nov 21, 2024
bcabeaa
Fix race condition around checking current round
Tristan-Wilson Nov 21, 2024
4c295c5
Use EIP712 signing scheme for bids
Tristan-Wilson Nov 26, 2024
dab4225
Fix bug where bid counts weren't reset
Tristan-Wilson Dec 9, 2024
06ea35b
Merge branch 'express-lane-timeboost' into express-lane-timeboost-ear…
Tristan-Wilson Dec 9, 2024
5f52169
Merge branch 'express-lane-timeboost-early-submission-grace' into exp…
Tristan-Wilson Dec 9, 2024
0d607f7
Fix duplicated case, better name for ticker
Tristan-Wilson Dec 11, 2024
bb1dc9f
Fix timeboost round control transfer
Tristan-Wilson Dec 11, 2024
8175908
Merge branch 'express-lane-timeboost' into express-lane-timeboost-ear…
Tristan-Wilson Dec 11, 2024
45ca632
Merge branch 'express-lane-timeboost-early-submission-grace' into exp…
Tristan-Wilson Dec 11, 2024
4863402
auctioneer should close the ackNotifier after setting the result
ganeshvanahalli Dec 11, 2024
c2b85d2
Move currentTime into loop
Tristan-Wilson Dec 11, 2024
6b8fd67
Merge branch 'express-lane-timeboost' into express-lane-timeboost-ear…
Tristan-Wilson Dec 11, 2024
e1344f7
Merge pull request #2788 from OffchainLabs/express-lane-timeboost-ear…
Tristan-Wilson Dec 11, 2024
45773a3
Merge branch 'express-lane-timeboost' into express-lane-timeboost-eip…
Tristan-Wilson Dec 11, 2024
cb71840
Merge pull request #2808 from OffchainLabs/express-lane-timeboost-eip…
Tristan-Wilson Dec 11, 2024
5e408da
Fix round control transfer to same check
Tristan-Wilson Dec 12, 2024
e64520f
Timeboost-test: Express lane control transfer
ganeshvanahalli Dec 13, 2024
a90a817
Include bidder addr in bid validator errors
Tristan-Wilson Dec 16, 2024
dea14a5
make timeboost testing structure more modular
ganeshvanahalli Dec 16, 2024
0d8c195
wait for controller change on sequencer side
ganeshvanahalli Dec 16, 2024
7780636
Merge branch 'express-lane-timeboost' into test-expresslanecontrol-tr…
ganeshvanahalli Dec 16, 2024
e857141
merge upstream and resolve conflicts
ganeshvanahalli Dec 16, 2024
0d23279
merge upstream
ganeshvanahalli Dec 16, 2024
e1798b4
use ticker to allow for timely posting of bids to s3
ganeshvanahalli Dec 16, 2024
89c0f53
Include seq number in EL submission error
Tristan-Wilson Dec 17, 2024
1799f2c
update batch name to firstRound-lastRound to improve ux and allow for…
ganeshvanahalli Dec 17, 2024
929a5e9
fix typo
ganeshvanahalli Dec 17, 2024
5cd6169
Merge branch 'express-lane-timeboost' into persist-auctioneerbids-s3
ganeshvanahalli Dec 17, 2024
c9a42e2
Refactor RoundTimingInfo, fix auctionCloseTicker
Tristan-Wilson Dec 18, 2024
3f3aba0
Merge branch 'express-lane-timeboost' into express-lane-timeboost-ref…
Tristan-Wilson Dec 18, 2024
bbc703a
Merge pull request #2841 from OffchainLabs/express-lane-timeboost-ref…
Tristan-Wilson Dec 18, 2024
a998a41
merge upstream
ganeshvanahalli Dec 18, 2024
2e80697
Merge pull request #2833 from OffchainLabs/test-expresslanecontrol-tr…
ganeshvanahalli Dec 18, 2024
63ba4d4
Update timeboost/roundtiminginfo.go
Tristan-Wilson Dec 20, 2024
a719c5c
Fix processing of transactions in expressLaneService
ganeshvanahalli Dec 20, 2024
9967120
fix lint errors
ganeshvanahalli Dec 23, 2024
72fb72a
fix race in expresslaneservice_test file
ganeshvanahalli Dec 23, 2024
a449e92
add a system test to test transaction handling
ganeshvanahalli Dec 23, 2024
1837035
fix race in TestBidValidatorAuctioneerRedisStream
ganeshvanahalli Dec 23, 2024
1f73102
fix CI lint and race errors
ganeshvanahalli Dec 26, 2024
8016d82
merge master
ganeshvanahalli Dec 26, 2024
8eeb797
Merge branch 'express-lane-timeboost' into persist-auctioneerbids-s3
ganeshvanahalli Dec 26, 2024
7e47ce2
address PR comments
ganeshvanahalli Dec 26, 2024
e9fc4a7
merge upstream and resolve conflicts
ganeshvanahalli Dec 26, 2024
d87c63c
fix lint error
ganeshvanahalli Dec 26, 2024
910a375
address PR comments
ganeshvanahalli Dec 26, 2024
6843fce
merge upstream and resolve conflicts
ganeshvanahalli Dec 26, 2024
68388dd
check that timed out express-lane tx returns an error
ganeshvanahalli Dec 26, 2024
0199caf
fix CI error
ganeshvanahalli Dec 26, 2024
8cacbb2
Merge remote-tracking branch 'origin/master' into express-lane-timeboost
Tristan-Wilson Dec 27, 2024
54be46a
Merge branch 'express-lane-timeboost' into add-timeboosted-broadcastf…
Tristan-Wilson Dec 27, 2024
77df3c7
fix stubPublisher in express_lane_service_test.go
ganeshvanahalli Dec 27, 2024
e4da075
Merge pull request #2745 from OffchainLabs/persist-auctioneerbids-s3
Tristan-Wilson Dec 27, 2024
6b99351
Merge pull request #2695 from OffchainLabs/add-timeboosted-broadcastf…
Tristan-Wilson Dec 27, 2024
a319bb5
Merge pull request #2735 from OffchainLabs/publish-blockmetadata-seqc…
Tristan-Wilson Dec 27, 2024
9955576
merge upstream
ganeshvanahalli Dec 27, 2024
704c61a
merge upstream
ganeshvanahalli Dec 27, 2024
a77252f
fix lint errors
ganeshvanahalli Dec 27, 2024
1155dea
merge upstream
ganeshvanahalli Dec 27, 2024
558e0fb
merge upstream
ganeshvanahalli Dec 27, 2024
411b1cd
fix lint errors
ganeshvanahalli Dec 27, 2024
067b687
fix minor issues with config
ganeshvanahalli Dec 27, 2024
8d759a9
add required default flag to --dev and nitro testnode
ganeshvanahalli Dec 27, 2024
f140a1d
enable checking for BlockHashMismatchLogMsg in the test logs
ganeshvanahalli Dec 27, 2024
e775ef2
test that express lane control switch happens seamlessly in extreme c…
ganeshvanahalli Dec 28, 2024
e18f1a2
Merge branch 'express-lane-timeboost' into fix-expresslaneservice-txp…
ganeshvanahalli Dec 28, 2024
f17852c
address PR comments
ganeshvanahalli Dec 30, 2024
925bb74
Merge pull request #2754 from OffchainLabs/bulk-blockmetadata-api
Tristan-Wilson Dec 30, 2024
d79ffde
Merge pull request #2760 from OffchainLabs/include-timeboosted-receip…
Tristan-Wilson Dec 30, 2024
1d7f045
merge upstream
ganeshvanahalli Dec 30, 2024
f1f1198
resolve conflicts
ganeshvanahalli Dec 30, 2024
a9bbd0b
Merge pull request #2765 from OffchainLabs/bulksyncing-missing-blockm…
ganeshvanahalli Dec 30, 2024
3b96d19
merge upstream
ganeshvanahalli Dec 30, 2024
2ac7fea
Merge pull request #2850 from OffchainLabs/fix-expresslaneservice-txp…
ganeshvanahalli Dec 30, 2024
090abb7
update geth pin
ganeshvanahalli Dec 30, 2024
9cb8dbb
update seq_filter_test
ganeshvanahalli Dec 30, 2024
d624150
fix blockhash mismatch issue in tests
ganeshvanahalli Dec 30, 2024
717364f
Improve timeboost implementation
ganeshvanahalli Dec 31, 2024
cf6b606
remove unused field
ganeshvanahalli Dec 31, 2024
6d8f406
solve race in expressLaneService
ganeshvanahalli Jan 3, 2025
d48436d
fix filterLogs params for auction contract. Avoid fetching same log t…
ganeshvanahalli Jan 6, 2025
b1aefc7
merge upstream
ganeshvanahalli Jan 6, 2025
44a393e
reduce some more race
ganeshvanahalli Jan 7, 2025
0c325f7
set zero blockMetadata when sequencing delayedMsgs and prevent markin…
ganeshvanahalli Jan 8, 2025
10414fe
Merge branch 'express-lane-timeboost' into improve-timeboost-code
ganeshvanahalli Jan 8, 2025
7df81a4
address PR comments and add max-queued-tx-count config option to limi…
ganeshvanahalli Jan 8, 2025
c9b61ce
Merge branch 'master' into express-lane-timeboost
ganeshvanahalli Jan 8, 2025
3a1f91c
Merge branch 'express-lane-timeboost' into improve-timeboost-code
ganeshvanahalli Jan 8, 2025
be11793
Merge pull request #2860 from OffchainLabs/improve-timeboost-code
Tristan-Wilson Jan 9, 2025
9920c6a
directly use result chan in sequencing of timeboosted txs, handle con…
ganeshvanahalli Jan 9, 2025
3b3ebeb
improve handling of contexts in PublishTransaction and PublishTimeboo…
ganeshvanahalli Jan 10, 2025
a1fc664
merge master and update geth pin
ganeshvanahalli Jan 10, 2025
4bddb79
Merge branch 'master' into express-lane-timeboost
ganeshvanahalli Jan 10, 2025
c0521f0
Allow forwarding of express lane txs to the chosen sequencer
ganeshvanahalli Jan 13, 2025
95102ae
merge master and resolve conflicts
ganeshvanahalli Jan 13, 2025
85f63af
fix forwarding of expressLane txs when paused
ganeshvanahalli Jan 13, 2025
fd83c05
merge master resolve conflicts
ganeshvanahalli Jan 15, 2025
5f302ed
prevent non-chosen sequencer from processing an expressLaneTx itself …
ganeshvanahalli Jan 15, 2025
b214ea6
address PR comments
ganeshvanahalli Jan 15, 2025
55044a8
Auction resolution latency metric
Tristan-Wilson Jan 16, 2025
61cca76
merge master and resolve conflicts
ganeshvanahalli Jan 16, 2025
bdd467e
Merge branch 'master' into express-lane-timeboost
ganeshvanahalli Jan 16, 2025
5936d34
prioritize reading from timeboostAuctionResolutionTxQueue
ganeshvanahalli Jan 16, 2025
b8dcdd6
Merge branch 'master' into express-lane-timeboost
ganeshvanahalli Jan 17, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -298,6 +298,8 @@ FROM nitro-node-slim AS nitro-node
USER root
COPY --from=prover-export /bin/jit /usr/local/bin/
COPY --from=node-builder /workspace/target/bin/daserver /usr/local/bin/
COPY --from=node-builder /workspace/target/bin/autonomous-auctioneer /usr/local/bin/
COPY --from=node-builder /workspace/target/bin/bidder-client /usr/local/bin/
COPY --from=node-builder /workspace/target/bin/datool /usr/local/bin/
COPY --from=nitro-legacy /home/user/target/machines /home/user/nitro-legacy/machines
RUN rm -rf /workspace/target/legacy-machines/latest
Expand Down
8 changes: 7 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ all: build build-replay-env test-gen-proofs
@touch .make/all

.PHONY: build
build: $(patsubst %,$(output_root)/bin/%, nitro deploy relay daserver datool mockexternalsigner seq-coordinator-invalidate nitro-val seq-coordinator-manager dbconv)
build: $(patsubst %,$(output_root)/bin/%, nitro deploy relay daserver autonomous-auctioneer bidder-client datool mockexternalsigner seq-coordinator-invalidate nitro-val seq-coordinator-manager dbconv)
@printf $(done)

.PHONY: build-node-deps
Expand Down Expand Up @@ -311,6 +311,12 @@ $(output_root)/bin/relay: $(DEP_PREDICATE) build-node-deps
$(output_root)/bin/daserver: $(DEP_PREDICATE) build-node-deps
go build $(GOLANG_PARAMS) -o $@ "$(CURDIR)/cmd/daserver"

$(output_root)/bin/autonomous-auctioneer: $(DEP_PREDICATE) build-node-deps
go build $(GOLANG_PARAMS) -o $@ "$(CURDIR)/cmd/autonomous-auctioneer"

$(output_root)/bin/bidder-client: $(DEP_PREDICATE) build-node-deps
go build $(GOLANG_PARAMS) -o $@ "$(CURDIR)/cmd/bidder-client"

$(output_root)/bin/datool: $(DEP_PREDICATE) build-node-deps
go build $(GOLANG_PARAMS) -o $@ "$(CURDIR)/cmd/datool"

Expand Down
151 changes: 151 additions & 0 deletions arbnode/blockmetadata.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
package arbnode

import (
"bytes"
"context"
"encoding/binary"
"time"

"github.com/spf13/pflag"

"github.com/ethereum/go-ethereum/ethdb"
"github.com/ethereum/go-ethereum/log"
"github.com/ethereum/go-ethereum/rpc"

"github.com/offchainlabs/nitro/arbutil"
"github.com/offchainlabs/nitro/execution"
"github.com/offchainlabs/nitro/execution/gethexec"
"github.com/offchainlabs/nitro/util"
"github.com/offchainlabs/nitro/util/rpcclient"
"github.com/offchainlabs/nitro/util/stopwaiter"
)

type BlockMetadataFetcherConfig struct {
Enable bool `koanf:"enable"`
Source rpcclient.ClientConfig `koanf:"source" reload:"hot"`
SyncInterval time.Duration `koanf:"sync-interval"`
APIBlocksLimit uint64 `koanf:"api-blocks-limit"`
}

var DefaultBlockMetadataFetcherConfig = BlockMetadataFetcherConfig{
Enable: false,
Source: rpcclient.DefaultClientConfig,
SyncInterval: time.Minute * 5,
APIBlocksLimit: 100,
}

func BlockMetadataFetcherConfigAddOptions(prefix string, f *pflag.FlagSet) {
f.Bool(prefix+".enable", DefaultBlockMetadataFetcherConfig.Enable, "enable syncing blockMetadata using a bulk blockMetadata api. If the source doesn't have the missing blockMetadata, we keep retyring in every sync-interval (default=5mins) duration")
rpcclient.RPCClientAddOptions(prefix+".source", f, &DefaultBlockMetadataFetcherConfig.Source)
f.Duration(prefix+".sync-interval", DefaultBlockMetadataFetcherConfig.SyncInterval, "interval at which blockMetadata are synced regularly")
f.Uint64(prefix+".api-blocks-limit", DefaultBlockMetadataFetcherConfig.APIBlocksLimit, "maximum number of blocks allowed to be queried for blockMetadata per arb_getRawBlockMetadata query.\n"+
"This should be set lesser than or equal to the limit on the api provider side")
}

type BlockMetadataFetcher struct {
stopwaiter.StopWaiter
config BlockMetadataFetcherConfig
db ethdb.Database
client *rpcclient.RpcClient
exec execution.ExecutionClient
}

func NewBlockMetadataFetcher(ctx context.Context, c BlockMetadataFetcherConfig, db ethdb.Database, exec execution.ExecutionClient) (*BlockMetadataFetcher, error) {
client := rpcclient.NewRpcClient(func() *rpcclient.ClientConfig { return &c.Source }, nil)
if err := client.Start(ctx); err != nil {
return nil, err
}
return &BlockMetadataFetcher{
config: c,
db: db,
client: client,
exec: exec,
}, nil
}

func (b *BlockMetadataFetcher) fetch(ctx context.Context, fromBlock, toBlock uint64) ([]gethexec.NumberAndBlockMetadata, error) {
var result []gethexec.NumberAndBlockMetadata
// #nosec G115
err := b.client.CallContext(ctx, &result, "arb_getRawBlockMetadata", rpc.BlockNumber(fromBlock), rpc.BlockNumber(toBlock))
if err != nil {
return nil, err
}
return result, nil
}

func (b *BlockMetadataFetcher) persistBlockMetadata(query []uint64, result []gethexec.NumberAndBlockMetadata) error {
batch := b.db.NewBatch()
queryMap := util.ArrayToSet(query)
for _, elem := range result {
pos, err := b.exec.BlockNumberToMessageIndex(elem.BlockNumber)
if err != nil {
return err
}
if _, ok := queryMap[uint64(pos)]; ok {
if err := batch.Put(dbKey(blockMetadataInputFeedPrefix, uint64(pos)), elem.RawMetadata); err != nil {
return err
}
if err := batch.Delete(dbKey(missingBlockMetadataInputFeedPrefix, uint64(pos))); err != nil {
return err
}
// If we reached the ideal batch size, commit and reset
if batch.ValueSize() >= ethdb.IdealBatchSize {
if err := batch.Write(); err != nil {
return err
}
batch.Reset()
}
}
}
return batch.Write()
}

func (b *BlockMetadataFetcher) Update(ctx context.Context) time.Duration {
handleQuery := func(query []uint64) bool {
result, err := b.fetch(
ctx,
b.exec.MessageIndexToBlockNumber(arbutil.MessageIndex(query[0])),
b.exec.MessageIndexToBlockNumber(arbutil.MessageIndex(query[len(query)-1])),
)
if err != nil {
log.Error("Error getting result from bulk blockMetadata API", "err", err)
return false
}
if err = b.persistBlockMetadata(query, result); err != nil {
log.Error("Error committing result from bulk blockMetadata API to ArbDB", "err", err)
return false
}
return true
}
iter := b.db.NewIterator(missingBlockMetadataInputFeedPrefix, nil)
defer iter.Release()
var query []uint64
for iter.Next() {
keyBytes := bytes.TrimPrefix(iter.Key(), missingBlockMetadataInputFeedPrefix)
query = append(query, binary.BigEndian.Uint64(keyBytes))
end := len(query) - 1
if query[end]-query[0]+1 >= uint64(b.config.APIBlocksLimit) {
if query[end]-query[0]+1 > uint64(b.config.APIBlocksLimit) && len(query) >= 2 {
end -= 1
}
if success := handleQuery(query[:end+1]); !success {
return b.config.SyncInterval
}
query = query[end+1:]
}
}
if len(query) > 0 {
_ = handleQuery(query)
}
return b.config.SyncInterval
}

func (b *BlockMetadataFetcher) Start(ctx context.Context) {
b.StopWaiter.Start(ctx, b)
b.CallIteratively(b.Update)
}

func (b *BlockMetadataFetcher) StopAndWait() {
b.StopWaiter.StopAndWait()
b.client.Close()
}
2 changes: 1 addition & 1 deletion arbnode/inbox_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,7 @@ func TestTransactionStreamer(t *testing.T) {
state.balances[dest].Add(state.balances[dest], value)
}

Require(t, inbox.AddMessages(state.numMessages, false, messages))
Require(t, inbox.AddMessages(state.numMessages, false, messages, nil))

state.numMessages += arbutil.MessageIndex(len(messages))
prevBlockNumber := state.blockNumber
Expand Down
9 changes: 7 additions & 2 deletions arbnode/inbox_tracker.go
Original file line number Diff line number Diff line change
Expand Up @@ -307,7 +307,12 @@ func (t *InboxTracker) PopulateFeedBacklog(broadcastServer *broadcaster.Broadcas
blockHash = &msgResult.BlockHash
}

feedMessage, err := broadcastServer.NewBroadcastFeedMessage(*message, seqNum, blockHash)
blockMetadata, err := t.txStreamer.BlockMetadataAtCount(seqNum + 1)
if err != nil {
log.Warn("Error getting blockMetadata byte array from tx streamer", "err", err)
}

feedMessage, err := broadcastServer.NewBroadcastFeedMessage(*message, seqNum, blockHash, blockMetadata)
if err != nil {
return fmt.Errorf("error creating broadcast feed message %v: %w", seqNum, err)
}
Expand Down Expand Up @@ -845,7 +850,7 @@ func (t *InboxTracker) AddSequencerBatches(ctx context.Context, client *ethclien
}

// This also writes the batch
err = t.txStreamer.AddMessagesAndEndBatch(prevbatchmeta.MessageCount, true, messages, dbBatch)
err = t.txStreamer.AddMessagesAndEndBatch(prevbatchmeta.MessageCount, true, messages, nil, dbBatch)
if err != nil {
return err
}
Expand Down
102 changes: 65 additions & 37 deletions arbnode/node.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,23 +82,24 @@ func GenerateRollupConfig(prod bool, wasmModuleRoot common.Hash, rollupOwner com
}

type Config struct {
Sequencer bool `koanf:"sequencer"`
ParentChainReader headerreader.Config `koanf:"parent-chain-reader" reload:"hot"`
InboxReader InboxReaderConfig `koanf:"inbox-reader" reload:"hot"`
DelayedSequencer DelayedSequencerConfig `koanf:"delayed-sequencer" reload:"hot"`
BatchPoster BatchPosterConfig `koanf:"batch-poster" reload:"hot"`
MessagePruner MessagePrunerConfig `koanf:"message-pruner" reload:"hot"`
BlockValidator staker.BlockValidatorConfig `koanf:"block-validator" reload:"hot"`
Feed broadcastclient.FeedConfig `koanf:"feed" reload:"hot"`
Staker legacystaker.L1ValidatorConfig `koanf:"staker" reload:"hot"`
Bold boldstaker.BoldConfig `koanf:"bold"`
SeqCoordinator SeqCoordinatorConfig `koanf:"seq-coordinator"`
DataAvailability das.DataAvailabilityConfig `koanf:"data-availability"`
SyncMonitor SyncMonitorConfig `koanf:"sync-monitor"`
Dangerous DangerousConfig `koanf:"dangerous"`
TransactionStreamer TransactionStreamerConfig `koanf:"transaction-streamer" reload:"hot"`
Maintenance MaintenanceConfig `koanf:"maintenance" reload:"hot"`
ResourceMgmt resourcemanager.Config `koanf:"resource-mgmt" reload:"hot"`
Sequencer bool `koanf:"sequencer"`
ParentChainReader headerreader.Config `koanf:"parent-chain-reader" reload:"hot"`
InboxReader InboxReaderConfig `koanf:"inbox-reader" reload:"hot"`
DelayedSequencer DelayedSequencerConfig `koanf:"delayed-sequencer" reload:"hot"`
BatchPoster BatchPosterConfig `koanf:"batch-poster" reload:"hot"`
MessagePruner MessagePrunerConfig `koanf:"message-pruner" reload:"hot"`
BlockValidator staker.BlockValidatorConfig `koanf:"block-validator" reload:"hot"`
Feed broadcastclient.FeedConfig `koanf:"feed" reload:"hot"`
Staker legacystaker.L1ValidatorConfig `koanf:"staker" reload:"hot"`
Bold boldstaker.BoldConfig `koanf:"bold"`
SeqCoordinator SeqCoordinatorConfig `koanf:"seq-coordinator"`
DataAvailability das.DataAvailabilityConfig `koanf:"data-availability"`
SyncMonitor SyncMonitorConfig `koanf:"sync-monitor"`
Dangerous DangerousConfig `koanf:"dangerous"`
TransactionStreamer TransactionStreamerConfig `koanf:"transaction-streamer" reload:"hot"`
Maintenance MaintenanceConfig `koanf:"maintenance" reload:"hot"`
ResourceMgmt resourcemanager.Config `koanf:"resource-mgmt" reload:"hot"`
BlockMetadataFetcher BlockMetadataFetcherConfig `koanf:"block-metadata-fetcher" reload:"hot"`
// SnapSyncConfig is only used for testing purposes, these should not be configured in production.
SnapSyncTest SnapSyncConfig
}
Expand Down Expand Up @@ -135,6 +136,12 @@ func (c *Config) Validate() error {
if err := c.Staker.Validate(); err != nil {
return err
}
if c.Sequencer && c.TransactionStreamer.TrackBlockMetadataFrom == 0 {
return errors.New("when sequencer is enabled track-block-metadata-from should be set as well")
}
if c.TransactionStreamer.TrackBlockMetadataFrom != 0 && !c.BlockMetadataFetcher.Enable {
log.Warn("track-block-metadata-from is set but blockMetadata fetcher is not enabled")
}
return nil
}

Expand Down Expand Up @@ -165,27 +172,29 @@ func ConfigAddOptions(prefix string, f *flag.FlagSet, feedInputEnable bool, feed
DangerousConfigAddOptions(prefix+".dangerous", f)
TransactionStreamerConfigAddOptions(prefix+".transaction-streamer", f)
MaintenanceConfigAddOptions(prefix+".maintenance", f)
BlockMetadataFetcherConfigAddOptions(prefix+".block-metadata-fetcher", f)
}

var ConfigDefault = Config{
Sequencer: false,
ParentChainReader: headerreader.DefaultConfig,
InboxReader: DefaultInboxReaderConfig,
DelayedSequencer: DefaultDelayedSequencerConfig,
BatchPoster: DefaultBatchPosterConfig,
MessagePruner: DefaultMessagePrunerConfig,
BlockValidator: staker.DefaultBlockValidatorConfig,
Feed: broadcastclient.FeedConfigDefault,
Staker: legacystaker.DefaultL1ValidatorConfig,
Bold: boldstaker.DefaultBoldConfig,
SeqCoordinator: DefaultSeqCoordinatorConfig,
DataAvailability: das.DefaultDataAvailabilityConfig,
SyncMonitor: DefaultSyncMonitorConfig,
Dangerous: DefaultDangerousConfig,
TransactionStreamer: DefaultTransactionStreamerConfig,
ResourceMgmt: resourcemanager.DefaultConfig,
Maintenance: DefaultMaintenanceConfig,
SnapSyncTest: DefaultSnapSyncConfig,
Sequencer: false,
ParentChainReader: headerreader.DefaultConfig,
InboxReader: DefaultInboxReaderConfig,
DelayedSequencer: DefaultDelayedSequencerConfig,
BatchPoster: DefaultBatchPosterConfig,
MessagePruner: DefaultMessagePrunerConfig,
BlockValidator: staker.DefaultBlockValidatorConfig,
Feed: broadcastclient.FeedConfigDefault,
Staker: legacystaker.DefaultL1ValidatorConfig,
Bold: boldstaker.DefaultBoldConfig,
SeqCoordinator: DefaultSeqCoordinatorConfig,
DataAvailability: das.DefaultDataAvailabilityConfig,
SyncMonitor: DefaultSyncMonitorConfig,
Dangerous: DefaultDangerousConfig,
TransactionStreamer: DefaultTransactionStreamerConfig,
ResourceMgmt: resourcemanager.DefaultConfig,
Maintenance: DefaultMaintenanceConfig,
BlockMetadataFetcher: DefaultBlockMetadataFetcherConfig,
SnapSyncTest: DefaultSnapSyncConfig,
}

func ConfigDefaultL1Test() *Config {
Expand All @@ -195,6 +204,7 @@ func ConfigDefaultL1Test() *Config {
config.SeqCoordinator = TestSeqCoordinatorConfig
config.Sequencer = true
config.Dangerous.NoSequencerCoordinator = true
config.TransactionStreamer.TrackBlockMetadataFrom = 1

return config
}
Expand Down Expand Up @@ -282,6 +292,7 @@ type Node struct {
MaintenanceRunner *MaintenanceRunner
DASLifecycleManager *das.LifecycleManager
SyncMonitor *SyncMonitor
blockMetadataFetcher *BlockMetadataFetcher
configFetcher ConfigFetcher
ctx context.Context
}
Expand Down Expand Up @@ -515,6 +526,14 @@ func createNodeImpl(
}
}

var blockMetadataFetcher *BlockMetadataFetcher
if config.BlockMetadataFetcher.Enable {
blockMetadataFetcher, err = NewBlockMetadataFetcher(ctx, config.BlockMetadataFetcher, arbDb, exec)
if err != nil {
return nil, err
}
}

if !config.ParentChainReader.Enable {
return &Node{
ArbDB: arbDb,
Expand All @@ -538,6 +557,7 @@ func createNodeImpl(
MaintenanceRunner: maintenanceRunner,
DASLifecycleManager: nil,
SyncMonitor: syncMonitor,
blockMetadataFetcher: blockMetadataFetcher,
configFetcher: configFetcher,
ctx: ctx,
}, nil
Expand Down Expand Up @@ -793,6 +813,7 @@ func createNodeImpl(
MaintenanceRunner: maintenanceRunner,
DASLifecycleManager: dasLifecycleManager,
SyncMonitor: syncMonitor,
blockMetadataFetcher: blockMetadataFetcher,
configFetcher: configFetcher,
ctx: ctx,
}, nil
Expand Down Expand Up @@ -1023,6 +1044,9 @@ func (n *Node) Start(ctx context.Context) error {
n.BroadcastClients.Start(ctx)
}()
}
if n.blockMetadataFetcher != nil {
n.blockMetadataFetcher.Start(ctx)
}
if n.configFetcher != nil {
n.configFetcher.Start(ctx)
}
Expand Down Expand Up @@ -1121,8 +1145,8 @@ func (n *Node) GetFinalizedMsgCount(ctx context.Context) (arbutil.MessageIndex,
return n.InboxReader.GetFinalizedMsgCount(ctx)
}

func (n *Node) WriteMessageFromSequencer(pos arbutil.MessageIndex, msgWithMeta arbostypes.MessageWithMetadata, msgResult execution.MessageResult) error {
return n.TxStreamer.WriteMessageFromSequencer(pos, msgWithMeta, msgResult)
func (n *Node) WriteMessageFromSequencer(pos arbutil.MessageIndex, msgWithMeta arbostypes.MessageWithMetadata, msgResult execution.MessageResult, blockMetadata common.BlockMetadata) error {
return n.TxStreamer.WriteMessageFromSequencer(pos, msgWithMeta, msgResult, blockMetadata)
}

func (n *Node) ExpectChosenSequencer() error {
Expand All @@ -1135,3 +1159,7 @@ func (n *Node) ValidatedMessageCount() (arbutil.MessageIndex, error) {
}
return n.BlockValidator.GetValidated(), nil
}

func (n *Node) BlockMetadataAtCount(count arbutil.MessageIndex) (common.BlockMetadata, error) {
return n.TxStreamer.BlockMetadataAtCount(count)
}
Loading
Loading