UNPKG

solana-framework

Version:

solana-framework is solana uni-tools for typescript

135 lines (128 loc) 3.82 kB
/** * This code was GENERATED using the solita package. * Please DO NOT EDIT THIS FILE, instead rerun solita to update it or write a wrapper to add functionality. * * See: https://github.com/metaplex-foundation/solita */ import * as beet from '@metaplex-foundation/beet'; import * as web3 from '@solana/web3.js'; import { CreateMetadataAccountArgsV3, createMetadataAccountArgsV3Beet, } from '../types/CreateMetadataAccountArgsV3'; /** * @category Instructions * @category CreateMetadataAccountV3 * @category generated */ export type CreateMetadataAccountV3InstructionArgs = { createMetadataAccountArgsV3: CreateMetadataAccountArgsV3; }; /** * @category Instructions * @category CreateMetadataAccountV3 * @category generated */ export const CreateMetadataAccountV3Struct = new beet.FixableBeetArgsStruct< CreateMetadataAccountV3InstructionArgs & { instructionDiscriminator: number; } >( [ ['instructionDiscriminator', beet.u8], ['createMetadataAccountArgsV3', createMetadataAccountArgsV3Beet], ], 'CreateMetadataAccountV3InstructionArgs', ); /** * Accounts required by the _CreateMetadataAccountV3_ instruction * * @property [_writable_] metadata Metadata key (pda of ['metadata', program id, mint id]) * @property [] mint Mint of token asset * @property [**signer**] mintAuthority Mint authority * @property [_writable_, **signer**] payer payer * @property [] updateAuthority update authority info * @category Instructions * @category CreateMetadataAccountV3 * @category generated */ export type CreateMetadataAccountV3InstructionAccounts = { metadata: web3.PublicKey; mint: web3.PublicKey; mintAuthority: web3.PublicKey; payer: web3.PublicKey; updateAuthority: web3.PublicKey; systemProgram?: web3.PublicKey; rent?: web3.PublicKey; }; export const createMetadataAccountV3InstructionDiscriminator = 33; /** * Creates a _CreateMetadataAccountV3_ instruction. * * Optional accounts that are not provided will be omitted from the accounts * array passed with the instruction. * An optional account that is set cannot follow an optional account that is unset. * Otherwise an Error is raised. * * @param accounts that will be accessed while the instruction is processed * @param args to provide as instruction data to the program * * @category Instructions * @category CreateMetadataAccountV3 * @category generated */ export function createCreateMetadataAccountV3Instruction( accounts: CreateMetadataAccountV3InstructionAccounts, args: CreateMetadataAccountV3InstructionArgs, programId = new web3.PublicKey('metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s'), ) { const [data] = CreateMetadataAccountV3Struct.serialize({ instructionDiscriminator: createMetadataAccountV3InstructionDiscriminator, ...args, }); const keys: web3.AccountMeta[] = [ { pubkey: accounts.metadata, isWritable: true, isSigner: false, }, { pubkey: accounts.mint, isWritable: false, isSigner: false, }, { pubkey: accounts.mintAuthority, isWritable: false, isSigner: true, }, { pubkey: accounts.payer, isWritable: true, isSigner: true, }, { pubkey: accounts.updateAuthority, isWritable: false, isSigner: false, }, { pubkey: accounts.systemProgram ?? web3.SystemProgram.programId, isWritable: false, isSigner: false, }, ]; if (accounts.rent != null) { keys.push({ pubkey: accounts.rent, isWritable: false, isSigner: false, }); } const ix = new web3.TransactionInstruction({ programId, keys, data, }); return ix; }