@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
57 lines (55 loc) • 1.66 kB
text/typescript
import { Chain, Transport } from "viem";
import {
AvalancheCoreClient,
AvalancheCoreClient as Client,
} from "../../clients/createAvalancheCoreClient.js";
import { PChainRpcSchema } from "./pChainRpcSchema.js";
import { GetFeeConfigReturnType } from "./types/getFeeConfig.js";
/**
* Get the fee configuration for the P-Chain.
*
* - Docs: https://build.avax.network/docs/api-reference/p-chain/api#platformgetfeeconfig
*
* @param client - The client to use. {@link AvalancheCoreClient}
* @returns The fee configuration. {@link GetFeeConfigReturnType}
*
* @example
* ```ts
* import { createAvalancheCoreClient } from '@avalanche-sdk/client'
* import { avalanche } from '@avalanche-sdk/client/chains'
* import { getFeeConfig } from '@avalanche-sdk/client/methods/pChain'
*
* const client = createAvalancheCoreClient({
* chain: avalanche,
* transport: {
* type: "http",
* url: "<url>",
* },
* })
*
* const feeConfig = await getFeeConfig(client)
* ```
*/
export async function getFeeConfig<chain extends Chain | undefined>(
client: Client<Transport, chain>
): Promise<GetFeeConfigReturnType> {
const feeConfig = await client.request<
PChainRpcSchema,
{
method: "platform.getFeeConfig";
params: {};
},
GetFeeConfigReturnType
>({
method: "platform.getFeeConfig",
params: {},
});
return {
...feeConfig,
maxCapacity: BigInt(feeConfig.maxCapacity),
maxPerSecond: BigInt(feeConfig.maxPerSecond),
minPrice: BigInt(feeConfig.minPrice),
targetPerSecond: BigInt(feeConfig.targetPerSecond),
excessConversionConstant: BigInt(feeConfig.excessConversionConstant),
};
}