Security News
New Python Packaging Proposal Aims to Solve Phantom Dependency Problem with SBOMs
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
eip1559-fee-suggestions-ethers
Advanced tools
JavaScript library that suggest fees on Ethereum after EIP-1559 using historical data using ethers.js
The function suggestFees() is a utility function written in Javascript and it's intended to use with an ethers.js provider.
It returns a list of suggested maxFeePerGas / maxPriorityFeePerGas pairs where the index of the list is the timeFactor.
A low timeFactor should be used for urgent transactions while higher values yield more economical suggestions that are expected to require more blocks to get included with a given chance.
Note that the relationship between timeFactor and inclusion chance in future blocks is not exactly determined but depends on the market behavior. Some rough estimates for this relationship might be calculated once we have actual market data to analyze.
The application frontend might display the fees vs time factor as a bar graph or curve. The steepness of this curve might also give a hint to users on whether there is currently a local congestion.
The return value is an array that looks like this:
[
{ maxFeePerGas: 1026172753, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172752, maxPriorityFeePerGas: 1026172744 },
{ maxFeePerGas: 1026172751, maxPriorityFeePerGas: 1026172744 }
]
The first element corresponds to the highest time preference (most urgent transaction). The basic idea behind the algorithm is similar to the old "gas price oracle" used in Geth; it takes the prices of recent blocks and makes a suggestion based on a low percentile of those prices. With EIP-1559 though the base fee of each block provides a less noisy and more reliable price signal. This allows for more sophisticated suggestions with a variable width (exponentially weighted) base fee time window. The window width corresponds to the time preference of the user. The underlying assumption is that price fluctuations over a given past time period indicate the probabilty of similar price levels being re-tested by the market over a similar length future time period.
import { JsonRpcProvider } from '@ethersproject/providers';
import { suggestFees } from './src';
const main = async() => {
const provider = new JsonRpcProvider(`https://ropsten.infura.io/v3/${YOUR_API_KEY}`);
const ret = await suggestFees(provider);
console.log('Result');
console.log(ret);
console.log('done');
}
main();
Optional parameters are:
blockCountHistory
defaults to 100
sampleMin
defaults to 0.1
sampleMax
defaults to 0.3
maxTimeFactor
defaults to 15
extraTipRatio
defaults to 0.25
fallbackTip
defaults to 2e9
1 - Install deps via yarn
2 - Add your Infura API_KEY on demo.ts:4
3 - yarn start
This code is 100% based on the work of @zsfelfoldi published at https://github.com/zsfelfoldi/feehistory/
It only adds compatibility for ethers and some JS related minor changes.
FAQs
JavaScript library that suggest fees on Ethereum after EIP-1559 using historical data using ethers.js
We found that eip1559-fee-suggestions-ethers demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
Security News
Socket CEO Feross Aboukhadijeh discusses open source security challenges, including zero-day attacks and supply chain risks, on the Cyber Security Council podcast.
Security News
Research
Socket researchers uncover how threat actors weaponize Out-of-Band Application Security Testing (OAST) techniques across the npm, PyPI, and RubyGems ecosystems to exfiltrate sensitive data.