@kamino-finance/farms-sdk
Version:
201 lines (185 loc) • 6.12 kB
text/typescript
/**
* 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),
};
}