-
Notifications
You must be signed in to change notification settings - Fork 1.7k
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
Move usage of eth_maxPriorityFeePerGas
to eth_feeHistory
#2259
Comments
Hi @kclowes, good excuse to dig into some more web3.py code. I will put together a PR for this. |
Awesome, thanks @broper2! |
Hi @kclowes, wanted to run something by you before submitting PR. I do think the underlying data used in eth_maxPriorityFeePerGas implementation is available in eth_feeHistory, and we could add a simple function to estimate a reasonable "tip" default. However, as I read about this more, I found this discussion: Seems we may be able to leverage relation between gas_price and get_block('latest')['baseFeePerGas'] to get an exact value of what eth_maxPriorityFeePerGas would return. The relationship (web3.eth.gas_price - web3.eth.get_block('latest')['baseFeePerGas']) == web3.eth.max_priority_fee seems to hold in some quick functional testing I have done. I don't claim to be ETH expert, so please tell me if I am missing something, or if this looks ok as a no-impact change. Thanks! |
I don't think this is good enough. Some testing on my end suggests that at every new block transition (most likely) there is inconsistency in the values for I did some quick-and-dirty testing calling the below method on an infura connection multiple times until I got def max_prio_calc():
gp = w3.eth.gas_price
bf = w3.eth.get_block('latest')['baseFeePerGas']
mpf = w3.eth.max_priority_fee
print(f'gas_price: {gp} | base_fee: {bf} | max_priority_fee: {mpf}')
theory_holds = mpf == gp - bf
print(theory_holds)
if not theory_holds:
print(f'{mpf} != {gp - bf}') e.g. >>> max_prio_calc()
gas_price: 78216696028 | base_fee: 77168141801 | max_priority_fee: 1250000000
False
1250000000 != 1048554227 Again, I haven't looked into this too much yet (other than testing the suggestion) but I would be good with building a calculation from scratch that is equal to what Thoughts? |
Yeah its a good point. From reading about this, I am not convinced we will be able to replicate behavior of RPC endpoint eth_maxPriorityFeePerGas perfectly either way, but if that is accepted I can put together a calculation and see if it gets closer over number of tries (I am actually guessing that it will not be as good, but don't mind trying). If the goal is really to never deviate from what eth_maxPriorityFeePerGas returns, I think it may make better sense to put responsibility on user. Let me know what you think @fselmo |
@broper2 yeah I hear you... I don't necessarily care that we replicate what geth is doing... something else that is reasonable would work well here too. The reason I don't like the e.g. >>> max_prio_calc()
gas_price: 67953109912 | base_fee: 74750863316 | max_priority_fee: 1500000000
False
1500000000 != -6797753404 Also, the more I think about it, the more I don't think I'm ok with putting the responsibility on the user. The barrier to entry is still pretty high for web3 and one of our main goals is to make the user experience better and make development more inviting. In the end I think this ended up being a bit more complicated of a task than we expected but thank you for starting the conversation on it. Let me know if you are still interested in pursuing this. No sweat if not. I wouldn't mind scooping this up after the holidays. I would probably start looking at what geth is doing and any other examples (if they exist) and look to implement a similar internal approach for when the |
Good catch with the negative value, should have considered that. And no problem, I'll give it a go creating an estimate to this endpoint in the next few days. I am just trying to dig into some web3 code so don't mind the added complexity at all. When I was researching this before, I came across this Alchemy blog which gives a lot of info on best way to do exactly this calculation. Will circle back when I have that PR updated. Thanks @fselmo https://docs.alchemy.com/alchemy/guides/eip-1559/gas-estimator |
Refactor idea from PR ethereum#2259 into sync and async fee utility methods. Change params passed into eth_feeHistory to values that allowed for better results when we tested locally. Add a min and max to the estimated fee history so that we don't allow unsuspecting users to contribute to fee bloating. Max and min values keep the priority fee within a range that healthy blocks should accept, so these transactions would be accepted when fee prices settle from high-fee periods.
Refactor idea from PR ethereum#2259 into sync and async fee utility methods. Change params passed into eth_feeHistory to values that allowed for better results when we tested locally. Add a min and max to the estimated fee history so that we don't allow unsuspecting users to contribute to fee bloating. Max and min values keep the priority fee within a range that healthy blocks should accept, so these transactions would be accepted when fee prices settle from high-fee periods.
Refactor idea from PR #2259 into sync and async fee utility methods. Change params passed into eth_feeHistory to values that allowed for better results when we tested locally. Add a min and max to the estimated fee history so that we don't allow unsuspecting users to contribute to fee bloating. Max and min values keep the priority fee within a range that healthy blocks should accept, so these transactions would be accepted when fee prices settle from high-fee periods.
* move default_account and default_block properties and setters to BaseEth so Eth and AsyncEth can access * Feature/ens request (ethereum#2319) * fixed ens contract function called twice * newsfragment * small typo in documentation * add newsfragment * Only apply ``to_hexbytes`` formatter if value is not null * asyncify eth.get_logs (ethereum#2310) * asyncify eth.get_logs * factor out `assert_contains_log` function Co-authored-by: Paul Robinson <[email protected]> * Add Github link to the main doc landing Because Github link is extremely useful * Newsfragment for github link to docs * Update typing extensions to allow v4 (ethereum#2217) * Update typing extensions to allow v4 * Loosen typing-extensions version * Add newsfragment for typing-extensions bump * Try out new py-evm requirements in eth-tester * Remove xfails for newly passing eth-tester tests * Upgrade eth-account requirement * Add newsfragment for eth-tester bump * correct misspellings and update referenced geth version * Compile release notes * Bump version: 5.26.0 → 5.27.0 * Add Async Geth Personal module (ethereum#2299) * fix: Missing commas (ethereum#2327) * fix: Missing commas * Add newsfragment for exception retry middleware whitelist Co-authored-by: kclowes <[email protected]> * Fixes ethereum#2259, remove dependency on eth_maxPriorityFeePerGas * fix lint and integration tests * refactor: utility for estimating maxPriorityFeePerGas via eth_feeHistory Refactor idea from PR ethereum#2259 into sync and async fee utility methods. Change params passed into eth_feeHistory to values that allowed for better results when we tested locally. Add a min and max to the estimated fee history so that we don't allow unsuspecting users to contribute to fee bloating. Max and min values keep the priority fee within a range that healthy blocks should accept, so these transactions would be accepted when fee prices settle from high-fee periods. * add tests for max_priority_fee when eth_maxPriorityFeePerGas is not available * asyncify eth.syncing * formatting and validation middleware async support * Properly test unused code in test * Align NamedTuples (ethereum#2312) * Align NamedTuples * Add NamedTuple alignment test. * Add newsfragment for NamedTuple change Co-authored-by: kclowes <[email protected]> * rm ens.utils.dict_copy Signed-off-by: Harmouch101 <[email protected]> * fixed lint error Signed-off-by: Harmouch101 <[email protected]> * Update main.py * add newsfragment * Feature/async geth admin (ethereum#2329) * Added BaseGethPersonal to geth.py * Added AsyncGethPersonal and test * Added Docs * lint fixes * news fragment update * removed import_raw_key test for now * mypy typing issues * typo * Added AsyncGethAdmin and BaseGethAdmin. Also, fixed test due to typing * made suggested changes * made suggested changes * fixed spelling errors * added test and docs * newsfragment * merge conflict * remove setSolc * copy in suggested test * forgot to check liniting before commit * linting * linting * Properly initialize external modules Properly initialize modules that do not inherit from the `web3.module.Module` class. We weren't properly testing self-referential, non-static methods with this functionality and so a test was also added for this. * correct docs for external modules * Refactor attach_module logic * Allow for accepting the ``Web3`` instance as the first argument in any module's ``__init()`` method, rather than requiring a module to inherit from ``web3.module.Module`` if it needs to make use of the ``Web3`` instance. * Update tests to test the above change. * Add a more friendly error message if the module has more than one __init__() argument. Add test for this error message / case. * recorrect docs for external modules * Compile release notes * Bump version: 5.27.0 → 5.28.0 * Add 'Breaking Changes' and 'Deprecation' to our valid newsfragment types (ethereum#2340) * Add 'Breaking Change' and 'Deprecation' to our valid newsfragment types * Add newsfragment for new newsfragment categories * Remove removal section of release notes * Drop python 3.6 (ethereum#2343) * Drop python 3.6 * Remove parity tests * Add newsfragment for py36 drop * Fix gas types (ethereum#2330) * fix: correct type for effectiveGasPrice (Wei, not int) * fix: correct type for gas and gas_limit (int, not Wei) * lint: removed unused type imports of Wei * Add newsfragment for Wei/int typing fixes Co-authored-by: kclowes <[email protected]> * Upgrade websockets dependency to v10+ (ethereum#2324) * Require websockets v10+ - Remove event loop parameter * Add newsfragment for websockets upgrade * ➕ Add Python 3.10 support (ethereum#2175) * ➕ Add Python 3.10 support to CI * Dropped support for all parities * Change docker image to use 3.10 * Update pytest-asyncio plugin * Mark async fixture as such, clean up pytest DeprecationWarnings Signed-off-by: Harmouch101 <[email protected]> Co-authored-by: Felipe Selmo <[email protected]> Co-authored-by: kclowes <[email protected]> * add fork description * [NBA-39] add multiple nodes for web3 HTTPProvider (#1) * Update README.md * Update README.md * Update README.md * typo fix Co-authored-by: pacrob <[email protected]> Co-authored-by: AlwaysData <[email protected]> Co-authored-by: alex <[email protected]> Co-authored-by: Felipe Selmo <[email protected]> Co-authored-by: DefiDebauchery <[email protected]> Co-authored-by: Mikko Ohtamaa <[email protected]> Co-authored-by: kclowes <[email protected]> Co-authored-by: Marek Šuppa <[email protected]> Co-authored-by: broper2 <[email protected]> Co-authored-by: Călina Cenan <[email protected]> Co-authored-by: Harmouch101 <[email protected]> Co-authored-by: Marc Garreau <[email protected]> Co-authored-by: coccoinomane <[email protected]>
Since
eth_maxPriorityFeePerGas
is Geth-specific, we should stop using it to fill in gas values. We should useeth_feeHistory
instead. I think it still makes sense to keep the RPC endpoint inweb3/eth.py
, but all places we calleth_maxPriorityFeePerGas
should be changed.Comment from #2237:
Originally posted by @guoyiteng in #2237 (comment)
The text was updated successfully, but these errors were encountered: