From 2751fee88907e47bbb0638b7c97caf53021eb234 Mon Sep 17 00:00:00 2001 From: Christophe Date: Thu, 27 Jun 2024 18:04:31 +0000 Subject: [PATCH] Feat: Add v1 SequencerInbox getters Closes FS-535 --- src/actions/getMaxTimeVariation.ts | 33 ++++++++++++++++++++++ src/actions/isBatchPoster.ts | 27 ++++++++++++++++++ src/actions/isValidKeysetHash.ts | 31 ++++++++++++++++++++ src/types/Actions.ts | 45 ++++++++++++++++++++++++++++++ 4 files changed, 136 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..617b8a1d --- /dev/null +++ b/src/actions/getMaxTimeVariation.ts @@ -0,0 +1,33 @@ +import { Chain, PublicClient, Transport } from 'viem'; +import { sequencerInbox } from '../contracts'; +import { ActionParameters } from '../types/Actions'; + +export type GetMaxTimeVariationParameters = ActionParameters< + {}, + 'sequencerInbox', + Curried +>; + +export type GetMaxTimeVariationReturnType = { + delayBlocks: bigint; + futureBlocks: bigint; + delaySeconds: bigint; + futureSeconds: bigint; +}; + +export async function getMaxTimeVariation( + client: PublicClient, + args: GetMaxTimeVariationParameters, +): 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..e878735a --- /dev/null +++ b/src/actions/isBatchPoster.ts @@ -0,0 +1,27 @@ +import { Address, Chain, PublicClient, ReadContractReturnType, Transport } from 'viem'; +import { sequencerInbox } from '../contracts'; +import { ActionParameters } from '../types/Actions'; + +type Args = { + batchPoster: Address; +}; +type SequencerInboxABI = typeof sequencerInbox.abi; +export type IsBatchPosterParameters = 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..b1896205 --- /dev/null +++ b/src/actions/isValidKeysetHash.ts @@ -0,0 +1,31 @@ +import { Chain, Hex, PublicClient, ReadContractReturnType, Transport } from 'viem'; +import { sequencerInbox } from '../contracts'; +import { ActionParameters } from '../types/Actions'; + +type Args = { + keysetHash: Hex; +}; +type SequencerInboxABI = typeof sequencerInbox.abi; + +export type IsValidKeysetHashParameters = 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; + } +>;