From a2fbb9cfefc01a64e9bbf4ac36843b9264e505dd Mon Sep 17 00:00:00 2001 From: Trent Nelson Date: Thu, 29 Apr 2021 08:04:33 -0600 Subject: [PATCH] fix: optional stake lockup field parameters (#16943) * fix: optional stake lockup field parameters * chore: update web3.js/src/stake-program.ts Co-authored-by: Justin Starry * chore: prettier Co-authored-by: Justin Starry Co-authored-by: Justin Starry --- web3.js/src/publickey.ts | 5 +++++ web3.js/src/stake-program.ts | 14 ++++++++++---- web3.js/test/stake-program.test.ts | 1 - 3 files changed, 15 insertions(+), 5 deletions(-) diff --git a/web3.js/src/publickey.ts b/web3.js/src/publickey.ts index 487b5270be6cd7..66f5945066dab7 100644 --- a/web3.js/src/publickey.ts +++ b/web3.js/src/publickey.ts @@ -39,6 +39,11 @@ export class PublicKey { } } + /** + * Default public key value. (All zeros) + */ + static default: PublicKey = new PublicKey('11111111111111111111111111111111'); + /** * Checks if two publicKeys are equal */ diff --git a/web3.js/src/stake-program.ts b/web3.js/src/stake-program.ts index b97776e4fe53b9..7d7516f326bb95 100644 --- a/web3.js/src/stake-program.ts +++ b/web3.js/src/stake-program.ts @@ -59,6 +59,11 @@ export class Lockup { this.epoch = epoch; this.custodian = custodian; } + + /** + * Default, inactive Lockup value + */ + static default: Lockup = new Lockup(0, 0, PublicKey.default); } /** @@ -72,7 +77,7 @@ export type CreateStakeAccountParams = { /** Authorities of the new stake account */ authorized: Authorized; /** Lockup of the new stake account */ - lockup: Lockup; + lockup?: Lockup; /** Funding amount */ lamports: number; }; @@ -86,7 +91,7 @@ export type CreateStakeAccountWithSeedParams = { basePubkey: PublicKey; seed: string; authorized: Authorized; - lockup: Lockup; + lockup?: Lockup; lamports: number; }; @@ -96,7 +101,7 @@ export type CreateStakeAccountWithSeedParams = { export type InitializeStakeParams = { stakePubkey: PublicKey; authorized: Authorized; - lockup: Lockup; + lockup?: Lockup; }; /** @@ -502,7 +507,8 @@ export class StakeProgram { * Generate an Initialize instruction to add to a Stake Create transaction */ static initialize(params: InitializeStakeParams): TransactionInstruction { - const {stakePubkey, authorized, lockup} = params; + const {stakePubkey, authorized, lockup: maybeLockup} = params; + const lockup: Lockup = maybeLockup || Lockup.default; const type = STAKE_INSTRUCTION_LAYOUTS.Initialize; const data = encodeData(type, { authorized: { diff --git a/web3.js/test/stake-program.test.ts b/web3.js/test/stake-program.test.ts index 1788c384002d4f..7348f55ae0abb2 100644 --- a/web3.js/test/stake-program.test.ts +++ b/web3.js/test/stake-program.test.ts @@ -367,7 +367,6 @@ describe('StakeProgram', () => { authorized.publicKey, authorized.publicKey, ), - lockup: new Lockup(0, 0, new PublicKey(0)), lamports: minimumAmount + 42, });