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

chore(rpc-types): Buildable Type #374

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open

chore(rpc-types): Buildable Type #374

wants to merge 1 commit into from

Conversation

refcell
Copy link
Collaborator

@refcell refcell commented Jan 9, 2025

Description

Fixes #29.

Implements the buildable_type method on the OpTransactionReceipt type.

@refcell refcell requested review from mattsse and emhane as code owners January 9, 2025 17:30
@refcell refcell added the A-rpc-types Area: op alloy rpc types label Jan 9, 2025
@refcell refcell requested a review from clabby as a code owner January 9, 2025 17:30
@refcell refcell added the C-chore Category: general cleanup label Jan 9, 2025
@refcell refcell self-assigned this Jan 9, 2025
@refcell
Copy link
Collaborator Author

refcell commented Jan 9, 2025

📚 $\text{Stack Overview}$

Pulls submitted in this stack:

This comment was automatically generated by st.

@refcell
Copy link
Collaborator Author

refcell commented Jan 9, 2025

Needs review from @emhane

@refcell refcell added the D-do-not-merge Desc: Do not merge label Jan 9, 2025
Some(TxType::Eip1559) => Some(OpTxType::Eip1559),
Some(TxType::Eip2930) => Some(OpTxType::Eip2930),
Some(TxType::Eip7702) => Some(OpTxType::Eip7702),
Some(TxType::Eip4844) => Some(OpTxType::Eip1559),
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

how did you think here, eip4844 -> eip1559 ? I would have thought that variant is just skipped, possibly with a debug log message that eip4844 isn't supported for eip4844

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can do that - was pretty unsure

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think technically 1559 is accurate here because if 4844 is buildable then 1559 is buildable as well, but 4844 is only buildable if 4844 fields were explicitly set, so I think we should return None here which would result in an error in the request builder impl

Some(TxType::Eip1559) => Some(OpTxType::Eip1559),
Some(TxType::Eip2930) => Some(OpTxType::Eip2930),
Some(TxType::Eip7702) => Some(OpTxType::Eip7702),
Some(TxType::Eip4844) => Some(OpTxType::Eip1559),
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think technically 1559 is accurate here because if 4844 is buildable then 1559 is buildable as well, but 4844 is only buildable if 4844 fields were explicitly set, so I think we should return None here which would result in an error in the request builder impl

if self.0.chain_id.is_none() {
return Some(OpTxType::Deposit);
}
match self.0.buildable_type() {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can use ? here

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-rpc-types Area: op alloy rpc types C-chore Category: general cleanup D-do-not-merge Desc: Do not merge
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Feature] Impl OpTransactionRequest::buildable_type
3 participants