From d14f602ad494b4b419516307271daf2e92c11a12 Mon Sep 17 00:00:00 2001 From: Christophe Date: Thu, 27 Jun 2024 17:38:48 +0000 Subject: [PATCH] Feat: Add v1 SequencerInbox getters Closes FS-535 --- src/actions/getMaxTimeVariation.ts | 35 +++++++++++++++++++++++ src/actions/isBatchPoster.ts | 32 +++++++++++++++++++++ src/actions/isValidKeysetHash.ts | 35 +++++++++++++++++++++++ src/types/Actions.ts | 45 ++++++++++++++++++++++++++++++ 4 files changed, 147 insertions(+) create mode 100644 src/actions/getMaxTimeVariation.ts create mode 100644 src/actions/isBatchPoster.ts create mode 100644 src/actions/isValidKeysetHash.ts create mode 100644 src/types/Actions.ts diff --git a/src/actions/getMaxTimeVariation.ts b/src/actions/getMaxTimeVariation.ts new file mode 100644 index 00000000..32b074f3 --- /dev/null +++ b/src/actions/getMaxTimeVariation.ts @@ -0,0 +1,35 @@ +import { Address, Chain, PublicClient, Transport } from 'viem'; +import { sequencerInbox } from '../contracts'; +import { ActionParameters } from '../types/Actions'; + +export type GetMaxTimeVariationActionParameters = ActionParameters< + {}, + 'sequencerInbox', + Curried +>; + +export type GetMaxTimeVariationReturnType = { + delayBlocks: bigint; + futureBlocks: bigint; + delaySeconds: bigint; + futureSeconds: bigint; +}; + +export async function getMaxTimeVariation( + client: PublicClient, + args: { + sequencerInbox: Address; + }, +): Promise { + const [delayBlocks, futureBlocks, delaySeconds, futureSeconds] = await client.readContract({ + abi: sequencerInbox.abi, + functionName: 'maxTimeVariation', + address: args.sequencerInbox, + }); + return { + delayBlocks, + futureBlocks, + delaySeconds, + futureSeconds, + }; +} diff --git a/src/actions/isBatchPoster.ts b/src/actions/isBatchPoster.ts new file mode 100644 index 00000000..bf4a24b6 --- /dev/null +++ b/src/actions/isBatchPoster.ts @@ -0,0 +1,32 @@ +import { Address, Chain, PublicClient, ReadContractReturnType, Transport } from 'viem'; +import { sequencerInbox } from '../contracts'; +import { ActionParameters, WithContractAddress } from '../types/Actions'; + +type Args = { + batchPoster: Address; +}; +type SequencerInboxABI = typeof sequencerInbox.abi; +type IsBatchPosterParameters = WithContractAddress< + Args, + 'sequencerInbox', + Curried +>; +export type IsBatchPosterActionParameters = ActionParameters< + Args, + 'sequencerInbox', + Curried +>; + +export type IsBatchPosterReturnType = ReadContractReturnType; + +export async function isBatchPoster( + client: PublicClient, + args: IsBatchPosterParameters, +): Promise { + return client.readContract({ + abi: sequencerInbox.abi, + functionName: 'isBatchPoster', + address: args.sequencerInbox, + args: [args.batchPoster], + }); +} diff --git a/src/actions/isValidKeysetHash.ts b/src/actions/isValidKeysetHash.ts new file mode 100644 index 00000000..20360a03 --- /dev/null +++ b/src/actions/isValidKeysetHash.ts @@ -0,0 +1,35 @@ +import { Chain, Hex, PublicClient, ReadContractReturnType, Transport } from 'viem'; +import { sequencerInbox } from '../contracts'; +import { ActionParameters, WithContractAddress } from '../types/Actions'; + +type Args = { + keysetHash: Hex; +}; +type SequencerInboxABI = typeof sequencerInbox.abi; +type IsValidKeysetHashParameters = WithContractAddress< + Args, + 'sequencerInbox', + Curried +>; +export type IsValidKeysetHashActionParameters = ActionParameters< + Args, + 'sequencerInbox', + Curried +>; + +export type IsValidKeysetHashReturnType = ReadContractReturnType< + SequencerInboxABI, + 'isValidKeysetHash' +>; + +export async function isValidKeysetHash( + client: PublicClient, + args: IsValidKeysetHashParameters, +): Promise { + return client.readContract({ + abi: sequencerInbox.abi, + functionName: 'isValidKeysetHash', + address: args.sequencerInbox, + args: [args.keysetHash], + }); +} diff --git a/src/types/Actions.ts b/src/types/Actions.ts new file mode 100644 index 00000000..b7ef6542 --- /dev/null +++ b/src/types/Actions.ts @@ -0,0 +1,45 @@ +import { Address } from 'viem'; +import { Prettify } from './utils'; + +type RemoveUndefinedArgs = T extends { args?: undefined } ? Omit : T; + +/** + * If the function has no args, `GetFunctionArgs` returns `{ args?: undefined }` + * we remove args from the returned type + * + * Contract address is required if no contract address was passed to the actions, otherwise it's optional + */ +export type WithContractAddress< + Args, + ContractName extends string, + Curried extends boolean = false, +> = Prettify< + RemoveUndefinedArgs< + Args & + (Curried extends true + ? { + [key in ContractName]?: Address; + } + : { [key in ContractName]: Address }) + > +>; + +/** + * Actions require contract address, but as part of decorators, the address might have been passed already to the decorator. + * + * If the address was passed to the decorator, it's now optional (we still allow overrides of the address per action). + * If the action doesn't have any other parameters beside the contract address, then parameters can either be { contract: address } or void + */ +export type ActionParameters = Prettify< + Curried extends false + ? RemoveUndefinedArgs + : Args extends { args?: undefined } + ? + | { + [key in ContractName]: Address; + } + | void + : Args & { + [key in ContractName]?: Address; + } +>;