/**
* 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 { Key } from '../types/Key';
import { Data } from '../types/Data';
import { TokenStandard } from '../types/TokenStandard';
import { Collection } from '../types/Collection';
import { Uses } from '../types/Uses';
import { CollectionDetails } from '../types/CollectionDetails';
import { ProgrammableConfig } from '../types/ProgrammableConfig';
/**
* Arguments used to create {@link Metadata}
* @category Accounts
* @category generated
*/
export type MetadataArgs = {
key: Key;
updateAuthority: web3.PublicKey;
mint: web3.PublicKey;
data: Data;
primarySaleHappened: boolean;
isMutable: boolean;
editionNonce: beet.COption;
tokenStandard: beet.COption;
collection: beet.COption;
uses: beet.COption;
collectionDetails: beet.COption;
programmableConfig: beet.COption;
};
/**
* Holds the data for the {@link Metadata} Account and provides de/serialization
* functionality for that data
*
* @category Accounts
* @category generated
*/
export declare class Metadata implements MetadataArgs {
readonly key: Key;
readonly updateAuthority: web3.PublicKey;
readonly mint: web3.PublicKey;
readonly data: Data;
readonly primarySaleHappened: boolean;
readonly isMutable: boolean;
readonly editionNonce: beet.COption;
readonly tokenStandard: beet.COption;
readonly collection: beet.COption;
readonly uses: beet.COption;
readonly collectionDetails: beet.COption;
readonly programmableConfig: beet.COption;
private constructor();
/**
* Creates a {@link Metadata} instance from the provided args.
*/
static fromArgs(args: MetadataArgs): Metadata;
/**
* Deserializes the {@link Metadata} 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?: number): [Metadata, number];
/**
* Retrieves the account info from the provided address and deserializes
* the {@link Metadata} from its data.
*
* @throws Error if no account info is found at the address or if deserialization fails
*/
static fromAccountAddress(connection: web3.Connection, address: web3.PublicKey, commitmentOrConfig?: web3.Commitment | web3.GetAccountInfoConfig): Promise;
/**
* Provides a {@link web3.Connection.getProgramAccounts} config builder,
* to fetch accounts matching filters that can be specified via that builder.
*
* @param programId - the program that owns the accounts we are filtering
*/
static gpaBuilder(programId?: web3.PublicKey): beetSolana.GpaBuilder;
/**
* Deserializes the {@link Metadata} 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?: number): [Metadata, number];
/**
* Serializes the {@link Metadata} 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];
/**
* Returns the byteSize of a {@link Buffer} holding the serialized data of
* {@link Metadata} for the provided args.
*
* @param args need to be provided since the byte size for this account
* depends on them
*/
static byteSize(args: MetadataArgs): number;
/**
* Fetches the minimum balance needed to exempt an account holding
* {@link Metadata} 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 getMinimumBalanceForRentExemption(args: MetadataArgs, connection: web3.Connection, commitment?: web3.Commitment): Promise;
/**
* Returns a readable version of {@link Metadata} properties
* and can be used to convert to JSON and/or logging
*/
pretty(): {
key: string;
updateAuthority: string;
mint: string;
data: Data;
primarySaleHappened: boolean;
isMutable: boolean;
editionNonce: beet.COption;
tokenStandard: beet.COption;
collection: beet.COption;
uses: beet.COption;
collectionDetails: beet.COption<{
__kind: "V1";
} & Omit<{
size: any;
}, "void">>;
programmableConfig: beet.COption<{
__kind: "V1";
} & Omit<{
ruleSet: beet.COption;
}, "void">>;
};
}
/**
* @category Accounts
* @category generated
*/
export declare const metadataBeet: beet.FixableBeetStruct;
//# sourceMappingURL=Metadata.d.ts.map