UNPKG

viem

Version:

TypeScript Interface for Ethereum

168 lines (158 loc) • 4.87 kB
import type { Address } from 'abitype' import type { Block, BlockIdentifier, BlockNumber, BlockTag, Uncle, } from './block.js' import type { FeeHistory, FeeValues } from './fee.js' import type { Log } from './log.js' import type { Hex } from './misc.js' import type { Proof } from './proof.js' import type { TransactionEIP1559, TransactionEIP2930, TransactionEIP4844, TransactionEIP7702, TransactionLegacy, TransactionReceipt, TransactionRequestEIP1559, TransactionRequestEIP2930, TransactionRequestEIP4844, TransactionRequestEIP7702, TransactionRequestLegacy, } from './transaction.js' import type { Omit, OneOf, PartialBy } from './utils.js' export type Index = `0x${string}` export type Quantity = `0x${string}` export type Status = '0x0' | '0x1' export type TransactionType = | '0x0' | '0x1' | '0x2' | '0x3' | '0x4' | (string & {}) export type RpcAuthorization = { /** Address of the contract to set as code for the Authority. */ address: Address /** Chain ID to authorize. */ chainId: Hex /** Nonce of the Authority to authorize. */ nonce: Hex /** ECDSA r value. */ r: Hex /** ECDSA s value. */ s: Hex /** y parity. */ yParity: Hex } export type RpcAuthorizationList = readonly RpcAuthorization[] export type RpcBlock< blockTag extends BlockTag = BlockTag, includeTransactions extends boolean = boolean, transaction = RpcTransaction<blockTag extends 'pending' ? true : false>, > = Block<Quantity, includeTransactions, blockTag, transaction> export type RpcBlockNumber = BlockNumber<Quantity> export type RpcBlockIdentifier = BlockIdentifier<Quantity> export type RpcUncle = Uncle<Quantity> export type RpcFeeHistory = FeeHistory<Quantity> export type RpcFeeValues = FeeValues<Quantity> export type RpcLog = Log<Quantity, Index> export type RpcProof = Proof<Quantity, Index> export type RpcTransactionReceipt = TransactionReceipt< Quantity, Index, Status, TransactionType > export type RpcTransactionRequest = OneOf< | TransactionRequestLegacy<Quantity, Index, '0x0'> | TransactionRequestEIP2930<Quantity, Index, '0x1'> | TransactionRequestEIP1559<Quantity, Index, '0x2'> | TransactionRequestEIP4844<Quantity, Index, '0x3'> | (Omit< TransactionRequestEIP7702<Quantity, Index, '0x4'>, 'authorizationList' > & { authorizationList?: RpcAuthorizationList | undefined }) > // `yParity` is optional on the RPC type as some nodes do not return it // for 1559 & 2930 transactions (they should!). export type RpcTransaction<pending extends boolean = boolean> = OneOf< | Omit<TransactionLegacy<Quantity, Index, pending, '0x0'>, 'typeHex'> | PartialBy< Omit<TransactionEIP2930<Quantity, Index, pending, '0x1'>, 'typeHex'>, 'yParity' > | PartialBy< Omit<TransactionEIP1559<Quantity, Index, pending, '0x2'>, 'typeHex'>, 'yParity' > | PartialBy< Omit<TransactionEIP4844<Quantity, Index, pending, '0x3'>, 'typeHex'>, 'yParity' > | PartialBy< Omit< TransactionEIP7702<Quantity, Index, pending, '0x4'>, 'authorizationList' | 'typeHex' > & { authorizationList?: RpcAuthorizationList | undefined }, 'yParity' > > type SuccessResult<result> = { method?: undefined result: result error?: undefined } type ErrorResult<error> = { method?: undefined result?: undefined error: error } type Subscription<result, error> = { method: 'eth_subscription' error?: undefined result?: undefined params: | { subscription: string result: result error?: undefined } | { subscription: string result?: undefined error: error } } export type RpcRequest = { jsonrpc?: '2.0' | undefined method: string params?: any | undefined id?: number | undefined } export type RpcResponse<result = any, error = any> = { jsonrpc: `${number}` id: number } & (SuccessResult<result> | ErrorResult<error> | Subscription<result, error>) /** A key-value mapping of slot and storage values (supposedly 32 bytes each) */ export type RpcStateMapping = { [slots: Hex]: Hex } export type RpcAccountStateOverride = { /** Fake balance to set for the account before executing the call. <32 bytes */ balance?: Hex | undefined /** Fake nonce to set for the account before executing the call. <8 bytes */ nonce?: Hex | undefined /** Fake EVM bytecode to inject into the account before executing the call. */ code?: Hex | undefined /** Fake key-value mapping to override all slots in the account storage before executing the call. */ state?: RpcStateMapping | undefined /** Fake key-value mapping to override individual slots in the account storage before executing the call. */ stateDiff?: RpcStateMapping | undefined } export type RpcStateOverride = { [address: Address]: RpcAccountStateOverride }