Compact JavaScript library for interacting with Ankr's Advanced APIs.
# with npm
npm install @ankr.com/ankr.js
# with yarn
yarn add @ankr.com/ankr.js
Note: to use Advanced API for free starting from 29.05.2023 you have to register on the platform.
Get your individual endpoint here https://www.ankr.com/rpc/advanced-api and provide it to the AnkrProvider
constructor.
import { AnkrProvider } from '@ankr.com/ankr.js';
const provider = new AnkrProvider('YOUR_ENDPOINT');
await provider.getNFTsByOwner({
blockchain: 'eth',
walletAddress: '0x0E11A192d574b342C51be9e306694C41547185DD',
});
ankr.js
supports the following chains at this time:
-
Ethereum:
"eth"
-
BNB Smart Chain:
"bsc"
-
Polygon:
"polygon"
-
Fantom:
"fantom"
-
Arbitrum:
"arbitrum"
-
Avalanche:
"avalanche"
-
Syscoin NEVM:
"syscoin"
-
Optimism:
"optimism"
-
Ethereum Goerli:
"eth_goerli"
-
Avalanche Fuji:
"avalanche_fuji"
ankr.js
supports the following methods:
getNFTsByOwner
getNFTMetadata
getNFTHolders
getTokenHolders
getAccountBalance
getTokenHoldersCount
getCurrencies
getLogs
getBlocks
getTransactionsByHash
getTransactionsByAddress
getTokenPrice
getTokenPriceHistory
Get logs matching the filter.
const logs = async () => {
return await provider.getLogs({
blockchain: 'eth',
fromBlock: 1181739,
toBlock: 1181739,
topics: [
[],
['0x000000000000000000000000feb92d30bf01ff9a1901666c5573532bfa07eeec'],
],
address: '0x3589d05a1ec4af9f65b0e5554e645707775ee43c',
decodeLogs: false,
});
};
Query data about blocks within a specified range.
const blocks = async () => {
return await provider.getBlocks({
blockchain: 'bsc',
fromBlock: 100,
toBlock: 200,
});
};
Query data about transaction(s) by the transaction hash.
const transactions = async () => {
return await provider.getTransactionsByHash({
transactionHash:
'0x82c13aaac6f0b6471afb94a3a64ae89d45baa3608ad397621dbb0d847f51196f',
decodeTxData: true,
});
};
Get the coin and token balances of a wallet.
const balances = async () => {
return await provider.getAccountBalance({
blockchain: 'eth',
walletAddress: '0xfa9019df60d3c710d7d583b2d69e18d412257617',
});
};
Get data about all the NFTs (collectibles) owned by a wallet.
const nfts = async () => {
return await provider.getNFTsByOwner({
blockchain: 'eth',
walletAddress: '0x0E11A192d574b342C51be9e306694C41547185DD',
filter: [
{ '0x700b4b9f39bb1faf5d0d16a20488f2733550bff4': [] },
{ '0xd8682bfa6918b0174f287b888e765b9a1b4dc9c3': ['8937'] },
],
});
};
Get the list of token holders for a given contract address.
const tokenHolders = async () => {
return await provider.getTokenHolders({
blockchain: 'eth',
contractAddress: '0xdac17f958d2ee523a2206206994597c13d831ec7',
});
};
Get current and historical data about the number of token holders for a given contract address.
const tokenHoldersCount = async () => {
return await provider.getTokenHoldersCount({
blockchain: 'eth',
contractAddress: '0xdac17f958d2ee523a2206206994597c13d831ec7',
});
};
Get a list of supported currencies for a given blockchain.
const currencies = async () => {
return await provider.getCurrencies({ blockchain: 'fantom' });
};
Ankr is offering free access to Advanced API, however you have to register on Ankr platform to access it. Get your individual endpoint here https://www.ankr.com/rpc/advanced-api.