UNPKG

viem

Version:

TypeScript Interface for Ethereum

61 lines 2.85 kB
import type { Client } from '../../clients/createClient.js'; import type { Transport } from '../../clients/transports/createTransport.js'; import type { ErrorType } from '../../errors/utils.js'; import type { Account } from '../../types/account.js'; import type { Chain, DeriveChain, GetChainParameter } from '../../types/chain.js'; import type { GetContractAddressParameter } from '../types/contract.js'; import { type GetGamesErrorType } from './getGames.js'; export type GetTimeToNextGameParameters<chain extends Chain | undefined = Chain | undefined, chainOverride extends Chain | undefined = Chain | undefined, _derivedChain extends Chain | undefined = DeriveChain<chain, chainOverride>> = GetChainParameter<chain, chainOverride> & GetContractAddressParameter<_derivedChain, 'portal' | 'disputeGameFactory'> & { /** * The buffer to account for discrepancies between non-deterministic time intervals. * @default 1.1 */ intervalBuffer?: number | undefined; /** * The minimum L2 block number of the next game. */ l2BlockNumber: bigint; }; export type GetTimeToNextGameReturnType = { /** The estimated interval (in seconds) between L2 dispute games. */ interval: number; /** * Estimated seconds until the next L2 dispute game. * `0` if the next L2 dispute game has already been submitted. */ seconds: number; /** * Estimated timestamp of the next L2 dispute game. * `undefined` if the next L2 dispute game has already been submitted. */ timestamp?: number | undefined; }; export type GetTimeToNextGameErrorType = GetGamesErrorType | ErrorType; /** * Returns the time until the next L2 dispute game (after the provided block number) is submitted. * Used for the [Withdrawal](/op-stack/guides/withdrawals) flow. * * - Docs: https://viem.sh/op-stack/actions/getTimeToNextGame * * @param client - Client to use * @param parameters - {@link GetTimeToNextGameParameters} * @returns The L2 transaction hash. {@link GetTimeToNextGameReturnType} * * @example * import { createPublicClient, http } from 'viem' * import { getBlockNumber } from 'viem/actions' * import { mainnet, optimism } from 'viem/chains' * import { getTimeToNextGame } from 'viem/op-stack' * * const publicClientL1 = createPublicClient({ * chain: mainnet, * transport: http(), * }) * * const { seconds } = await getTimeToNextGame(publicClientL1, { * l2BlockNumber: 113405763n, * targetChain: optimism * }) */ export declare function getTimeToNextGame<chain extends Chain | undefined, account extends Account | undefined, chainOverride extends Chain | undefined = undefined>(client: Client<Transport, chain, account>, parameters: GetTimeToNextGameParameters<chain, chainOverride>): Promise<GetTimeToNextGameReturnType>; //# sourceMappingURL=getTimeToNextGame.d.ts.map