@rainfi/sdk
Version:
This package is used to interact with Rain.fi protocol on Solana
166 lines (165 loc) • 5.75 kB
TypeScript
/**
* 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[];
}>;