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

RPC update - add l2 gas #2335

Open
wants to merge 23 commits into
base: main
Choose a base branch
from
Open

RPC update - add l2 gas #2335

wants to merge 23 commits into from

Conversation

AnkushinDaniil
Copy link
Contributor

@AnkushinDaniil AnkushinDaniil commented Dec 18, 2024

Fix #2323
Fix #2324
Fix #2334

Implement RPC changes regarding l2_gas

Core Data Structures and Adaptation Functions:

  • core/block.go: Updated the Header struct to include L1GasPriceETH, L2GasPriceETH, L1GasPriceSTRK, and L2GasPriceSTRK fields, replacing the previous GasPrice and GasPriceSTRK fields. [1] [2]
  • adapters/p2p2core/block.go: Updated the AdaptBlockHeader function to include the new L1 and L2 gas price fields.
  • adapters/sn2core/sn2core.go: Adjusted the AdaptBlock function to handle the new gas price fields.

RPC:

  • rpc/block.go: Updated the BlockHeader struct and adaptBlockHeader function to include L2 gas prices. [1] [2]
  • rpc/estimate_fee.go: Introduced a new FeeEstimate struct to handle L1 and L2 gas prices and added a versioned EstimateFeeV0_7 function for backward compatibility. [1] [2] [3]

Test Cases:

Copy link

codecov bot commented Dec 18, 2024

Codecov Report

Attention: Patch coverage is 80.21978% with 18 lines in your changes missing coverage. Please review.

Project coverage is 74.93%. Comparing base (27b6968) to head (6dcb2f5).

Files with missing lines Patch % Lines
rpc/estimate_fee.go 51.85% 12 Missing and 1 partial ⚠️
rpc/simulation.go 82.14% 5 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #2335      +/-   ##
==========================================
+ Coverage   74.62%   74.93%   +0.30%     
==========================================
  Files         110      110              
  Lines       12024    12072      +48     
==========================================
+ Hits         8973     9046      +73     
+ Misses       2354     2332      -22     
+ Partials      697      694       -3     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@AnkushinDaniil AnkushinDaniil added the RPC JSON RPC API label Dec 20, 2024
@AnkushinDaniil AnkushinDaniil changed the title Daniil/update rpc RPC update - add l2 gas Dec 20, 2024
@AnkushinDaniil AnkushinDaniil added the go Pull requests that update Go code label Dec 20, 2024
rpc/estimate_fee.go Outdated Show resolved Hide resolved
rpc/block.go Outdated Show resolved Hide resolved
Copy link
Contributor

@weiihann weiihann left a comment

Choose a reason for hiding this comment

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

LGTM

core/block.go Show resolved Hide resolved
return nil, httpHeader, err
}

return utils.Map(result, func(tx SimulatedTransaction) FeeEstimateV0_7 {
Copy link
Contributor

Choose a reason for hiding this comment

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

you can pass function name (=pointer) like:

return utils.Map(result, FeeEstimateToV0_7)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I don't think so, feeEstimateToV0_7 adapts FeeEstimate, not SimulatedTransaction.
return utils.Map(result, feeEstimateToV0_7) requires changes in feeEstimateToV0_7.

rpc/estimate_fee.go Outdated Show resolved Hide resolved
@AnkushinDaniil AnkushinDaniil force-pushed the daniil/update-rpc branch 2 times, most recently from dfa0789 to eed5b3e Compare December 26, 2024 07:55
@AnkushinDaniil AnkushinDaniil force-pushed the daniil/update-rpc branch 4 times, most recently from 968275a to c1abd7a Compare January 13, 2025 18:49
Copy link
Contributor

@rodrigo-pino rodrigo-pino left a comment

Choose a reason for hiding this comment

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

Half review. Will continue tomorrow

core/felt/felt.go Outdated Show resolved Hide resolved
Comment on lines 60 to 61
L2GasPriceFri: AdaptUint128(header.L2GasPriceSTRK.NilToZero()),
L2GasPriceWei: AdaptUint128(header.L2GasPriceETH.NilToZero()),
Copy link
Contributor

Choose a reason for hiding this comment

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

If this values cannot be nil they should be handled explicitly up top.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

rpc/block.go Outdated Show resolved Hide resolved
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
go Pull requests that update Go code RPC JSON RPC API
Projects
None yet
Development

Successfully merging this pull request may close these issues.

RPC08 - Execution_resources changes RPC08 - Fee_estimate changes RPC08 - Block header now contains l2_gas
4 participants