/** * This code was AUTOGENERATED using the Codama library. * Please DO NOT EDIT THIS FILE, instead use visitors * to add features, then rerun Codama to update it. * * @see https://github.com/codama-idl/codama */ import { AccountRole, combineCodec, getStructDecoder, getStructEncoder, getU8Decoder, getU8Encoder, transformEncoder, type AccountMeta, type AccountSignerMeta, type Address, type FixedSizeCodec, type FixedSizeDecoder, type FixedSizeEncoder, type Instruction, type InstructionWithAccounts, type InstructionWithData, type ReadonlyAccount, type ReadonlySignerAccount, type ReadonlyUint8Array, type TransactionSigner, type WritableAccount, } from '@solana/kit'; import { TOKEN_PROGRAM_ADDRESS } from '../programs'; import { getAccountMetaFactory, type ResolvedAccount } from '../shared'; export const CLOSE_ACCOUNT_DISCRIMINATOR = 9; export function getCloseAccountDiscriminatorBytes() { return getU8Encoder().encode(CLOSE_ACCOUNT_DISCRIMINATOR); } export type CloseAccountInstruction< TProgram extends string = typeof TOKEN_PROGRAM_ADDRESS, TAccountAccount extends string | AccountMeta = string, TAccountDestination extends string | AccountMeta = string, TAccountOwner extends string | AccountMeta = string, TRemainingAccounts extends readonly AccountMeta[] = [], > = Instruction & InstructionWithData & InstructionWithAccounts< [ TAccountAccount extends string ? WritableAccount : TAccountAccount, TAccountDestination extends string ? WritableAccount : TAccountDestination, TAccountOwner extends string ? ReadonlyAccount : TAccountOwner, ...TRemainingAccounts, ] >; export type CloseAccountInstructionData = { discriminator: number }; export type CloseAccountInstructionDataArgs = {}; export function getCloseAccountInstructionDataEncoder(): FixedSizeEncoder { return transformEncoder( getStructEncoder([['discriminator', getU8Encoder()]]), (value) => ({ ...value, discriminator: CLOSE_ACCOUNT_DISCRIMINATOR }) ); } export function getCloseAccountInstructionDataDecoder(): FixedSizeDecoder { return getStructDecoder([['discriminator', getU8Decoder()]]); } export function getCloseAccountInstructionDataCodec(): FixedSizeCodec< CloseAccountInstructionDataArgs, CloseAccountInstructionData > { return combineCodec( getCloseAccountInstructionDataEncoder(), getCloseAccountInstructionDataDecoder() ); } export type CloseAccountInput< TAccountAccount extends string = string, TAccountDestination extends string = string, TAccountOwner extends string = string, > = { /** The account to close. */ account: Address; /** The destination account. */ destination: Address; /** The account's owner or its multisignature account. */ owner: Address | TransactionSigner; multiSigners?: Array; }; export function getCloseAccountInstruction< TAccountAccount extends string, TAccountDestination extends string, TAccountOwner extends string, TProgramAddress extends Address = typeof TOKEN_PROGRAM_ADDRESS, >( input: CloseAccountInput, config?: { programAddress?: TProgramAddress } ): CloseAccountInstruction< TProgramAddress, TAccountAccount, TAccountDestination, (typeof input)['owner'] extends TransactionSigner ? ReadonlySignerAccount & AccountSignerMeta : TAccountOwner > { // Program address. const programAddress = config?.programAddress ?? TOKEN_PROGRAM_ADDRESS; // Original accounts. const originalAccounts = { account: { value: input.account ?? null, isWritable: true }, destination: { value: input.destination ?? null, isWritable: true }, owner: { value: input.owner ?? null, isWritable: false }, }; const accounts = originalAccounts as Record< keyof typeof originalAccounts, ResolvedAccount >; // Original args. const args = { ...input }; // Remaining accounts. const remainingAccounts: AccountMeta[] = (args.multiSigners ?? []).map( (signer) => ({ address: signer.address, role: AccountRole.READONLY_SIGNER, signer, }) ); const getAccountMeta = getAccountMetaFactory(programAddress, 'programId'); return Object.freeze({ accounts: [ getAccountMeta(accounts.account), getAccountMeta(accounts.destination), getAccountMeta(accounts.owner), ...remainingAccounts, ], data: getCloseAccountInstructionDataEncoder().encode({}), programAddress, } as CloseAccountInstruction< TProgramAddress, TAccountAccount, TAccountDestination, (typeof input)['owner'] extends TransactionSigner ? ReadonlySignerAccount & AccountSignerMeta : TAccountOwner >); } export type ParsedCloseAccountInstruction< TProgram extends string = typeof TOKEN_PROGRAM_ADDRESS, TAccountMetas extends readonly AccountMeta[] = readonly AccountMeta[], > = { programAddress: Address; accounts: { /** The account to close. */ account: TAccountMetas[0]; /** The destination account. */ destination: TAccountMetas[1]; /** The account's owner or its multisignature account. */ owner: TAccountMetas[2]; }; data: CloseAccountInstructionData; }; export function parseCloseAccountInstruction< TProgram extends string, TAccountMetas extends readonly AccountMeta[], >( instruction: Instruction & InstructionWithAccounts & InstructionWithData ): ParsedCloseAccountInstruction { if (instruction.accounts.length < 3) { // TODO: Coded error. throw new Error('Not enough accounts'); } let accountIndex = 0; const getNextAccount = () => { const accountMeta = (instruction.accounts as TAccountMetas)[accountIndex]!; accountIndex += 1; return accountMeta; }; return { programAddress: instruction.programAddress, accounts: { account: getNextAccount(), destination: getNextAccount(), owner: getNextAccount(), }, data: getCloseAccountInstructionDataDecoder().decode(instruction.data), }; }