BaseClient
BaseClient<
TMode,TExtended>:object&EIP1193EventEmitter&TExtended
The base client used by Tevm. Add extensions to add additional functionality
Type declaration
extend()
readonlyextend: <TExtension>(decorator) =>BaseClient<TMode,TExtended&TExtension>
Extends the base client with additional functionality. This enables optimal code splitting and extensibility
Type parameters
• TExtension extends Record<string, any>
Parameters
• decorator
Returns
BaseClient<TMode, TExtended & TExtension>
forkTransport?
optionalreadonlyforkTransport:object
Client to make json rpc requests to a forked node
Example
const client = createMemoryClient({ request: eip1193RequestFn })forkTransport.request
request:
EIP1193RequestFn
getFilters()
Gets all registered filters mapped by id
Returns
getImpersonatedAccount()
readonlygetImpersonatedAccount: () =>Address|undefined
The currently impersonated account. This is only used in fork mode
Returns
Address | undefined
getReceiptsManager()
readonlygetReceiptsManager: () =>Promise<ReceiptsManager>
Interface for querying receipts and historical state
Returns
Promise<ReceiptsManager>
getTxPool()
readonlygetTxPool: () =>Promise<TxPool>
Gets the pool of pending transactions to be included in next block
Returns
Promise<TxPool>
getVm()
readonlygetVm: () =>Promise<Vm>
Internal instance of the VM. Can be used for lower level operations. Normally not recomended to use unless building libraries or extensions on top of Tevm.
Returns
Promise<Vm>
logger
readonlylogger:Logger
The logger instance
miningConfig
readonlyminingConfig:MiningConfig
The configuration for mining. Defaults to ‘auto'
- 'auto’ will mine a block on every transaction
- ’interval’ will mine a block every
intervalmilliseconds - ’manual’ will not mine a block automatically and requires a manual call to
mineBlock
mode
readonlymode:TMode
The mode the current client is running in
fork mode will fetch and cache all state from the block forked from the provided URL
normal mode will not fetch any state and will only run the EVM in memory
Example
let client = createMemoryClient()console.log(client.mode) // 'normal'client = createMemoryClient({ forkUrl: 'https://mainnet.infura.io/v3/your-api-key' })console.log(client.mode) // 'fork'ready()
readonlyready: () =>Promise<true>
Returns promise that resulves when the client is ready The client is usable without calling this method but may have extra latency on the first call from initialization
Example
const client = createMemoryClient()await client.ready()Returns
Promise<true>
removeFilter()
readonlyremoveFilter: (id) =>void
Removes a filter by id
Parameters
• id: Hex
Returns
void
setFilter()
readonlysetFilter: (filter) =>void
Creates a new filter to watch for logs events and blocks
Parameters
• filter: Filter
Returns
void
setImpersonatedAccount()
readonlysetImpersonatedAccount: (address) =>void
Sets the account to impersonate. This will allow the client to act as if it is that account On Ethereum JSON_RPC endpoints. Pass in undefined to stop impersonating
Parameters
• address: Address | undefined
Returns
void
Type parameters
• TMode extends "fork" | "normal" = "fork" | "normal"
• TExtended = object
Source
packages/base-client/src/BaseClient.ts:14