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

fix(eigen-client-m0-implementation): fix get all blobs program #3367

Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
fcecc81
add integration doc
juan518munoz Oct 31, 2024
2bcf78f
Reimplement eigen config (#320)
gianbelinche Nov 1, 2024
537cf92
feat(eigen-client-extra-feature): rlp encoding (#319)
juan518munoz Nov 1, 2024
f58e0bf
feat(eigen-client-extra-features): non auth dispersal (#318)
juan518munoz Nov 1, 2024
04b93e6
initial commit
juan518munoz Nov 1, 2024
c121eca
add spaces
juan518munoz Nov 1, 2024
4a38ee2
Revert wrong push
juan518munoz Nov 1, 2024
e64cc2e
initial commit
juan518munoz Nov 1, 2024
5b8665b
Merge pull request #324 from lambdaclass/eigen-client-get-inclusion-data
juanbono Nov 1, 2024
aa9f1b2
fix(eigen-client-extra-features): fix eigen config test (#323)
juan518munoz Nov 4, 2024
e033630
feat(eigen-client-extra-features): Eigen client memstore (#321)
gianbelinche Nov 5, 2024
b164870
feat(eigen-client-extra-features): blob size limit (#325)
juan518munoz Nov 5, 2024
f95bc1b
feat(eigen-client-extra-features): Add soft confirmations (#322)
gianbelinche Nov 5, 2024
9c06b40
feat(eigen-client-extra-features): Verifier (#326)
gianbelinche Nov 5, 2024
3b9e766
feat(eigen-client-extra-features): Eigen client documentation (#327)
juan518munoz Nov 5, 2024
6668ab9
feat(eigen-client-extra-features): Eth confirmation depth (#328)
gianbelinche Nov 7, 2024
cc9e2be
feat(eigen-client-extra-features): Remove unused custom quorum number…
gianbelinche Nov 7, 2024
9769a17
doc & cargo check all
juan518munoz Nov 7, 2024
91bb79b
clippy
juan518munoz Nov 7, 2024
cbe124e
Merge branch 'main' into eigen-client-merge-main
juan518munoz Nov 7, 2024
9c73b3f
update contracts submodule
juan518munoz Nov 7, 2024
94ecb52
Merge pull request #330 from lambdaclass/eigen-client-clippy-and-doc
juanbono Nov 8, 2024
342b476
Merge pull request #331 from lambdaclass/eigen-client-merge-main
juanbono Nov 8, 2024
077bc13
Merge branch 'main' into eigen-client-extra-features
juanbono Nov 8, 2024
c98726a
Update integration readme (#335)
gianbelinche Nov 11, 2024
64d0a38
feat(eigen-client-m0-implementation): concurrent da dispatcher (#333)
juan518munoz Nov 12, 2024
991c340
update contracts submodule
juan518munoz Nov 12, 2024
f55a424
Merge pull request #337 from lambdaclass/eigen-client-contracts-submo…
juanbono Nov 12, 2024
f2fb12c
feat(eigen-client-extra-features): Remove kzgpad (#339)
gianbelinche Nov 15, 2024
b825d4f
Create eigendaservicemanager type (#340)
gianbelinche Nov 15, 2024
9561bc3
Change match to if (#341)
gianbelinche Nov 15, 2024
986a1d2
feat(eigen-client-eigen-features): Move dependencies (#342)
gianbelinche Nov 15, 2024
09ecfdd
feat(eigen-client-extra-features): Backon (#344)
gianbelinche Nov 19, 2024
a2ddcc3
Remove memstore (#346)
gianbelinche Nov 19, 2024
4c5af89
feat(eigen-client-m0-implementation): grafana metrics (#334)
juan518munoz Nov 19, 2024
103ae8e
fix sleep millis instead of secs (#348)
juan518munoz Nov 19, 2024
5e3b125
feat(eigen-client-m0-implementation): send blob id to l1 (#332)
juan518munoz Nov 20, 2024
7d369a8
Add reserved to proto (#343)
gianbelinche Nov 21, 2024
a9c31a7
Remove extra config (#351)
gianbelinche Nov 21, 2024
6e1de82
feat(eigen-client-extra-features): Kzg bn254 crate (#352)
gianbelinche Nov 21, 2024
8d0b908
feat(eigen-client-extra-features): Remove Alloy Dependency (#349)
gianbelinche Nov 21, 2024
43a3e5c
Merge branch 'eigen-client-extra-features' into eigen-client-m0-with-…
gianbelinche Nov 22, 2024
28c826c
Merge branch 'main' into eigen-client-extra-features-merge-main
gianbelinche Nov 22, 2024
68abc97
Fix cargo lock
gianbelinche Nov 22, 2024
05ee9b6
Merge branch 'eigen-client-extra-features-merge-main' into eigen-clie…
gianbelinche Nov 22, 2024
f3725c6
Fix conflicts
gianbelinche Nov 22, 2024
c47a0cd
clippy & doc
juan518munoz Nov 22, 2024
9416d8d
Merge pull request #353 from lambdaclass/eigen-client-m0-with-extra
gianbelinche Nov 22, 2024
99b153a
Merge pull request #354 from lambdaclass/eigen-client-extra-features-…
gianbelinche Nov 22, 2024
f91bd58
Merge pull request #355 from lambdaclass/eigen-client-m0-extra-merge-…
juan518munoz Nov 22, 2024
01b50ed
feat(eigen-client-extra-features): Move inclusion logic (#357)
gianbelinche Nov 28, 2024
daace34
feat(eigen-client-extra-features): Remove verify cert (#359)
gianbelinche Nov 28, 2024
99c6d42
feat(eigen-client-extra-features): Small changes (#358)
gianbelinche Nov 28, 2024
163c41a
feat(eigen-client-extra-features): minimal client changes (#362)
juan518munoz Nov 28, 2024
cef9a89
feat(eigen-client-extra-features): Add option to download points (#361)
gianbelinche Nov 28, 2024
75090b6
feat(eigen-client-extra-features): Replace third party dependant test…
juan518munoz Nov 28, 2024
7a61574
feat(eigen-client-extra-features): Remove steps to run from integrati…
gianbelinche Nov 28, 2024
bc90cc6
Merge branch 'main' into eigen-client-extra-features-and-main
gianbelinche Nov 28, 2024
87d450f
Update Cargo.lock
gianbelinche Nov 28, 2024
e2d4dab
Merge pull request #363 from lambdaclass/eigen-client-extra-features-…
gianbelinche Nov 29, 2024
f0dc911
Merge branch 'eigen-client-extra-features' into eigen-client-m0-imple…
gianbelinche Dec 2, 2024
4439795
Fix concurrent dispatcher
gianbelinche Dec 3, 2024
e1d42c7
Go back to sequential dispatcher
gianbelinche Dec 3, 2024
4d1fadb
Merge branch 'main' into eigen-client-extra-features
juanbono Dec 3, 2024
4bb08b9
feat(eigen-client-pr-comments): Eigen client pr comments (#365)
gianbelinche Dec 6, 2024
0d01df7
Remove points (#366)
gianbelinche Dec 6, 2024
2100256
Merge branch 'main' into eigen-client-extra-features
gianbelinche Dec 6, 2024
0169b1e
Merge pull request #364 from lambdaclass/eigen-client-m0-sequential-d…
gianbelinche Dec 6, 2024
83c3e13
Merge pull request #367 from lambdaclass/eigen-client-extra-main
gianbelinche Dec 6, 2024
f75e703
merge branch 'eigen-client-extra-features'
juan518munoz Dec 6, 2024
f2aa6f2
initial commit
juan518munoz Dec 9, 2024
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
1,033 changes: 1,011 additions & 22 deletions Cargo.lock

Large diffs are not rendered by default.

5 changes: 5 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ members = [
# Test infrastructure
"core/tests/loadnext",
"core/tests/vm-benchmark",
"get_all_blobs",
]
resolver = "2"

Expand Down Expand Up @@ -222,6 +223,10 @@ pbjson-types = "0.6.0"

# Eigen
tokio-stream = "0.1.16"
rust-kzg-bn254 = "0.2.1"
ark-bn254 = "0.5.0"
num-bigint = "0.4.6"
serial_test = "3.1.1"

# Here and below:
# We *always* pin the latest version of protocol to disallow accidental changes in the execution logic.
Expand Down
25 changes: 21 additions & 4 deletions core/lib/config/src/configs/da_client/eigen.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,27 @@
use serde::Deserialize;
use zksync_basic_types::secrets::PrivateKey;

#[derive(Clone, Debug, Default, PartialEq, Deserialize)]
/// Configuration for the EigenDA remote disperser client.
#[derive(Clone, Debug, PartialEq, Deserialize, Default)]
pub struct EigenConfig {
pub rpc_node_url: String,
pub inclusion_polling_interval_ms: u64,
/// URL of the Disperser RPC server
pub disperser_rpc: String,
/// Block height needed to reach in order to consider the blob finalized
/// a value less or equal to 0 means that the disperser will not wait for finalization
pub settlement_layer_confirmation_depth: i32,
/// URL of the Ethereum RPC server
pub eigenda_eth_rpc: String,
/// Address of the service manager contract
pub eigenda_svc_manager_address: String,
/// Wait for the blob to be finalized before returning the response
pub wait_for_finalization: bool,
/// Authenticated dispersal
pub authenticated: bool,
/// Url to the file containing the G1 point used for KZG
pub g1_url: String,
/// Url to the file containing the G2 point used for KZG
pub g2_url: String,
/// Chain ID of the Ethereum network
pub chain_id: u64,
}

#[derive(Clone, Debug, PartialEq)]
Expand Down
4 changes: 4 additions & 0 deletions core/lib/config/src/configs/da_dispatcher.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ pub const DEFAULT_POLLING_INTERVAL_MS: u32 = 5000;
pub const DEFAULT_MAX_ROWS_TO_DISPATCH: u32 = 100;
pub const DEFAULT_MAX_RETRIES: u16 = 5;
pub const DEFAULT_USE_DUMMY_INCLUSION_DATA: bool = false;
pub const DEFAULT_MAX_CONCURRENT_REQUESTS: u32 = 100;

#[derive(Debug, Clone, PartialEq, Deserialize)]
pub struct DADispatcherConfig {
Expand All @@ -19,6 +20,8 @@ pub struct DADispatcherConfig {
// TODO: run a verification task to check if the L1 contract expects the inclusion proofs to
// avoid the scenario where contracts expect real proofs, and server is using dummy proofs.
pub use_dummy_inclusion_data: Option<bool>,
/// The maximun number of concurrent request to send to the DA server.
pub max_concurrent_requests: Option<u32>,
}

impl DADispatcherConfig {
Expand All @@ -28,6 +31,7 @@ impl DADispatcherConfig {
max_rows_to_dispatch: Some(DEFAULT_MAX_ROWS_TO_DISPATCH),
max_retries: Some(DEFAULT_MAX_RETRIES),
use_dummy_inclusion_data: Some(DEFAULT_USE_DUMMY_INCLUSION_DATA),
max_concurrent_requests: Some(DEFAULT_MAX_CONCURRENT_REQUESTS),
}
}

Expand Down
1 change: 1 addition & 0 deletions core/lib/config/src/testonly.rs
Original file line number Diff line number Diff line change
Expand Up @@ -972,6 +972,7 @@ impl Distribution<configs::da_dispatcher::DADispatcherConfig> for EncodeDist {
max_rows_to_dispatch: self.sample(rng),
max_retries: self.sample(rng),
use_dummy_inclusion_data: self.sample(rng),
max_concurrent_requests: self.sample(rng),
}
}
}
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading
Loading