UNPKG

@kamino-finance/farms-sdk

Version:
201 lines (185 loc) 6.12 kB
/** * 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 { combineCodec, fixDecoderSize, fixEncoderSize, getBytesDecoder, getBytesEncoder, getStructDecoder, getStructEncoder, transformEncoder, type AccountMeta, type Address, type FixedSizeCodec, type FixedSizeDecoder, type FixedSizeEncoder, type Instruction, type InstructionWithAccounts, type InstructionWithData, type ReadonlyAccount, type ReadonlyUint8Array, type WritableAccount, } from "@solana/kit"; import { FARMS_PROGRAM_ADDRESS } from "../programs"; import { getAccountMetaFactory, type ResolvedAccount } from "../shared"; export const REFRESH_USER_STATE_DISCRIMINATOR = new Uint8Array([ 1, 135, 12, 62, 243, 140, 77, 108, ]); export function getRefreshUserStateDiscriminatorBytes() { return fixEncoderSize(getBytesEncoder(), 8).encode( REFRESH_USER_STATE_DISCRIMINATOR, ); } export type RefreshUserStateInstruction< TProgram extends string = typeof FARMS_PROGRAM_ADDRESS, TAccountUserState extends string | AccountMeta<string> = string, TAccountFarmState extends string | AccountMeta<string> = string, TAccountScopePrices extends string | AccountMeta<string> = string, TRemainingAccounts extends readonly AccountMeta<string>[] = [], > = Instruction<TProgram> & InstructionWithData<ReadonlyUint8Array> & InstructionWithAccounts< [ TAccountUserState extends string ? WritableAccount<TAccountUserState> : TAccountUserState, TAccountFarmState extends string ? WritableAccount<TAccountFarmState> : TAccountFarmState, TAccountScopePrices extends string ? ReadonlyAccount<TAccountScopePrices> : TAccountScopePrices, ...TRemainingAccounts, ] >; export type RefreshUserStateInstructionData = { discriminator: ReadonlyUint8Array; }; export type RefreshUserStateInstructionDataArgs = {}; export function getRefreshUserStateInstructionDataEncoder(): FixedSizeEncoder<RefreshUserStateInstructionDataArgs> { return transformEncoder( getStructEncoder([["discriminator", fixEncoderSize(getBytesEncoder(), 8)]]), (value) => ({ ...value, discriminator: REFRESH_USER_STATE_DISCRIMINATOR }), ); } export function getRefreshUserStateInstructionDataDecoder(): FixedSizeDecoder<RefreshUserStateInstructionData> { return getStructDecoder([ ["discriminator", fixDecoderSize(getBytesDecoder(), 8)], ]); } export function getRefreshUserStateInstructionDataCodec(): FixedSizeCodec< RefreshUserStateInstructionDataArgs, RefreshUserStateInstructionData > { return combineCodec( getRefreshUserStateInstructionDataEncoder(), getRefreshUserStateInstructionDataDecoder(), ); } export type RefreshUserStateInput< TAccountUserState extends string = string, TAccountFarmState extends string = string, TAccountScopePrices extends string = string, > = { userState: Address<TAccountUserState>; farmState: Address<TAccountFarmState>; scopePrices?: Address<TAccountScopePrices>; }; export function getRefreshUserStateInstruction< TAccountUserState extends string, TAccountFarmState extends string, TAccountScopePrices extends string, TProgramAddress extends Address = typeof FARMS_PROGRAM_ADDRESS, >( input: RefreshUserStateInput< TAccountUserState, TAccountFarmState, TAccountScopePrices >, config?: { programAddress?: TProgramAddress }, ): RefreshUserStateInstruction< TProgramAddress, TAccountUserState, TAccountFarmState, TAccountScopePrices > { // Program address. const programAddress = config?.programAddress ?? FARMS_PROGRAM_ADDRESS; // Original accounts. const originalAccounts = { userState: { value: input.userState ?? null, isWritable: true }, farmState: { value: input.farmState ?? null, isWritable: true }, scopePrices: { value: input.scopePrices ?? null, isWritable: false }, }; const accounts = originalAccounts as Record< keyof typeof originalAccounts, ResolvedAccount >; const getAccountMeta = getAccountMetaFactory(programAddress, "programId"); return Object.freeze({ accounts: [ getAccountMeta(accounts.userState), getAccountMeta(accounts.farmState), getAccountMeta(accounts.scopePrices), ], data: getRefreshUserStateInstructionDataEncoder().encode({}), programAddress, } as RefreshUserStateInstruction< TProgramAddress, TAccountUserState, TAccountFarmState, TAccountScopePrices >); } export type ParsedRefreshUserStateInstruction< TProgram extends string = typeof FARMS_PROGRAM_ADDRESS, TAccountMetas extends readonly AccountMeta[] = readonly AccountMeta[], > = { programAddress: Address<TProgram>; accounts: { userState: TAccountMetas[0]; farmState: TAccountMetas[1]; scopePrices?: TAccountMetas[2] | undefined; }; data: RefreshUserStateInstructionData; }; export function parseRefreshUserStateInstruction< TProgram extends string, TAccountMetas extends readonly AccountMeta[], >( instruction: Instruction<TProgram> & InstructionWithAccounts<TAccountMetas> & InstructionWithData<ReadonlyUint8Array>, ): ParsedRefreshUserStateInstruction<TProgram, TAccountMetas> { 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; }; const getNextOptionalAccount = () => { const accountMeta = getNextAccount(); return accountMeta.address === FARMS_PROGRAM_ADDRESS ? undefined : accountMeta; }; return { programAddress: instruction.programAddress, accounts: { userState: getNextAccount(), farmState: getNextAccount(), scopePrices: getNextOptionalAccount(), }, data: getRefreshUserStateInstructionDataDecoder().decode(instruction.data), }; }