-
Notifications
You must be signed in to change notification settings - Fork 304
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
hack: Allow skipping bytecode propagation when registering contract classes to support Sepolia #10000
Comments
spalladino
added a commit
that referenced
this issue
Nov 15, 2024
Skips emitting the event with the contract public bytecode when registering the contract class. This allows for smaller L1 txs so they fit in Sepolia. This is a temporary hack to be reverted. To get bytecode into the nodes, we push it forcefully from the PXE whenever we register a new contract. However, this only gets the bytecode into the node that the PXE is connected to. To avoid nodes or prover nodes from missing bytecode that is to be used for known deployments, such as the token or token bridge contracts, we now manually register them on initialization. Reverting this is logged as issue #10007 Fixes #10000
Hmm, this is interesting. Public bytecode is not expected to get any smaller anytime soon. What's the calldata size? I think the token contract would now be between 30kB and 55kB? |
@fcarreiro I understand we should be fine when we move to blobs |
spalladino
added a commit
that referenced
this issue
Nov 20, 2024
Skips emitting the event with the contract public bytecode when registering the contract class. This allows for smaller L1 txs so they fit in Sepolia. This is a temporary hack to be reverted. To get bytecode into the nodes, we push it forcefully from the PXE whenever we register a new contract. However, this only gets the bytecode into the node that the PXE is connected to. To avoid nodes or prover nodes from missing bytecode that is to be used for known deployments, such as the token or token bridge contracts, we now manually register them on initialization. Reverting this is logged as issue #10007 Fixes #10000 Please read [contributing guidelines](CONTRIBUTING.md) and remove this line.
spalladino
added a commit
that referenced
this issue
Jan 6, 2025
Since #10000 we are not broadcasting public bytecode. To work around this in some networks, we're manually adding some common contracts (Token) to archivers on startup. Since an Aztec node returns that a class is publicly registered as long as it's on its archiver, clients were not sending txs to register the Token class. However, we will soon check for registration nullifiers. But since clients think the Token class is registered, they never send the registration tx. So this will cause all interactions with the Token to break. This attempts to fix this by only telling clients that a class is registered if the nullifier is present.
spalladino
added a commit
that referenced
this issue
Jan 6, 2025
Since #10000 we are not broadcasting public bytecode. To work around this in some networks, we're manually adding some common contracts (Token) to archivers on startup. Since an Aztec node returns that a class is publicly registered as long as it's on its archiver, clients were not sending txs to register the Token class. However, we will soon check for registration nullifiers. But since clients think the Token class is registered, they never send the registration tx. So this will cause all interactions with the Token to break. This attempts to fix this by only telling clients that a class is registered if the nullifier is present.
spalladino
added a commit
that referenced
this issue
Jan 6, 2025
Since #10000 we are not broadcasting public bytecode. To work around this in some networks, we're manually adding some common contracts (Token) to archivers on startup. Since an Aztec node returns that a class is publicly registered as long as it's on its archiver, clients were not sending txs to register the Token class. However, we will soon check for registration nullifiers. But since clients think the Token class is registered, they never send the registration tx. So this will cause all interactions with the Token to break. This attempts to fix this by only telling clients that a class is registered if the nullifier is present.
spalladino
added a commit
that referenced
this issue
Jan 6, 2025
Since #10000 we are not broadcasting public bytecode. To work around this in some networks, we're manually adding some common contracts (Token) to archivers on startup. Since an Aztec node returns that a class is publicly registered as long as it's on its archiver, clients were not sending txs to register the Token class. However, we will soon check for registration nullifiers. But since clients think the Token class is registered, they never send the registration tx. So this will cause all interactions with the Token to break. This attempts to fix this by only telling clients that a class is registered if the nullifier is present.
spalladino
added a commit
that referenced
this issue
Jan 7, 2025
#11074) Since #10000 we are not broadcasting public bytecode. To work around this in some networks, we're manually adding some common contracts (Token) to archivers on startup. Since an Aztec node returns that a class is publicly registered as long as it's on its archiver, clients were not sending txs to register the Token class. However, we will soon check for registration nullifiers. But since clients think the Token class is registered, they never send the registration tx. So this will cause all interactions with the Token to break. This attempts to fix this by only telling clients that a class is registered if the nullifier is present.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
We cannot deploy public contracts to Sepolia because bytecode size is too large, which exceeds L1 tx maximum calldata size. To unblock us until we get blobs or reduced AVM public bytecode, we can hack the contract class registerer so it does not broadcast public bytecode if it goes over a configurable threshold, and manually register that bytecode into nodes in order to use it.
The text was updated successfully, but these errors were encountered: