@avalanche-sdk/client
Version:
A TypeScript SDK for interacting with the Avalanche network through JSON-RPC APIs. This SDK provides a comprehensive set of tools to interact with all Avalanche chains (P-Chain, X-Chain, C-Chain) and various APIs, including wallet functionality for transa
61 lines (59 loc) • 1.7 kB
text/typescript
import { Chain, Transport } from "viem";
import {
AvalancheCoreClient,
AvalancheCoreClient as Client,
} from "../../clients/createAvalancheCoreClient.js";
import {
GetBalanceParameters,
GetBalanceReturnType,
} from "./types/getBalance.js";
import { XChainRpcSchema } from "./xChainRpcSchema.js";
/**
* Get the balance of an asset controlled by given addresses.
*
* - Docs: https://build.avax.network/docs/api-reference/x-chain/api#avmgetbalance
*
* @param client - The client to use. {@link AvalancheCoreClient}
* @param params - The addresses and asset ID. {@link GetBalanceParameters}
* @returns The balance of the asset. {@link GetBalanceReturnType}
*
* @example
* ```ts
* import { createAvalancheCoreClient } from '@avalanche-sdk/client'
* import { avalanche } from '@avalanche-sdk/client/chains'
* import { getBalance } from '@avalanche-sdk/client/methods/xChain'
*
* const client = createAvalancheCoreClient({
* chain: avalanche,
* transport: {
* type: "http",
* url: "<url>",
* },
* })
*
* const balance = await getBalance(client, {
* addresses: ["X-avax18jma8ppw3nhx5r4ap8clazz0dps7rv5ukulre5"],
* assetID: "FvwEAhmxKfeiG8SnEvq42hc6whRyY3EFYAvebMqDNDGCgxN5Z"
* })
* ```
*/
export async function getBalance<chain extends Chain | undefined>(
client: Client<Transport, chain>,
params: GetBalanceParameters
): Promise<GetBalanceReturnType> {
const balance = await client.request<
XChainRpcSchema,
{
method: "avm.getBalance";
params: GetBalanceParameters;
},
GetBalanceReturnType
>({
method: "avm.getBalance",
params,
});
return {
...balance,
balance: BigInt(balance.balance),
};
}