A modular interface for interacting with the Nuklai blockchain, built on top of the Avalanche HyperSDK.
npm install @nuklai/nuklai-sdk
# or
yarn add @nuklai/nuklai-sdkimport { NuklaiSDK } from "@nuklai/nuklai-sdk";
const sdk = new NuklaiSDK("http://127.0.0.1:9650");
const healthStatus = await sdk.rpcService.validateConnection();- π° Asset Management (Fungible/Non-Fungible Tokens)
- π Dataset Creation and Management
- πͺ Marketplace Operations
- π³ Transaction Management
- π Network Status and Health Checks
- ποΈ Validator Management
- π Staking Operations
import { NuklaiSDK } from "@nuklai/nuklai-sdk";
const sdk = new NuklaiSDK({
  baseApiUrl: "http://127.0.0.1:9650",
});
// Set the signer for transactions
sdk.rpcService.setSigner("your-private-key-here");// Create SDK instance
const sdk = new NuklaiSDK();
// Create a new random wallet
const wallet = sdk.createWallet();
console.log("Wallet address:", wallet.getAddress());
// Get wallet's private key
const privateKey = wallet.getPrivateKey();
console.log("Private key:", privateKey); // Returns the 128-character private key string
// Or import an existing wallet
const importedWallet = sdk.importWalletFromPrivateKey("your-private-key-hex");
// Check wallet connection
if (sdk.isWalletConnected()) {
    // Use wallet features
    const address = sdk.getAddress();
}// Using a private key string
await sdk.rpcService.setSigner(privateKeyString);
// Using any custom signer that implements SignerIface
await sdk.rpcService.setSigner(customSigner);// Create a fungible token
const ftResult = await sdk.rpcService.createFTAsset(
  "Test Token",
  "TEST",
  9,
  "metadata",
  BigInt("1000000000000000000"), // Max supply
  "owner-address",
  "admin-address",
  "admin-address",
  "admin-address"
);
// Create an NFT collection
const nftResult = await sdk.rpcService.createNFTAsset(
  "Test NFT",
  "TNFT",
  "metadata",
  BigInt(1000), // Max supply
  "owner-address",
  "admin-address",
  "admin-address",
  "admin-address"
);// Mint fungible tokens
const mintAmount = BigInt("1000000000000000000"); // 1 token
const mintResult = await sdk.rpcService.mintFTAsset(
  "receiver-address",
  "token-address",
  mintAmount
);
// Mint NFT
const nftMintResult = await sdk.rpcService.mintNFTAsset(
  "nft-collection-address",
  JSON.stringify({
    name: "Test NFT #1",
    description: "First NFT",
    attributes: [],
  }),
  "receiver-address"
);
// Transfer tokens
const transferAmount = BigInt("100000000000000000"); // 0.1 token
const transferResult = await sdk.rpcService.transfer(
  "recipient-address",
  "token-address",
  transferAmount,
  "Transfer memo"
);// Get native NAI token balance
const nativeBalance = await sdk.rpcService.getBalance("address");
// Get any asset balance by passing asset address
const assetBalance = await sdk.rpcService.getBalance("address", "assetAddress");NOTE: Balance is returned as raw strings without decimal formatting. Use asset decimals info from
getAssetInfo()to correctly format & display the balance corectly.
// Create a dataset
const result = await sdk.rpcService.createDataset(
  "asset-address",
  "Test Dataset",
  "Description",
  "AI,Testing",
  "MIT",
  "MIT",
  "https://opensource.org/licenses/MIT",
  "metadata",
  true // isCommunityDataset
);Build from source:
yarn
yarn buildRun tests:
yarn testThe examples/ directory contains sample implementations:
examples/
βββ datasets.ts            # Dataset creation and management
βββ fungible-tokens.ts     # Fungible Token operations
βββ non-fungible-tokens.ts # Non-Fungible Token operations
βββ marketplace.ts         # Marketplace interactions
You can run all examples at once using:
yarn examplesOr run individual examples:
ts-node --esm examples/fungible-tokens.ts
ts-node --esm examples/non-fungible-tokens.tsAll methods are accessible through the sdk.rpcService instance. Below is a comprehensive reference of available methods grouped by their functionality.
| Method | Description | Parameters | Returns | 
|---|---|---|---|
| validateConnection() | Checks node connectivity | None | Promise<boolean> | 
| getEmissionInfo() | Retrieves emission statistics | None | Promise<ActionOutput> | 
| getAllValidators() | Lists all validators | None | Promise<ActionOutput> | 
| getStakedValidators() | Lists validators with stake | None | Promise<ActionOutput> | 
| getValidatorStake(nodeID) | Gets specific validator stake | nodeID: string | Promise<ActionOutput> | 
| Method | Description | Parameters | Returns | 
|---|---|---|---|
| createFTAsset() | Creates a new Fungible Token | - name: string- symbol: string- decimals: number- metadata: string- maxSupply: bigint- mintAdmin: string- pauseAdmin: string- freezeAdmin: string- kycAdmin: string | Promise<TxResult> | 
| mintFTAsset() | Mints Fungible Tokens | - to: string- assetAddress: string- amount: bigint | Promise<TxResult> | 
| transfer() | Transfers tokens | - to: string- assetAddress: string- value: bigint- memo: string | Promise<TxResult> | 
| Method | Description | Parameters | Returns | 
|---|---|---|---|
| createNFTAsset() | Creates an NFT collection | - name: string- symbol: string- metadata: string- maxSupply: bigint- mintAdmin: string- pauseAdmin: string- freezeAdmin: string- kycAdmin: string | Promise<TxResult> | 
| mintNFTAsset() | Mints a new NFT | - assetAddress: string- metadata: string- to: string | Promise<TxResult> | 
| Method | Description | Parameters | Returns | 
|---|---|---|---|
| createDataset() | Creates a new dataset | - assetAddress: string- name: string- description: string- categories: string- licenseName: string- licenseSymbol: string- licenseURL: string- metadata: string- isCommunityDataset: boolean | Promise<TxResult> | 
| updateDataset() | Updates dataset info | - datasetAddress: string- name: string- description: string- categories: string- licenseName: string- licenseSymbol: string- licenseURL: string- isCommunityDataset: boolean | Promise<TxResult> | 
| getDatasetInfo() | Gets dataset details | datasetID: string | Promise<ActionOutput> | 
| Method | Description | Parameters | Returns | 
|---|---|---|---|
| publishDatasetToMarketplace() | Lists dataset on marketplace | - datasetAddress: string- paymentAssetAddress: string- datasetPricePerBlock: number | Promise<TxResult> | 
| subscribeDatasetMarketplace() | Subscribes to dataset | - marketplaceAssetAddress: string- paymentAssetAddress: string- numBlocksToSubscribe: number | Promise<TxResult> | 
| claimMarketplacePayment() | Claims marketplace earnings | - marketplaceAssetAddress: string- paymentAssetAddress: string | Promise<TxResult> | 
| Method | Description | Parameters | Returns | 
|---|---|---|---|
| getBalance() | Get's address balance | address: string | Promise<string> | 
| getAssetInfo() | Get's asset details | assetAddress: string | Promise<ActionOutput> | 
| getDatasetBalance() | Get's dataset balance | - address: string- assetID: string | Promise<ActionOutput> | 
| getDatasetNFTInfo() | Get's NFT details | nftID: string | Promise<ActionOutput> | 
| getPendingContributions() | Lists pending contributions | datasetID: string | Promise<ActionOutput> | 
| getPrivateKey() | Get's wallet's private key | None | string | 
| getAddress() | Get's wallet's address | None | string | 
| getPublicKey() | Get's wallet's public key | None | string | 
Creating and minting a fungible token
// Create a FT
const ftResult = await sdk.rpcService.createFTAsset(
  "Test Token",
  "TEST",
  9,
  "metadata",
  BigInt("1000000000000000000"),
  "owner-address",
  "admin-address",
  "admin-address",
  "admin-address"
);
// After creation, mint some tokens
const mintResult = await sdk.rpcService.mintFTAsset(
  "receiver-address",
  ftResult.result[0].asset_address,
  BigInt("1000000000000000000")
);MIT License - see LICENSE for details.