@cks-systems/manifest-sdk
Version:
TypeScript SDK for Manifest
120 lines (119 loc) • 4.51 kB
JavaScript
/**
* 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 beetSolana from '@metaplex-foundation/beet-solana';
import * as beet from '@metaplex-foundation/beet';
import { globalAtomsBeet } from './GlobalAtoms';
/**
* Holds the data for the {@link GlobalDepositLog} Account and provides de/serialization
* functionality for that data
*
* @category Accounts
* @category generated
*/
export class GlobalDepositLog {
global;
trader;
globalAtoms;
constructor(global, trader, globalAtoms) {
this.global = global;
this.trader = trader;
this.globalAtoms = globalAtoms;
}
/**
* Creates a {@link GlobalDepositLog} instance from the provided args.
*/
static fromArgs(args) {
return new GlobalDepositLog(args.global, args.trader, args.globalAtoms);
}
/**
* Deserializes the {@link GlobalDepositLog} 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, offset = 0) {
return GlobalDepositLog.deserialize(accountInfo.data, offset);
}
/**
* Retrieves the account info from the provided address and deserializes
* the {@link GlobalDepositLog} from its data.
*
* @throws Error if no account info is found at the address or if deserialization fails
*/
static async fromAccountAddress(connection, address, commitmentOrConfig) {
const accountInfo = await connection.getAccountInfo(address, commitmentOrConfig);
if (accountInfo == null) {
throw new Error(`Unable to find GlobalDepositLog account at ${address}`);
}
return GlobalDepositLog.fromAccountInfo(accountInfo, 0)[0];
}
/**
* 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 = new web3.PublicKey('MNFSTqtC93rEfYHB6hF82sKdZpUDFWkViLByLd1k1Ms')) {
return beetSolana.GpaBuilder.fromStruct(programId, globalDepositLogBeet);
}
/**
* Deserializes the {@link GlobalDepositLog} 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, offset = 0) {
return globalDepositLogBeet.deserialize(buf, offset);
}
/**
* Serializes the {@link GlobalDepositLog} into a Buffer.
* @returns a tuple of the created Buffer and the offset up to which the buffer was written to store it.
*/
serialize() {
return globalDepositLogBeet.serialize(this);
}
/**
* Returns the byteSize of a {@link Buffer} holding the serialized data of
* {@link GlobalDepositLog}
*/
static get byteSize() {
return globalDepositLogBeet.byteSize;
}
/**
* Fetches the minimum balance needed to exempt an account holding
* {@link GlobalDepositLog} data from rent
*
* @param connection used to retrieve the rent exemption information
*/
static async getMinimumBalanceForRentExemption(connection, commitment) {
return connection.getMinimumBalanceForRentExemption(GlobalDepositLog.byteSize, commitment);
}
/**
* Determines if the provided {@link Buffer} has the correct byte size to
* hold {@link GlobalDepositLog} data.
*/
static hasCorrectByteSize(buf, offset = 0) {
return buf.byteLength - offset === GlobalDepositLog.byteSize;
}
/**
* Returns a readable version of {@link GlobalDepositLog} properties
* and can be used to convert to JSON and/or logging
*/
pretty() {
return {
global: this.global.toBase58(),
trader: this.trader.toBase58(),
globalAtoms: this.globalAtoms,
};
}
}
/**
* @category Accounts
* @category generated
*/
export const globalDepositLogBeet = new beet.BeetStruct([
['global', beetSolana.publicKey],
['trader', beetSolana.publicKey],
['globalAtoms', globalAtomsBeet],
], GlobalDepositLog.fromArgs, 'GlobalDepositLog');