/** * 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 web3 from '@solana/web3.js'; import * as beet from '@metaplex-foundation/beet'; import * as beetSolana from '@metaplex-foundation/beet-solana'; import { SellingResourceState, sellingResourceStateBeet } from '../types/SellingResourceState'; /** * Arguments used to create {@link SellingResource} * @category Accounts * @category generated */ export type SellingResourceArgs = { store: web3.PublicKey; owner: web3.PublicKey; resource: web3.PublicKey; vault: web3.PublicKey; vaultOwner: web3.PublicKey; supply: beet.bignum; maxSupply: beet.COption; state: SellingResourceState; }; const sellingResourceDiscriminator = [15, 32, 69, 235, 249, 39, 18, 167]; /** * Holds the data for the {@link SellingResource} Account and provides de/serialization * functionality for that data * * @category Accounts * @category generated */ export class SellingResource implements SellingResourceArgs { private constructor( readonly store: web3.PublicKey, readonly owner: web3.PublicKey, readonly resource: web3.PublicKey, readonly vault: web3.PublicKey, readonly vaultOwner: web3.PublicKey, readonly supply: beet.bignum, readonly maxSupply: beet.COption, readonly state: SellingResourceState, ) {} /** * Creates a {@link SellingResource} instance from the provided args. */ static fromArgs(args: SellingResourceArgs) { return new SellingResource( args.store, args.owner, args.resource, args.vault, args.vaultOwner, args.supply, args.maxSupply, args.state, ); } /** * Deserializes the {@link SellingResource} from the data of the provided {@link web3.AccountInfo}. * @returns a tuple of the account data and the offset up to which the buffer was read to obtain it. */ static fromAccountInfo( accountInfo: web3.AccountInfo, offset = 0, ): [SellingResource, number] { return SellingResource.deserialize(accountInfo.data, offset); } /** * Retrieves the account info from the provided address and deserializes * the {@link SellingResource} from its data. * * @throws Error if no account info is found at the address or if deserialization fails */ static async fromAccountAddress( connection: web3.Connection, address: web3.PublicKey, ): Promise { const accountInfo = await connection.getAccountInfo(address); if (accountInfo == null) { throw new Error(`Unable to find SellingResource account at ${address}`); } return SellingResource.fromAccountInfo(accountInfo, 0)[0]; } /** * Deserializes the {@link SellingResource} from the provided data Buffer. * @returns a tuple of the account data and the offset up to which the buffer was read to obtain it. */ static deserialize(buf: Buffer, offset = 0): [SellingResource, number] { return sellingResourceBeet.deserialize(buf, offset); } /** * Serializes the {@link SellingResource} into a Buffer. * @returns a tuple of the created Buffer and the offset up to which the buffer was written to store it. */ serialize(): [Buffer, number] { return sellingResourceBeet.serialize({ accountDiscriminator: sellingResourceDiscriminator, ...this, }); } /** * Returns the byteSize of a {@link Buffer} holding the serialized data of * {@link SellingResource} for the provided args. * * @param args need to be provided since the byte size for this account * depends on them */ static byteSize(args: SellingResourceArgs) { const instance = SellingResource.fromArgs(args); return sellingResourceBeet.toFixedFromValue({ accountDiscriminator: sellingResourceDiscriminator, ...instance, }).byteSize; } /** * Fetches the minimum balance needed to exempt an account holding * {@link SellingResource} data from rent * * @param args need to be provided since the byte size for this account * depends on them * @param connection used to retrieve the rent exemption information */ static async getMinimumBalanceForRentExemption( args: SellingResourceArgs, connection: web3.Connection, commitment?: web3.Commitment, ): Promise { return connection.getMinimumBalanceForRentExemption(SellingResource.byteSize(args), commitment); } /** * Returns a readable version of {@link SellingResource} properties * and can be used to convert to JSON and/or logging */ pretty() { return { store: this.store.toBase58(), owner: this.owner.toBase58(), resource: this.resource.toBase58(), vault: this.vault.toBase58(), vaultOwner: this.vaultOwner.toBase58(), supply: this.supply, maxSupply: this.maxSupply, state: 'SellingResourceState.' + SellingResourceState[this.state], }; } } /** * @category Accounts * @category generated */ export const sellingResourceBeet = new beet.FixableBeetStruct< SellingResource, SellingResourceArgs & { accountDiscriminator: number[] /* size: 8 */; } >( [ ['accountDiscriminator', beet.uniformFixedSizeArray(beet.u8, 8)], ['store', beetSolana.publicKey], ['owner', beetSolana.publicKey], ['resource', beetSolana.publicKey], ['vault', beetSolana.publicKey], ['vaultOwner', beetSolana.publicKey], ['supply', beet.u64], ['maxSupply', beet.coption(beet.u64)], ['state', sellingResourceStateBeet], ], SellingResource.fromArgs, 'SellingResource', );