custom ​
The custom
Transport connects to a JSON-RPC API via custom. Wraps Viem's custom
Transport.
Import ​
ts
import { custom } from 'wagmi'
import { custom } from 'wagmi'
Usage ​
ts
import {
createConfig,
custom
} from 'wagmi'
import { mainnet } from 'wagmi/chains'
import { customRpc } from './rpc'
export const config = createConfig({
chains: [mainnet],
connectors: [injected()],
transports: {
[mainnet.id]: custom({
async request({ method, params }) {
const response = await customRpc.request(method, params)
return response
}
})
},
})
import {
createConfig,
custom
} from 'wagmi'
import { mainnet } from 'wagmi/chains'
import { customRpc } from './rpc'
export const config = createConfig({
chains: [mainnet],
connectors: [injected()],
transports: {
[mainnet.id]: custom({
async request({ method, params }) {
const response = await customRpc.request(method, params)
return response
}
})
},
})
Parameters ​
provider ​
{ request({ method: string, params: unknown[] }): Promise<unknown> }
An EIP-1193 request
function function.
ts
import { customRpc } from './rpc'
const transport = custom({
async request({ method, params }) {
const response = await customRpc.request(method, params)
return response
}
})
import { customRpc } from './rpc'
const transport = custom({
async request({ method, params }) {
const response = await customRpc.request(method, params)
return response
}
})
key (optional) ​
string
A key for the Transport. Defaults to "custom"
.
ts
const transport = custom(
provider,
{
key: 'windowProvider',
}
)
const transport = custom(
provider,
{
key: 'windowProvider',
}
)
name (optional) ​
string
A name for the Transport. Defaults to "Ethereum Provider"
.
ts
const transport = custom(
provider,
{
name: 'Window Ethereum Provider',
}
)
const transport = custom(
provider,
{
name: 'Window Ethereum Provider',
}
)
retryCount (optional) ​
number
The max number of times to retry when a request fails. Defaults to 3
.
ts
const transport = custom(provider, {
retryCount: 5,
})
const transport = custom(provider, {
retryCount: 5,
})
retryDelay (optional) ​
number
The base delay (in ms) between retries. By default, the Transport will use exponential backoff (~~(1 << count) * retryDelay
), which means the time between retries is not constant.
ts
const transport = custom(provider, {
retryDelay: 100,
})
const transport = custom(provider, {
retryDelay: 100,
})