UNPKG

@rainfi/sdk

Version:

This package is used to interact with Rain.fi protocol on Solana

166 lines (165 loc) 5.75 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 */ /// <reference types="node" /> import * as web3 from '@solana/web3.js'; import * as beet from '@metaplex-foundation/beet'; import * as beetSolana from '@metaplex-foundation/beet-solana'; /** * Arguments used to create {@link UserStats} * @category Accounts * @category generated */ export type UserStatsArgs = { owner: web3.PublicKey; totalLoan: beet.bignum; totalMortgage: beet.bignum; totalLiquidation: beet.bignum; currentLoan: beet.bignum; currentMortgage: beet.bignum; createdAt: beet.bignum; totalVolumeBorrower: beet.bignum; totalVolumePool: beet.bignum; points: beet.bignum; creditScore: beet.bignum; referrer: web3.PublicKey; padding: beet.bignum[]; }; export declare const userStatsDiscriminator: number[]; /** * Holds the data for the {@link UserStats} Account and provides de/serialization * functionality for that data * * @category Accounts * @category generated */ export declare class UserStats implements UserStatsArgs { readonly owner: web3.PublicKey; readonly totalLoan: beet.bignum; readonly totalMortgage: beet.bignum; readonly totalLiquidation: beet.bignum; readonly currentLoan: beet.bignum; readonly currentMortgage: beet.bignum; readonly createdAt: beet.bignum; readonly totalVolumeBorrower: beet.bignum; readonly totalVolumePool: beet.bignum; readonly points: beet.bignum; readonly creditScore: beet.bignum; readonly referrer: web3.PublicKey; readonly padding: beet.bignum[]; private constructor(); /** * Creates a {@link UserStats} instance from the provided args. */ static fromArgs(args: UserStatsArgs): UserStats; /** * Deserializes the {@link UserStats} 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<Buffer>, offset?: number): [UserStats, number]; /** * Retrieves the account info from the provided address and deserializes * the {@link UserStats} 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<UserStats>; /** * 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<{ accountDiscriminator: any; createdAt: any; padding: any; owner: any; totalLoan: any; totalMortgage: any; totalLiquidation: any; currentLoan: any; currentMortgage: any; totalVolumeBorrower: any; totalVolumePool: any; points: any; creditScore: any; referrer: any; }>; /** * Deserializes the {@link UserStats} 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): [UserStats, number]; /** * Serializes the {@link UserStats} 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 UserStats} */ static get byteSize(): number; /** * Fetches the minimum balance needed to exempt an account holding * {@link UserStats} data from rent * * @param connection used to retrieve the rent exemption information */ static getMinimumBalanceForRentExemption(connection: web3.Connection, commitment?: web3.Commitment): Promise<number>; /** * Determines if the provided {@link Buffer} has the correct byte size to * hold {@link UserStats} data. */ static hasCorrectByteSize(buf: Buffer, offset?: number): boolean; /** * Returns a readable version of {@link UserStats} properties * and can be used to convert to JSON and/or logging */ pretty(): { owner: string; totalLoan: number | { toNumber: () => number; }; totalMortgage: number | { toNumber: () => number; }; totalLiquidation: number | { toNumber: () => number; }; currentLoan: number | { toNumber: () => number; }; currentMortgage: number | { toNumber: () => number; }; createdAt: number | { toNumber: () => number; }; totalVolumeBorrower: number | { toNumber: () => number; }; totalVolumePool: number | { toNumber: () => number; }; points: number | { toNumber: () => number; }; creditScore: number | { toNumber: () => number; }; referrer: string; padding: beet.bignum[]; }; } /** * @category Accounts * @category generated */ export declare const userStatsBeet: beet.BeetStruct<UserStats, UserStatsArgs & { accountDiscriminator: number[]; }>;