Gathering detailed insights and metrics for eth-block-tracker
Gathering detailed insights and metrics for eth-block-tracker
Gathering detailed insights and metrics for eth-block-tracker
Gathering detailed insights and metrics for eth-block-tracker
eth-json-rpc-filters
[json-rpc-engine](https://github.com/MetaMask/json-rpc-engine) middleware implementing ethereum filter methods. Backed by an [eth-block-tracker](https://github.com/MetaMask/eth-block-tracker) and web3 provider interface (`web3.currentProvider`).
@metamask/eth-json-rpc-filters
[json-rpc-engine](https://github.com/MetaMask/json-rpc-engine) middleware implementing ethereum filter methods. Backed by an [eth-block-tracker](https://github.com/MetaMask/eth-block-tracker) and web3 provider interface (`web3.currentProvider`).
@metamask/eth-block-tracker
A block tracker for the Ethereum blockchain. Keeps track of the latest block.
eth-block-tracker-es5
This module walks the Ethereum blockchain, keeping track of the latest block. It uses a web3 provider as a data source and will continuously poll for the next block.
A JS module for keeping track of the latest Ethereum block by polling an ethereum provider
npm install eth-block-tracker
Module System
Min. Node Version
Typescript Support
Node Version
NPM Version
131 Stars
295 Commits
81 Forks
50 Watching
9 Branches
277 Contributors
Updated on 25 Nov 2024
TypeScript (99.42%)
JavaScript (0.58%)
Cumulative downloads
Total Downloads
Last day
2.4%
61,040
Compared to previous day
Last week
12%
341,726
Compared to previous week
Last month
1.9%
1,342,684
Compared to previous month
Last year
-10.7%
15,895,534
Compared to previous year
5
29
This module walks the Ethereum blockchain, keeping track of the latest block. It uses a web3 provider as a data source and will continuously poll for the next block.
yarn add @metamask/eth-block-tracker
or
npm install @metamask/eth-block-tracker
1const createInfuraProvider = require('@metamask/eth-json-rpc-infura'); 2const { PollingBlockTracker } = require('@metamask/eth-block-tracker'); 3 4const provider = createInfuraProvider({ 5 network: 'mainnet', 6 projectId: process.env.INFURA_PROJECT_ID, 7}); 8const blockTracker = new PollingBlockTracker({ provider }); 9 10blockTracker.on('sync', ({ newBlock, oldBlock }) => { 11 if (oldBlock) { 12 console.log(`sync #${Number(oldBlock)} -> #${Number(newBlock)}`); 13 } else { 14 console.log(`first sync #${Number(newBlock)}`); 15 } 16});
provider
as a data source and pollingInterval
(ms) timeout between polling for the latest block.retryTimeout
(ms) before attempting again.keepEventLoopActive
is false
, in Node.js it will unref the polling timeout, allowing the process to exit during the polling interval. Defaults to true
, meaning the process will be kept alive.usePastBlocks
is true
, block numbers less than the current block number can used and emitted. Defaults to false
, meaning that only block numbers greater than the current block number will be used and emitted.Synchronously returns the current block. May be null
.
1console.log(blockTracker.getCurrentBlock());
Asynchronously returns the latest block. if not immediately available, it will fetch one.
Tells the block tracker to ask for a new block immediately, in addition to its normal polling interval. Useful if you received a hint of a new block (e.g. via tx.blockNumber
from getTransactionByHash
). Will resolve to the new latest block when done polling.
The latest
event is emitted for whenever a new latest block is detected. This may mean skipping blocks if there were two created since the last polling period.
1blockTracker.on('latest', (newBlock) => console.log(newBlock));
The sync
event is emitted the same as "latest" but includes the previous block.
1blockTracker.on('sync', ({ newBlock, oldBlock }) => 2 console.log(newBlock, oldBlock), 3);
The error
event means an error occurred while polling for the latest block.
1blockTracker.on('error', (err) => console.error(err));
nvm use
will automatically choose the right node version for you.yarn setup
to install dependencies and run any requried post-install scripts
yarn
/ yarn install
command directly. Use yarn setup
instead. The normal install command will skip required post-install scripts, leaving your development environment in an invalid state.Run yarn test
to run the tests once. To run tests on file changes, run yarn test:watch
.
Run yarn lint
to run the linter, or run yarn lint:fix
to run the linter and fix any automatically fixable issues.
The project follows the same release process as the other libraries in the MetaMask organization. The GitHub Actions action-create-release-pr
and action-publish-release
are used to automate the release process; see those repositories for more information about how they work.
Choose a release version.
If this release is backporting changes onto a previous release, then ensure there is a major version branch for that version (e.g. 1.x
for a v1
backport release).
v1.0.2
release, you'd want to ensure there was a 1.x
branch that was set to the v1.0.1
tag.Trigger the workflow_dispatch
event manually for the Create Release Pull Request
action to create the release PR.
action-create-release-pr
workflow to create the release PR.Update the changelog to move each change entry into the appropriate change category (See here for the full list of change categories, and the correct ordering), and edit them to be more easily understood by users of the package.
yarn auto-changelog validate --rc
to check that the changelog is correctly formatted.Review and QA the release.
Squash & Merge the release.
action-publish-release
workflow to tag the final release commit and publish the release on GitHub.Publish the release on npm.
npm publish --dry-run
to examine the release contents to ensure the correct files are included. Compare to previous releases if necessary (e.g. using https://unpkg.com/browse/[package name]@[package version]/
).npm publish
.No vulnerabilities found.
Reason
all changesets reviewed
Reason
no binaries found in the repo
Reason
no dangerous workflow patterns detected
Reason
license file detected
Details
Reason
security policy file detected
Details
Reason
SAST tool is not run on all commits -- score normalized to 6
Details
Reason
4 existing vulnerabilities detected
Details
Reason
branch protection is not maximal on development and all release branches
Details
Reason
4 commit(s) and 1 issue activity found in the last 90 days -- score normalized to 4
Reason
dependency not pinned by hash detected -- score normalized to 0
Details
Reason
detected GitHub workflow tokens with excessive permissions
Details
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
project is not fuzzed
Details
Score
Last Scanned on 2024-11-25
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More