Skip to content

Commit

Permalink
Patch lagrange coeff merge main (#1655)
Browse files Browse the repository at this point in the history
* serialize

* Use the correct validated state on restart

* Allow undecided state storage to be selectively turned out

* PublicHotshotConfig

* update hotshot

* prepend target directory to PATH

* expose state public key

* Improve reference object tests

* Add round-trip serialization check
* Print out a valid serialization if the test fails, so that we can
  more easily update the test vectors when we change data structures
* Generate test vectors from Rust objects
* Add tests for ChainConfig, FeeInfo

* toml file to public env vars for /env

* rm env vars

* rm private bind endpoints env vars

* rm storage-sql module requirement

* Add serialization compatibility test for Hotshot messages

* enable config module for sequencer0

* remove l1 provider and account index variables

* Move all typos excludes to .typos.toml

* More helpful failures from serialization tests

* add libp2p key derivation to binary (#1490)

* Add bincode serialization compatibility checks

* Check in missing files

* update builder (#1494)

* Avoid always using binaries in target/release (#1498)

* Avoid always using binaries in target/release

* fix comment

* reject txn with namespace > u32::max

* --- (#1487)

updated-dependencies:
- dependency-name: cachix/cachix-action
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* typos: excludes excluded files in precommit hook

* Serialize U256 numbers as decimal strings in JSON

Adds two functions to be used with `(de)serialize_with`. This avoids
having to define a macro, the downside is that it makes it possible to
specify `serialize_with` without `deserialize_with`.

- Changes the serialization of ChainID and FeeAmount.
- Updates reference types. Apparently `chain_config.json` was not sorted
  before.
- Add test to check if a roundtrip works.
- Add test well as a test to check that bincode serialization is not
  affected by the customization.

Close #1496
Close #1497

* add ResolvableChainConfig to ValidatedState

* get_chain_config

* Define a genesis config file

This aims to separate onchain data, which must be the same for all
nodes (chain ID, base fee, etc) from node-specific configuration.
Node configuration continues to be done via environment variables,
whereas onchain data is defined in a configuration file which we
can distribute to all node operators when launching a network. This
should greatly simplify coordination and reduce the frequency of
errors due to misconfigured nodes.

* Use serde for loading genesis from TOML file

A new `FromStringOrInteger` helper in `sequencer_utils` allows us
to hook the custom parsing logic for `FeeAmount`, `ChainId`, and
`BlockSize` into deserialization, so that all the types that include
these (`ChainConfig`, `Genesis`), we can use vanilla deserialization
without custom TOML parsing code.

The changes to the reference JSON data are acceptable because
* They only affect JSON, bincode references are byte-for-byte
  unchange
* We retain full backwards compatibility. See ad hoc tests for this
  in chain_config.rs and state.rs

* Allow genesis file to specify L1 genesis by number or full block

* Allow genesis file to specify genesis timestamp

* Add file extension to docker genesis path

* Use ethers parse_units to parse FeeAmount

* Fix argument parsing in integration test

* Fix reference header

* Include genesis files in sequencer docker

The idea is to include a genesis file for all officially supported
networks (demo, staging, cappuccino, and eventually mainnet) so that
operators can easily connect to the appropriate network just by setting
the `ESPRESSO_SEQUENCER_GENESIS_FILE` environment variable to point at
the appropriate bundled genesis file.

Of course, operators can also connect to an unsupported chain (e.g.
private testnet) by including their own genesis file via a volume.

* Add genesis files to builder Docker build (#1509)

* add genesis files to builder docker build

* fix env var

* Fix WebSocket timeout handling in nasty-client

The server might close an idle connection after 60s. This should not
be considered an error. Currently, though, it is causing errors, because
our caluclation of idle time is not correct. We are using time since last
read, but a read doesn't necessarily mean traffic over the connection. We
might be reading a message that was sent long ago and has been sitting in
our TCP buffer while the connection has been idle.

To more accurately gauge how long the connection has been idle, we use time
since the last _blocking_ read. Thus, we are less likely to produce an error,
and more likely to just chalk ConnectionReset errors up to a stale stream and
refresh the stream and continue.

* chain config route

* 30mb max block size (#1511)

* Remove env vars that are ignored after the genesis change

* Sort env vars alphabetically in env endpoint

* add test

* clippy

* add recipe for clippy to justfile

* Use `just clippy` in flake.nix

* Remove dead code (#1516)

This code is no longer used after #1443 (genesis file)

* Update architecture diagram (#1445)

* Update architecture diagram
* add CDN annotations
* Add Fee Contract
* Add validated state
* Re-organize sequencer node and network
* Move DB into sequencer node
* Add Hotshot Events in Hotshot package
* Add sequence diagram, update README
* Add sequence diagram step to architecture diagram
* Address comments, add brief glossary
* Add optimistic rollup dispute to diagram
* Add optimistic rollup to architecture diagram

---------

Co-authored-by: Rob <[email protected]>
Co-authored-by: Jeb Bearer <[email protected]>
Co-authored-by: Philippe Camacho <[email protected]>

* Fix docker demo (#1519)

* Fix docker demo

- Set stake table capacity to 10 for mock contract.
- Log the stake table capacity on prover service startup.
- Set a lower prover interval for local demos.
- Query all logs in smoke test. By default it only queries the latest
  block.
- Add stake table capacity to public env vars

* Generate rust docs and publish (#1518)

* Generate rust docs and publish

- Fix compilation by adding RUSTDOCFLAGS
- Add CI job to publish docs (modified from hotshot)
- Add a just recipe
- Update README

Close #1517

* Change doc CI job name

* Fix cross compilation dev shell

Put rust env vars into a nix attrset to avoid repeating them many times

* Set RUSTFLAGS in doc CI job

* longer delay time for fee bridge

* broken

* remove apersand

* one build failure left

* remove unused imports

* arcing things

* fix build

* Specifiy fetch requests rate limit for SQL (#1524)

* update hotshot query service to 0.1.26

* set env var to 25

* Add backoff to state catchup retry loops

* Backoff with jitter

* CI: fix docker demo (#1526)

* CI: fix docker demo

- Rename bridge to espresso-bridge to avoid conflicts with other
  executable called bridge which often already exist on disk.
- Improve output of smoke-test script to make it easier to debug
  failures in the future.

* Allow access to host from within bridge container

* Undo unwanted change

* Fix local docker image build scripts

* Fix copying of genesis data

* Add dev-node binary (#1353)

Add  `espresso-dev-node` binary and friends. Currently docker image includes dev node, postgres and anvil. `builder_port` will be added in follow up (#1522).




---------

Co-authored-by: sveitser <[email protected]>
Co-authored-by: Abdul Basit <[email protected]>
Co-authored-by: Abdul Basit <[email protected]>
Co-authored-by: tbro <[email protected]>

* fix cargo

* fix build and versions

* point hotshot to main and others to daily-build

* pass simple builder config

* merge abdul/move-chain-config, hotshot ss/fee-upgrade others abdul/update-hotshot

* make clippy happy

* update lockfile to point to specific hotshot commit

* update builder-core

* arc SystemContextHandle

* version

* bump versions

* add upgrades to Genesis and Nodestate

* use fee_contract address from updated chain_config

* rename upgrade block field to view

* update version

* update hotshot-query-service to 0.1.29

* tests building now

* change clone

* update query-service to 0.1.30

* Add env vars for new rate limiting parameters

* add methods to SequencerContext for consensus

* Chain config persistence

* fix: use espresso-bridge instead of bridge for fund-builder

* merge main, rebuild, update

* Remove unnecessary write lock for submit endpoint

The submit endpoint took a write lock on the state by default, since
it is a POST endpoint. However, this lock is unnecessary, because
internally all we do is send an event, we don't mutate any state.
By using `at` instead of `post`, we can manually control the locking,
and take just a read lock. This should help significantly in avoiding
queues on the API state lock when many transactions are being submitted.

* Add `Option<builder_port>` param to dev-node

This PR add `Option<builder_port>` param in order to supply known port to
`SimpleBuilder`. In addition in changes some variable names in
`espresso-dev-node` to avoid confusion.

Closes #1522

* lint

* [Libp2p upgrade] Load bootstrap info from genesis file (#1505)

* libp2p bootstrap info from file

* wait for one connection to be initialized

* move to new genesis toml

* try_from

* fix: use instance chain config for genesis validated_state

* test for chain config catchup

* remove version from NodeState

* move proposal.chain_config and state chainconfig check below upgrade

* move current version back to NodeState

* get upgrade for current_version

* update lockfile

* add test for chain config upgrade

* pass None for builder port

* merge main

* Implement server side connection limit

This change implements a configurable limit on the number of simultaneous
HTTP connections allowed by a query server. This should allow us to
efficiently filter out requests during periods of high load so that
the burden is pushed back onto clients, and the server continues
operating within normal limits. This in turn will allow us to turn off
or scale back the AWS rate limiter.

* Fix dev-node options

* test: reference_tests use nontrivial payload, ns_table (#1557)

reference_tests use nontrivial payload, ns_table

* Update query service

* bump query service to 0.1.32

* update hotshot-query-service to 0.1.33

* DRAFT PR: 1470 escape hatch add sliding windows to light client contract (#1493)

* added isHotshotLive function

* added more tests

* remove delayThreshold from LightClient contract, tests and rust tests

* improve comments

* added the abiity to get the commitment at a certain HotShot blockheight

* simplified wasL1Updated function

* variable name and function refactor

* variable name and function refactor

* added setHotShotCommitments function in LightClientMock

* updated hotshotheight test

* switched wasL1Updated to lagOverEscapeHatchThreshold

* updates to getHotShotCommitment function

* fix test

* return block height as well as block comm root when fetching light client snapshot

* update

* update query service to 0.1.34

* update migration version to V31 and cleanup

* apply_upgrade() and get_chain_config()

* update only if chain config is different

* return early

* Remove the commitment task in dev node (#1555)

* Remove the commitment task in dev node

* Fix the building dev-node image

* Drop created index on merklized state tables

* Add logging and metrics for slow HTTP requests

* Add queries by payload hash

* wip implementing storage

* almost done

* broken query

* Add state validation error types (#1543)

Add error types for state validation

  * return these types from validation functions
  * update related tests
  * add wrapper `StateValidation` enum (only for human comprehension)
---------

Co-authored-by: tbro <[email protected]>

* integrate new versions

* bump query service

* add migration, change name

* improve fs interface

* add sql gc

* update tests to include quorum proposal saving and loadin

* typo

* typo

* typo

* Add env var to recover archive after pruning

* rename executable

* chore: rewrite block payload (#1499)

* new struct Payload2

* WIP new fns usize_to_bytes, max_from_byte_len with tests

* implement NamespaceBuider

* WIP begin implementing from_transactions

* dead end: const generics not stable in Rust https://stackoverflow.com/a/72467535

* finish impl for from_transactions, use macro_rules to generalize usize_to_bytes

* WIP friendly deserializers

* generalized friendly deserializer

* usize_from_bytes const generic param, add xxx_from_bytes functions

* impl namespace_with_proof and some helpers

* WIP test infra for namespace proofs

* tweak test

* Payload2:namespace_with_proof pass tests (yay)

* don't double count dupliate namespace ids

* tidy

* restore block.rs from main, new file block2.rs

* move mod tx_table to separate file payload_bytes.rs

* rename block2::Payload2 -> Payload

* set Payload::ns_iter() Item to NamespaceId

* move namespace iterator to a separate file

* rename payload2 -> ns_payload_builder

* visibility tweaks for ns_iter

* new fn verify_namespace_proof, temporary re-use of old parse_ns_payload, enforce maximum ns payload index in ns_iter, rename a few things

* move namespace_with_proof and test to ns_proof.rs, use new verify_namespace_proof in test

* move Payload::ns_iter, etc to ns_iter.rs

* rename ns_payload_builder -> ns_payload

* new mod tx_iter, a proper impl for parse_ns_payload

* WIP combined iterator for QueryablePayload

* move the combined iterator to iter.rs, delete the extra namespace iterator

* stub impl of QueryablePayload for Payload

* more stubs, tidy, new file tx_proof.rs

* fix bug in TxIter, fix test

* impl Payload::transaction with test

* move tests to new file test.rs

* tidy and comments

* NsProof do not store VID common data

* tidying and stub

* new fn tx_table_range with doc

* impl transaction_with_proof, still pretty messy tho

* WIP tx proof only for num_txs

* fix bug in iter, fix test

* test: verify transaction proofs

* major rework of ns_iter: new struct NsTable, NsIter::Item is now just usize

* newtype NsIndex

* TxIndex is now a serialized index, newtype NsPayload with awesome helper methods

* fix name _max_from_byte_len2 -> _max_from_byte_len

* xxx_from_bytes allow small byte lengths

* NsIndex in serialized form like TxIndex

* move tx_iter mod into ns_payload to enable private data in TxIndex

* rename module ns_iter -> ns_table

* tweak todo comments

* move ns_payload, ns_proof, tx_proof modules inside ns_table

* tidy

* put TxIndex in a new mod tx_iter, move NsPayload::read_tx_offset into tx_iter, new method NsPayload::read_tx_offset_pref

* add tx table range proof to TxProof

* NsPayload now a DST, add newtype NsPayloadOwned so that it's to NsPayload as Vec<T> is to [T]

* untested: TxProof::verify check tx table proof

* dumbest bug ever

* TxProof::verify now check tx payload proof (yay)

* tidy: new module ns_iter like tx_iter, new method NsTable::read_ns_offset_prev like NsPayload::read_tx_offset_prev

* new struct NsPayloadRange with helpers

* WIP tweak tx_payload_range[_relative]

* make NsPayloadRange a Range<usize>

* WIP prep for experiments with NsPayload

* add range field to NsPayload, it can no longer be a DST (boo)

* revert back to DST for NsPayload

* move tx_payload_range method from NsPayload to NsPayloadRange, add args to make it work

* move modules ns_proof, tx_proof from ns_table up to block

* move module ns_payload_range to its own file

* Index fields private

* move module ns_iter to its own file

* move module tx_iter to its own file

* newtype NumTxs

* manual serde impl for NumTxs

* NsPayloadRange::tx_payload_range arg type change usize -> NumTxs

* new struct TxTableEntries

* manual serde impl for TxTableEntries

* tidy ns_table

* move module num_txs into its own file

* move module tx_table_entries to its own file

* remove pub(crate) from NsPayloadRange newtype field

* add TODOs, ugh Rust is killing me

* TxIndex newtype from array to usize

* NsIndex newtype from array to usize

* move module num_txs up to block, experiment with access key design pattern

* move module ns_iter up to block

* move module tx_table_entries up to block

* move module tx_iter up to block

* move module ns_payload up to block

* move module ns_payload_range up to block

* move some NsTable impls into ns_table module

* NsTable member private

* move some impl Payload to block module

* move NsProof construction from Payload to NsProof

* move TxProof construction from Payload to TxProof

* move struct Payload to a new module payload

* visibility restrictions to payload module

* oops

* delete num_txs_as_bytes from payload_bytes

* delete num_txs_from_bytes from payload_bytes

* delete tx_offset_as_bytes from payload_bytes

* delete tx_offset_from_bytes from payload_bytes

* delete num_nss_as_bytes from payload_bytes

* delete num_nss_from_bytes from payload_bytes

* delete ns_offset_as_bytes from payload_bytes

* delete ns_offset_from_bytes from payload_bytes

* delete ns_offset_[as|from]_bytes from payload_bytes

* tweak: Payload::ns_payload re-use ns_payload_range

* move byte len constants to block module

* rename module payload_bytes -> uint_bytes

* tidy, minor refactor new function usize_fits

* replace NsTable::num_nss_with_duplicates -> in_bounds, reflect the change in NsIter, use it in TxProof; also remove NsPayload::find_ns_id and reorder arg list in TxProof::new

* check tx index in TxProof::new, new method NsPayload::in_bounds

* WIP new model for NsPayload[Range]

* WIP read_tx_offset

* new traits AsBytes, BytesReader, new test for TxProof2

* PoC TxTableEntries in the new model

* tidy, rename

* remove const generic param from AsPayloadBytes trait

* new structs NumTxs2, TxTableEntries2 using traits AsPayloadBytes

* add tx payload range to TxProof2

* error checking in TxProof::new

* TxProof::verify: add ns_table arg, remove ns_payload_range from proof, add error checking

* derive serde for types in TxProof2

* delete old type TxProof in favor of TxProof2

* NsProofExistence use NsPayloadOwned2 instead of NsPayloadOwned

* Iter use TxIter::new2 instead of new (progress toward switching from NsPayload to NsPayload2)

* move NamespacePayloadBuilder to module newtypes

* delete module ns_payload_range

* delete old modules

* newtype NsPayloadByteLen

* newtype NumTxsChecked

* move tx_table_entries_range_relative into TxTableEntriesRange::new

* move module tx_iter into newtypes

* impl AsPayloadBytes for TxIndex

* WIP test fails: AsPayloadBytes new param T

* fix test, but AsPayloadBytes trait is now unusable (boo)

* fix TxTableEntries deserialization

* delete unneeded stuff

* rename a bunch of types in module newtypes

* make AsPayloadBytes readable and rename it to FromPayloadBytes

* tidy and rename

* rename ns_payload[_range]2.rx -> without the 2

* tidy and renaming

* newtype PayloadByteLen

* tidy and docs

* tidy ns_table

* tidy payload

* fix macro bytes_serde_impl

* delete ns_iter.rs, move contents to ns_table.rs

* restrict visibility of magic constants to a single file (yay)

* tidy ns_payload

* replace NsPayloadRange::offset with block_payload_range, simplify NsPayloadBytesRange

* tidy tx_proof, rename some things

* tidy

* new method export_tx, in prep for reduced visibility

* fix use statements

* new module full_payload

* WIP new module namespace_payload

* move tx_proof, iter to namespace_payload; add helpers to avoid excessive visibility

* new helper Payload::ns_payload

* doc for bytes_serde_impl macro

* move ns_payload_traits module into newtypes

* rename module newtypes -> types

* fix build after merge main

* WIP swap out block for block2

* WIP fix test_namespace_query for block2

* WIP fix nasty_client except for NsIndex serialization issue

* fix nasty-client for new block2, appease clippy

* fix reference test for new ns table format

* fix test demo, tidy

* accounting for block byte length limit

* temporary hack to pass tests

* set forge-std git submodule to correct commit

* fix test_message_compat

* failing test for large namespace ids

* single-character bug fix (damn that feels good)

* fix doctest

* update reference tests (again)

* add test enforce_max_block_size

* delete old block module

* tidy TODOs, some general tidying

* NsTable::read_ns_id check index in bounds

* NsTable::ns_range check index in bounds

* use read_ns_id_unchecked in NsIter

* revert NsTable::ns_range to unchecked and restrict visibility

* revert NsTable::read_ns_id to unchecked

* re-arrange methods

* NsTable::as_bytes_slice restrict visibility

* delete NsTable::as_bytes_slice in favor of Encode trait

* delete Payload::as_byte_slice in favor of Encode trait

* tidy PayloadByteLen

* restrict visibility for NsIter

* restrict visibility of PayloadByteLen

* restrict visibility of NsPayload

* restrict visibility of NsPayloadRange

* restrict visibility of NsPayloadBuilder

* restrict visibility of TxIndex, TxIter

* rename module block2 -> block

* rename ns_payload_unchecked -> ns_payload

* remove obsolete todo

* revert #1504 ; this PR supports arbitrary 8-byte namespace IDs

* detailed specification rustdoc for Payload, NsTable

* detailed specification in rustdoc for namespace payload

* rename Payload::payload -> ns_payloads

* NsProof do not prove non-existence

* Payload::is_consistent return Result instead of bool, eliminate panic

* NsProof::new take NsIndex arg instead of NamespaceId

* NamespaceProofQueryData::proof is now optional

* fix: NsProof::ns_proof for empty payload should be None

* address #1499 (comment)

* NsTable  field for backwards compatibility

* set NS_ID_BYTE_LEN to 4 for backwards compatibility

* Payload::builder_commitment hack for backwards compatibility

* TODOs for NamespaceId, fix tests in block/test.rs

* restore data/ files from main branch

* remove obsolete comment

* fix doc for NsProof::new as per #1499 (comment)

* new method NsTable::read_ns_id_unchecked as per #1499 (comment)

* NamespaceId manual Deserialize impl enforce u32::MAX

* NamespaceId impl From<u32> as per #1499 (comment)

* doc: links to github issues in code comments

* 1328 update prover permissions on the light client contract via openzeppelin defender and safe wallets (#1454)

* using the safe  SDK for transaction proposals with a safe multisig wallet

* Add yarn to flake.nix

* ts-jest installed locally and env variable name changed

* moved the safe sdk scripts into the contracts/script folder

* Add @types/jest

This allows me to run `yarn jest` without errors

* Run prettier on typescript files

* Commit yarn lockfile

Avoid errors arising from non-reproducible dev enviornments

* Add more steps to documentation, add dotenv

* Update contracts/script/multisigTransactionProposals/README.md

Co-authored-by: Mathis <[email protected]>

* Update contracts/script/multisigTransactionProposals/safeSDK/disableProverProposal.ts

Co-authored-by: Mathis <[email protected]>

---------

Co-authored-by: sveitser <[email protected]>

* hotfix: revert field rename Payload::ns_payloads -> raw_payload (#1586)

revert field rename Payload::ns_payloads -> raw_payload

* test: reference test for Payload (#1588)

* cherry-pick new reference test for Payload from gg/payload-serialization-tests

* remove Committable impl from Payload, fix reference tests

* Update query service

* bump

* update

* block_size is allowed to be equal to `max_block_size` (#1579)

Closes #1464

Co-authored-by: tbro <[email protected]>

* [Prover] Sequencer node stake table initialization (#1600)

* query node stake table initialization

* fmt

* [Libp2p] Bootstrap from env variable instead (#1601)

bootstrap from env variable

* groan

* use Base::instance()

* add propose_window, commit and revert in caller, remove header cf commit check

* lint

* lint

* fix migrations version and use propose_window

* fix: enforce_max_block_size test

* change TestConfig nodes to 5

* set propose window to 10

* use transaction()

* remove header cf commit check

* update hotshot and cdn

* Update CDN in `ab/fee-upgrade` (#1606)

* update the CDN

* update comment

* fix latency calculation

* query service update

* cargo sort

* add commit check back

* `try_cast`

* clippy

* bump

* FEATURE: Allow pulling a genesis file from AWS Secrets Manager (#1612)

* Enable libp2p (#1621)

enable libp2p

* feat: enforce namespace table validity at consensus (#1607)

* new method NsTable::validate, use it in state::validate_proposal

* serde deserialize check NsTable::validate via ugly boilerplate serde-rs/serde#1220 (comment)

* add test for invalid byte lengths

* rename and tidy doc

* Payload::from_transactions use BTreeMap instead of HashMap

* NsIter do not skip duplicate entries

* NsTable::validate enforce increasing entries, with tests

* NsTable::validate enforce correct header, with tests

* NsTable::validate disallow 0 namespace id, offset

* tweak doc

* clippy pacification game with old rust version

* more clippy pacification (someone plz update nix)

* debug CI

* debug-ci: revert BTreeMap to HashMap

* debug ci: remove serde validation, restore BTreeMap

* restore NsTable serde validation

* NsTable::validate tests also check serde round trip

* NsTable do not derive Default, fix test_append_and_collect_garbage

* restore ns_table.validate()

* NamespaceId do not derive Default, Copy, do not impl Namespace, Namespaced, serde deserialize disallow zero

* tidy use statements

* allow zero NamespaceId (changed my mind)

* fix doc NsTable::validate

* nice job, idiot

* clarify doc on serde derivation for NsTable

* clarify doc for NsTable::len

* fix: byte length check in NsTable::validate

* address #1607 (comment)

* make NamespaceId Copy again

* fix again: byte length check in NsTable::validate

* address #1607 (comment)

* Remove old database port config (#1622)

* Bump docker/build-push-action from 5 to 6 (#1615)

Bumps [docker/build-push-action](https://github.com/docker/build-push-action) from 5 to 6.
- [Release notes](https://github.com/docker/build-push-action/releases)
- [Commits](docker/build-push-action@v5...v6)

---
updated-dependencies:
- dependency-name: docker/build-push-action
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Add prover in dev node (#1583)

* Add prover in dev-node

* Check the namespace proof

* Check vid common endpoint

* Fix the getHotShotCommitment in contract

* tmp broken build

* fix one

* fix build

* fmt

* update query-service

* update query-service

* Adding configuration changes for builder-core update

* Adding configuration changes for builder-core update

* fix test and add comments explaining how we fetch the hotshot commitment

* feat: Namespace table enforce final offset equals payload length (#1642)

* rename validate -> validate_deserialization_invariants, make it private

* method NsTable::validate now take PayloadByteLen arg

* clippy pacification for PayloadByteLen::is_consistent

* new test payload_byte_len

* PayloadByteLen::is_consistent don't panic

* explainer comment

* empty namespace table implies empty block payload, with tests

* Fix possible lack of combined network message deduplication (#1643)

* fix possible lack of message deduplication

* clippy

* Make catchup backoff params configurable; adjust defaults

Makes the parameters controlling backoff for catchup requests
configurable via env var. Adjusts the defaults to retry more quickly
when there are few failures and backoff more dramatically when there
are many failures.

* Remove overly verbose log

* Adjust stake table capacity so staging can use real prover contract

* Merge main branch.

---------

Signed-off-by: dependabot[bot] <[email protected]>
Co-authored-by: Abdul Basit <[email protected]>
Co-authored-by: imabdulbasit <[email protected]>
Co-authored-by: Jeb Bearer <[email protected]>
Co-authored-by: Jeb Bearer <[email protected]>
Co-authored-by: Brendon Fish <[email protected]>
Co-authored-by: sveitser <[email protected]>
Co-authored-by: rob-maron <[email protected]>
Co-authored-by: Himanshu Goyal <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Rob <[email protected]>
Co-authored-by: nomaxg <[email protected]>
Co-authored-by: Jarred Parr <[email protected]>
Co-authored-by: Jeremy <[email protected]>
Co-authored-by: tbro <[email protected]>
Co-authored-by: Gus Gutoski <[email protected]>
Co-authored-by: Alysia Tech <[email protected]>
Co-authored-by: tbro <[email protected]>
Co-authored-by: Mat R <[email protected]>
Co-authored-by: Nathan F Yospe <[email protected]>
  • Loading branch information
20 people authored Jul 2, 2024
1 parent cc89003 commit 9e8694e
Show file tree
Hide file tree
Showing 177 changed files with 20,577 additions and 6,007 deletions.
77 changes: 47 additions & 30 deletions .env
Original file line number Diff line number Diff line change
Expand Up @@ -15,35 +15,37 @@ ASYNC_STD_THREAD_COUNT=1
PROVER_RAYON_NUM_THREADS=2

# Internal port inside container
ESPRESSO_CDN_SERVER_PORT=40000
ESPRESSO_CDN_SERVER_PORT=30000
ESPRESSO_CDN_SERVER_METRICS_PORT=9090
ESPRESSO_ORCHESTRATOR_PORT=40001
ESPRESSO_ORCHESTRATOR_PORT=30001
ESPRESSO_ORCHESTRATOR_NUM_NODES=5
ESPRESSO_ORCHESTRATOR_START_DELAY=5s
ESPRESSO_ORCHESTRATOR_NEXT_VIEW_TIMEOUT=30s
ESPRESSO_ORCHESTRATOR_NEXT_VIEW_TIMEOUT=12s
ESPRESSO_ORCHESTRATOR_BUILDER_TIMEOUT=2s
ESPRESSO_SEQUENCER_CDN_ENDPOINT=marshal-0:${ESPRESSO_CDN_SERVER_PORT}
ESPRESSO_SEQUENCER_ORCHESTRATOR_URL=http://orchestrator:${ESPRESSO_ORCHESTRATOR_PORT}
ESPRESSO_SEQUENCER_API_PORT=44000
ESPRESSO_SEQUENCER_HOTSHOT_EVENT_STREAMING_API_PORT=42000
ESPRESSO_SEQUENCER1_API_PORT=44001
ESPRESSO_SEQUENCER2_API_PORT=44002
ESPRESSO_SEQUENCER3_API_PORT=44003
ESPRESSO_SEQUENCER4_API_PORT=44004
ESPRESSO_SEQUENCER_MAX_BLOCK_SIZE=10kb
ESPRESSO_SEQUENCER_BASE_FEE=1
ESPRESSO_SEQUENCER_API_PORT=24000
ESPRESSO_SEQUENCER_HOTSHOT_EVENT_STREAMING_API_PORT=22000
ESPRESSO_SEQUENCER1_API_PORT=24001
ESPRESSO_SEQUENCER2_API_PORT=24002
ESPRESSO_SEQUENCER3_API_PORT=24003
ESPRESSO_SEQUENCER4_API_PORT=24004
ESPRESSO_SEQUENCER_URL=http://sequencer0:${ESPRESSO_SEQUENCER_API_PORT}
ESPRESSO_SEQUENCER_MAX_CONNECTIONS=25
ESPRESSO_SEQUENCER_STORAGE_PATH=/store/sequencer
ESPRESSO_SEQUENCER_GENESIS_FILE=/genesis/demo.toml
ESPRESSO_SEQUENCER_L1_PORT=8545
ESPRESSO_SEQUENCER_L1_WS_PORT=8546
ESPRESSO_SEQUENCER_L1_PROVIDER=http://demo-l1-network:${ESPRESSO_SEQUENCER_L1_PORT}
# Only allow 1 block to be processed for events at a time, simulating a very bad L1 provider.
ESPRESSO_SEQUENCER_L1_EVENTS_MAX_BLOCK_RANGE=1
ESPRESSO_SEQUENCER_ETH_MNEMONIC="test test test test test test test test test test test junk"
# The first account is the permission less builder, the last are sequencer0 to 4
ESPRESSO_SEQUENCER_PREFUNDED_BUILDER_ACCOUNTS=0x23618e81E3f5cdF7f54C3d65f7FBc0aBf5B21E8f
ESPRESSO_COMMITMENT_TASK_PORT=60000
ESPRESSO_SEQUENCER_DB_PORT=5432
ESPRESSO_STATE_RELAY_SERVER_PORT=40004
ESPRESSO_COMMITMENT_TASK_PORT=30010
ESPRESSO_SEQUENCER0_DB_PORT=5432
ESPRESSO_SEQUENCER1_DB_PORT=5433
ESPRESSO_STATE_RELAY_SERVER_PORT=30011
ESPRESSO_STATE_RELAY_SERVER_URL=http://state-relay-server:${ESPRESSO_STATE_RELAY_SERVER_PORT}
ESPRESSO_BLOCK_EXPLORER_PORT=3000

# Ethereum accounts (note 11-15 are used by the sequencer nodes)
ESPRESSO_SEQUENCER_HOTSHOT_ACCOUNT_INDEX=5
Expand All @@ -52,8 +54,8 @@ ESPRESSO_BUILDER_ETH_ACCOUNT_INDEX=8
ESPRESSO_DEPLOYER_ACCOUNT_INDEX=9

# Contracts
ESPRESSO_SEQUENCER_HOTSHOT_ADDRESS=0x700b6a60ce7eaaea56f065753d8dcb9653dbad35
ESPRESSO_SEQUENCER_LIGHT_CLIENT_PROXY_ADDRESS=0xe1aa25618fa0c7a1cfdab5d6b456af611873b629
ESPRESSO_SEQUENCER_HOTSHOT_ADDRESS=0xb19b36b1456e65e3a6d514d3f715f204bd59f431
ESPRESSO_SEQUENCER_LIGHT_CLIENT_PROXY_ADDRESS=0x0c8e79f3534b00d9a3d4a856b665bf4ebc22f2ba
ESPRESSO_SEQUENCER_LIGHTCLIENT_ADDRESS=$ESPRESSO_SEQUENCER_LIGHT_CLIENT_PROXY_ADDRESS

# Example sequencer demo private keys
Expand All @@ -76,6 +78,9 @@ ESPRESSO_DEMO_SEQUENCER_LIBP2P_PORT_2=7002
ESPRESSO_DEMO_SEQUENCER_LIBP2P_PORT_3=7003
ESPRESSO_DEMO_SEQUENCER_LIBP2P_PORT_4=7004

# The demo uses the mock stake table contract, only capacity 10 is supported.
ESPRESSO_SEQUENCER_STAKE_TABLE_CAPACITY=10

# Foundry
# The mnemonic used by foundry to deploy contracts.
MNEMONIC="test test test test test test test test test test test junk"
Expand All @@ -86,31 +91,34 @@ ETHERSCAN_API_KEY="placeholder"

# Temporary flags for state relay server, should remove after integrating with stake table
# Related issue: [https://github.com/EspressoSystems/espresso-sequencer/issues/1022]
ESPRESSO_STATE_SIGNATURE_WEIGHT_THRESHOLD=3
ESPRESSO_STATE_SIGNATURE_TOTAL_STAKE=5

# Prover service
ESPRESSO_PROVER_SERVICE_PORT=40050
ESPRESSO_STATE_PROVER_UPDATE_INTERVAL=10m
ESPRESSO_PROVER_SERVICE_PORT=30050
ESPRESSO_STATE_PROVER_UPDATE_INTERVAL=20s

# Builder service
ESPRESSO_BUILDER_L1_PROVIDER=${ESPRESSO_SEQUENCER_L1_PROVIDER}
ESPRESSO_BUILDER_ETH_MNEMONIC=${ESPRESSO_SEQUENCER_ETH_MNEMONIC}
ESPRESSO_BUILDER_SERVER_PORT=41003
ESPRESSO_BUILDER_CHANNEL_CAPACITY=1024
ESPRESSO_BUILDER_SERVER_PORT=31003
ESPRESSO_BUILDER_TX_CHANNEL_CAPACITY=4096
ESPRESSO_BUILDER_EVENT_CHANNEL_CAPACITY=128
ESPRESSO_BUILDER_INIT_NODE_COUNT=$ESPRESSO_ORCHESTRATOR_NUM_NODES
ESPRESSO_BUILDER_BOOTSTRAPPED_VIEW=0
ESPRESSO_BUILDER_WEBSERVER_RESPONSE_TIMEOUT_DURATION=1s
ESPRESSO_BUILDER_BUFFER_VIEW_NUM_COUNT=15
ESPRESSO_BUILDER_WEBSERVER_RESPONSE_TIMEOUT_DURATION=1500ms
ESPRESSO_BUILDER_BUFFER_VIEW_NUM_COUNT=50
ESPRESSO_BUILDER_GENESIS_FILE=$ESPRESSO_SEQUENCER_GENESIS_FILE

# Load generator
ESPRESSO_SUBMIT_TRANSACTIONS_DELAY=2s
ESPRESSO_SUBMIT_TRANSACTIONS_PUBLIC_PORT=44010
ESPRESSO_SUBMIT_TRANSACTIONS_PRIVATE_PORT=44020
ESPRESSO_SUBMIT_TRANSACTIONS_PUBLIC_PORT=24010
ESPRESSO_SUBMIT_TRANSACTIONS_PRIVATE_PORT=24020

# Query service stress test
ESPRESSO_NASTY_CLIENT_PORT=44011
# Query service fetch requests rate limit
ESPRESSO_SEQUENCER_FETCH_RATE_LIMIT=25

# Query service stress test
ESPRESSO_NASTY_CLIENT_PORT=44011
ESPRESSO_NASTY_CLIENT_PORT=24011

# Openzeppelin Defender Deployment Profile
DEFENDER_KEY=
Expand All @@ -120,3 +128,12 @@ LIGHT_CLIENT_SALT=12
FEE_CONTRACT_UPGRADE_NAME="FeeContract.sol"
LIGHT_CLIENT_UPGRADE_NAME="LightClientV2.sol"
FOUNDRY_OUT=contracts/out

# The Ethereum address of the safe multisig wallet used to deploy and operate the contracts.
SAFE_MULTISIG_ADDRESS=
# The Ethereum private key of the wallet used for the proposing multisig transactions.
SAFE_ORCHESTRATOR_PRIVATE_KEY=

# Light Client
LIGHT_CLIENT_CONTRACT_ADDRESS=
APPROVED_PROVER_ADDRESS=
75 changes: 62 additions & 13 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,11 @@ jobs:
run: |
cargo build --locked --release --workspace
- name: Build Espresso Dev Node
# Espresso Dev Node currently requires testing feature, so it is built separately.
run: |
cargo build --locked --release --features testing --bin espresso-dev-node
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
Expand All @@ -72,7 +77,9 @@ jobs:
target/release/keygen
target/release/permissionless-builder
target/release/nasty-client
target/release/espresso-dev-node
target/release/pub-key
target/release/espresso-bridge
build-arm:
runs-on: buildjet-4vcpu-ubuntu-2204-arm
Expand All @@ -96,6 +103,11 @@ jobs:
run: |
cargo build --locked --release --workspace
- name: Build Espresso Dev Node
# Espresso Dev Node currently requires testing feature, so it is built separately.
run: |
cargo build --locked --release --features testing --bin espresso-dev-node
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
Expand All @@ -116,7 +128,9 @@ jobs:
target/release/keygen
target/release/permissionless-builder
target/release/nasty-client
target/release/espresso-dev-node
target/release/pub-key
target/release/espresso-bridge
build-dockers:
runs-on: ubuntu-latest
Expand All @@ -134,6 +148,8 @@ jobs:
deploy-tag: ${{ steps.deploy.outputs.tags }}
builder-tag: ${{ steps.builder.outputs.tags }}
nasty-client-tag: ${{ steps.nasty-client.outputs.tags }}
espresso-dev-node-tag: ${{ steps.espresso-dev-node.outputs.tags }}
bridge-tag: ${{ steps.bridge.outputs.tags }}
steps:
- name: Checkout Repository
uses: actions/checkout@v4
Expand Down Expand Up @@ -235,8 +251,20 @@ jobs:
with:
images: ghcr.io/espressosystems/espresso-sequencer/nasty-client

- name: Generate espresso-dev-node metadata
uses: docker/metadata-action@v5
id: espresso-dev-node
with:
images: ghcr.io/espressosystems/espresso-sequencer/espresso-dev-node

- name: Generate bridge metadata
uses: docker/metadata-action@v5
id: bridge
with:
images: ghcr.io/espressosystems/espresso-sequencer/bridge

- name: Build and push sequencer docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/sequencer.Dockerfile
Expand All @@ -246,7 +274,7 @@ jobs:
labels: ${{ steps.sequencer.outputs.labels }}

- name: Build and push cdn-broker docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/cdn-broker.Dockerfile
Expand All @@ -256,7 +284,7 @@ jobs:
labels: ${{ steps.cdn-broker.outputs.labels }}

- name: Build and push cdn-marshal docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/cdn-marshal.Dockerfile
Expand All @@ -266,7 +294,7 @@ jobs:
labels: ${{ steps.cdn-marshal.outputs.labels }}

- name: Build and push cdn-whitelist docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/cdn-whitelist.Dockerfile
Expand All @@ -276,7 +304,7 @@ jobs:
labels: ${{ steps.cdn-whitelist.outputs.labels }}

- name: Build and push state-relay-server docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/state-relay-server.Dockerfile
Expand All @@ -286,7 +314,7 @@ jobs:
labels: ${{ steps.state-relay-server.outputs.labels }}

- name: Build and push prover-service docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/prover-service.Dockerfile
Expand All @@ -296,7 +324,7 @@ jobs:
labels: ${{ steps.prover-service.outputs.labels }}

- name: Build and push orchestrator docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/orchestrator.Dockerfile
Expand All @@ -306,7 +334,7 @@ jobs:
labels: ${{ steps.orchestrator.outputs.labels }}

- name: Build and push commitment-task docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/commitment-task.Dockerfile
Expand All @@ -316,7 +344,7 @@ jobs:
labels: ${{ steps.commitment-task.outputs.labels }}

- name: Build and push submit-transactions docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/submit-transactions.Dockerfile
Expand All @@ -326,7 +354,7 @@ jobs:
labels: ${{ steps.submit-transactions.outputs.labels }}

- name: Build and push deploy docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/deploy.Dockerfile
Expand All @@ -336,7 +364,7 @@ jobs:
labels: ${{ steps.deploy.outputs.labels }}

- name: Build and push builder docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/permissionless-builder.Dockerfile
Expand All @@ -346,7 +374,7 @@ jobs:
labels: ${{ steps.builder.outputs.labels }}

- name: Build and push nasty-client docker
uses: docker/build-push-action@v5
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/nasty-client.Dockerfile
Expand All @@ -355,6 +383,25 @@ jobs:
tags: ${{ steps.nasty-client.outputs.tags }}
labels: ${{ steps.nasty-client.outputs.labels }}

- name: Build and push espresso-dev-node docker
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/espresso-dev-node.Dockerfile
platforms: linux/amd64,linux/arm64
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.espresso-dev-node.outputs.tags }}
labels: ${{ steps.espresso-dev-node.outputs.labels }}
- name: Build and push bridge docker
uses: docker/build-push-action@v6
with:
context: ./
file: ./docker/espresso-bridge.Dockerfile
platforms: linux/amd64,linux/arm64
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.bridge.outputs.tags }}
labels: ${{ steps.bridge.outputs.labels }}

test-demo:
if: ${{ github.event_name != 'pull_request' }}
runs-on: ubuntu-latest
Expand Down Expand Up @@ -382,6 +429,7 @@ jobs:
docker pull ${{ needs.build-dockers.outputs.deploy-tag }}
docker pull ${{ needs.build-dockers.outputs.builder-tag }}
docker pull ${{ needs.build-dockers.outputs.nasty-client-tag }}
docker pull ${{ needs.build-dockers.outputs.bridge-tag }}
- name: Tag new docker images
run: |
docker tag ${{ needs.build-dockers.outputs.sequencer-tag }} ghcr.io/espressosystems/espresso-sequencer/sequencer:main
Expand All @@ -396,8 +444,9 @@ jobs:
docker tag ${{ needs.build-dockers.outputs.deploy-tag }} ghcr.io/espressosystems/espresso-sequencer/deploy:main
docker tag ${{ needs.build-dockers.outputs.builder-tag }} ghcr.io/espressosystems/espresso-sequencer/builder:main
docker tag ${{ needs.build-dockers.outputs.nasty-client-tag }} ghcr.io/espressosystems/espresso-sequencer/nasty-client:main
docker tag ${{ needs.build-dockers.outputs.bridge-tag }} ghcr.io/espressosystems/espresso-sequencer/bridge:main
- name: Test docker demo
run: |
just demo &
timeout 600 scripts/smoke-test-demo
timeout -v 600 scripts/smoke-test-demo | sed -e 's/^/smoke-test: /;'
Loading

0 comments on commit 9e8694e

Please sign in to comment.