Helper module for getting Ethereum chains info from chainid.network.
yarn add @bdtren/eth-chains
npm install @bdtren/eth-chains
@bdtren/eth-chains
uses a weekly automated release script that updates its chain data. This release script takes breaking changes into account, so breaking changes (e.g. renamed chains) are released as a new major version, while non-breaking changes (e.g. new chains) are released as a new minor version.
Import chains
methods and enums:
import chains, { ChainId, ChainName } from '@bdtren/eth-chains'
import { chain } from '@bdtren/eth-chains'
console.log(chain.ethereum.rinkeby)
console.log(chain.polygon.mumbai)
console.log(ChainId.EthereumMainnet) // 1
console.log(ChainId.BinanceSmartChainMainnet) // 56
console.log(ChainName.EthereumMainnet) // "Ethereum Mainnet"
console.log(ChainName.Rinkeby) // "Rinkeby"
chains.getById(ChainId.EthereumMainnet) // { name: "Ethereum Mainnet", ..., "infoURL": "https://ethereum.org" }
// Equivalent
chains.getById(1)
chains.getByName(ChainName.EthereumMainnet) // { name: "Ethereum Mainnet", ..., "infoURL": "https://ethereum.org" }
// Equivalent
chains.getByName('Ethereum Mainnet')
const allChains = chains.all()
// { 1: { name: "Ethereum Mainnet", ..., "infoURL": "https://ethereum.org" }, 2: {...}}
const allChains = chains.allIcons()
// { "5ireChain": { data: [...], imgUrls: ["https://ipfs.io/ipfs/QmaZDNDFLWESH4i3XqwEWfWBb1HPnQSNbDAr74nr2x8QAk"] }, "ETND": {...}}
chains.getIconByName("ethereum") // { data: [...], imgUrls: ["https://ipfs.io/ipfs/QmdwQDr6vmBtXmK2TmknkEuZNoaDqTasFdZdu3DRw8b2wt"] }
import { Chain, NativeCurrency, Explorer } from '@bdtren/eth-chains'
const ethereum: Chain = chains.getById(ChainId.EthereumMainnet)
ethereum.chain // 'ETH'
TODO:
- Add webhook that watches the chains repo and triggers an update to this package whenever that repo gets updated
- Add check in the deploy script to make sure that the types are correct before publishing
- Add Tests
- Once quicktype is added, test with different chains.json objects to make sure it can handle new types
- Use quicktype to autogen types from json
- Autogen Chain Id enum
- Autogen Chain Name enum