From fa789d90ddb2bbf0f112d56ca05104233233fe4c Mon Sep 17 00:00:00 2001 From: Matthew M <62824345+mmackz@users.noreply.github.com> Date: Tue, 19 Nov 2024 08:34:03 -0800 Subject: [PATCH] [ADHOC] feat(cli): allow Validator to be optional in seed (#277) --- .changeset/real-suns-explode.md | 5 +++++ packages/cli/src/commands/seed.ts | 29 +++++++++++++++++------------ 2 files changed, 22 insertions(+), 12 deletions(-) create mode 100644 .changeset/real-suns-explode.md diff --git a/.changeset/real-suns-explode.md b/.changeset/real-suns-explode.md new file mode 100644 index 00000000..7e03d0f6 --- /dev/null +++ b/.changeset/real-suns-explode.md @@ -0,0 +1,5 @@ +--- +"@boostxyz/cli": minor +--- + +Make Validator and Allowlist optional in boost seed diff --git a/packages/cli/src/commands/seed.ts b/packages/cli/src/commands/seed.ts index 63ad0223..803cb1e1 100644 --- a/packages/cli/src/commands/seed.ts +++ b/packages/cli/src/commands/seed.ts @@ -9,6 +9,7 @@ import { BoostRegistry, type Budget, type CGDAIncentivePayload, + type CreateBoostPayload, type DeployablePayloadOrAddress, type ERC20IncentivePayload, type ERC20VariableCriteriaIncentivePayload, @@ -75,6 +76,7 @@ export const seed: Command = async function seed( if (positionals.at(0) === 'erc20') { let erc20 = new MockERC20({ config, account }, {}); + // @ts-expect-error await erc20.deploy(); return { erc20: erc20.assertValidAddress(), @@ -183,16 +185,20 @@ export const seed: Command = async function seed( const incentives = await Promise.all(incentivePromises); - const boost = await core.createBoost({ + const boostConfig: CreateBoostPayload = { protocolFee: template.protocolFee, maxParticipants: template.maxParticipants, budget: budget, - action: core.EventAction(template.action as EventActionPayload), - validator: core.SignerValidator(template.validator), + action: core.EventAction(template.action), allowList: await getAllowList(template, { core }), - // biome-ignore lint/suspicious/noExplicitAny: - incentives: incentives as any[], - }); + incentives, + }; + + if (template.validator) { + boostConfig.validator = core.SignerValidator(template.validator); + } + + const boost = await core.createBoost(boostConfig); boostIds.push(boost.id.toString()); } @@ -413,12 +419,10 @@ export const BoostSeedConfigSchema = z.object({ maxParticipants: z.coerce.bigint(), budget: z.union([AddressSchema, ManagedBudgetSchema]), action: z.union([AddressSchema, EventActionSchema]), - validator: z.union([AddressSchema, SignerValidatorSchema]), - allowList: z.union([ - AddressSchema, - SimpleDenyListSchema, - SimpleAllowListSchema, - ]), + validator: z.union([AddressSchema, SignerValidatorSchema]).optional(), + allowList: z + .union([AddressSchema, SimpleDenyListSchema, SimpleAllowListSchema]) + .optional(), incentives: z.array( z.union([ AllowListIncentiveSchema, @@ -435,6 +439,7 @@ async function getAllowList( { allowList }: z.infer, { core }: { core: BoostCore }, ): Promise { + if (!allowList) return core.OpenAllowList(); if (typeof allowList === 'string' && isAddress(allowList)) return await allowListFromAddress( //@ts-expect-error i do what i want