UNPKG

@nosana/kit

Version:

Nosana KIT

103 lines (102 loc) 4.16 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, getI64Decoder, getI64Encoder, getStructDecoder, getStructEncoder, transformEncoder, } from '@solana/kit'; import { NOSANA_JOBS_PROGRAM_ADDRESS } from '../programs'; import { getAccountMetaFactory } from '../shared'; export const EXTEND_DISCRIMINATOR = new Uint8Array([ 228, 127, 0, 1, 227, 154, 54, 168, ]); export function getExtendDiscriminatorBytes() { return fixEncoderSize(getBytesEncoder(), 8).encode(EXTEND_DISCRIMINATOR); } export function getExtendInstructionDataEncoder() { return transformEncoder(getStructEncoder([ ['discriminator', fixEncoderSize(getBytesEncoder(), 8)], ['timeout', getI64Encoder()], ]), (value) => ({ ...value, discriminator: EXTEND_DISCRIMINATOR })); } export function getExtendInstructionDataDecoder() { return getStructDecoder([ ['discriminator', fixDecoderSize(getBytesDecoder(), 8)], ['timeout', getI64Decoder()], ]); } export function getExtendInstructionDataCodec() { return combineCodec(getExtendInstructionDataEncoder(), getExtendInstructionDataDecoder()); } export function getExtendInstruction(input, config) { // Program address. const programAddress = config?.programAddress ?? NOSANA_JOBS_PROGRAM_ADDRESS; // Original accounts. const originalAccounts = { job: { value: input.job ?? null, isWritable: true }, market: { value: input.market ?? null, isWritable: false }, user: { value: input.user ?? null, isWritable: true }, vault: { value: input.vault ?? null, isWritable: true }, rewardsReflection: { value: input.rewardsReflection ?? null, isWritable: true, }, rewardsVault: { value: input.rewardsVault ?? null, isWritable: true }, authority: { value: input.authority ?? null, isWritable: false }, rewardsProgram: { value: input.rewardsProgram ?? null, isWritable: false }, tokenProgram: { value: input.tokenProgram ?? null, isWritable: false }, }; const accounts = originalAccounts; // Original args. const args = { ...input }; // Resolve default values. if (!accounts.tokenProgram.value) { accounts.tokenProgram.value = 'TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA'; } const getAccountMeta = getAccountMetaFactory(programAddress, 'programId'); const instruction = { accounts: [ getAccountMeta(accounts.job), getAccountMeta(accounts.market), getAccountMeta(accounts.user), getAccountMeta(accounts.vault), getAccountMeta(accounts.rewardsReflection), getAccountMeta(accounts.rewardsVault), getAccountMeta(accounts.authority), getAccountMeta(accounts.rewardsProgram), getAccountMeta(accounts.tokenProgram), ], programAddress, data: getExtendInstructionDataEncoder().encode(args), }; return instruction; } export function parseExtendInstruction(instruction) { if (instruction.accounts.length < 9) { // TODO: Coded error. throw new Error('Not enough accounts'); } let accountIndex = 0; const getNextAccount = () => { const accountMeta = instruction.accounts[accountIndex]; accountIndex += 1; return accountMeta; }; return { programAddress: instruction.programAddress, accounts: { job: getNextAccount(), market: getNextAccount(), user: getNextAccount(), vault: getNextAccount(), rewardsReflection: getNextAccount(), rewardsVault: getNextAccount(), authority: getNextAccount(), rewardsProgram: getNextAccount(), tokenProgram: getNextAccount(), }, data: getExtendInstructionDataDecoder().decode(instruction.data), }; }