UNPKG

viem

Version:

TypeScript Interface for Ethereum

52 lines (48 loc) 1.56 kB
import type { Account } from '../../accounts/types.js' import type { Client } from '../../clients/createClient.js' import type { Transport } from '../../clients/transports/createTransport.js' import type { ErrorType } from '../../errors/utils.js' import type { Chain } from '../../types/chain.js' import type { RequestErrorType } from '../../utils/buildRequest.js' import { type HexToNumberErrorType, hexToNumber, } from '../../utils/encoding/fromHex.js' export type GetChainIdReturnType = number export type GetChainIdErrorType = | HexToNumberErrorType | RequestErrorType | ErrorType /** * Returns the chain ID associated with the current network. * * - Docs: https://viem.sh/docs/actions/public/getChainId * - JSON-RPC Methods: [`eth_chainId`](https://ethereum.org/en/developers/docs/apis/json-rpc/#eth_chainid) * * @param client - Client to use * @returns The current chain ID. {@link GetChainIdReturnType} * * @example * import { createPublicClient, http } from 'viem' * import { mainnet } from 'viem/chains' * import { getChainId } from 'viem/public' * * const client = createPublicClient({ * chain: mainnet, * transport: http(), * }) * const chainId = await getChainId(client) * // 1 */ export async function getChainId< chain extends Chain | undefined, account extends Account | undefined, >(client: Client<Transport, chain, account>): Promise<GetChainIdReturnType> { const chainIdHex = await client.request( { method: 'eth_chainId', }, { dedupe: true }, ) return hexToNumber(chainIdHex) }