âī¸ NFT BalancesLearn how to fetch ERC721 and ERC1155 NFT balances of user(s) on Ethereum, Base, Zora, and other Airstack-supported chains. their variations.
Airstack provides easy-to-use NFT APIs for enriching Web3 applications with onchain and offchain NFT data from Ethereum, Base, Degen Chain, and other Airstack-supported chains.
Table Of Contents
In this guide you will learn how to use Airstack to:
Pre-requisites
Basic knowledge of GraphQL
Get Started
JavaScript/TypeScript/Python
If you are using JavaScript/TypeScript or Python, Install the Airstack SDK:
npm yarn pnpm pip
React
Copy npm install @airstack/airstack-react
Node
Copy npm install @airstack/node
React
Copy yarn add @airstack/airstack-react
Node
Copy yarn add @airstack/node
React
Copy pnpm install @airstack/airstack-react
Node
Copy pnpm install @airstack/node
Then, add the following snippets to your code:
React Node Python
Copy import { init , useQuery } from "@airstack/airstack-react" ;
init ( "YOUR_AIRSTACK_API_KEY" );
const query = `YOUR_QUERY` ; // Replace with GraphQL Query
const Component = () => {
const { data , loading , error } = useQuery (query);
if (data) {
return < p >Data: { JSON .stringify (data)}</ p >;
}
if (loading) {
return < p >Loading...</ p >;
}
if (error) {
return < p >Error: { error .message}</ p >;
}
};
Copy import { init , fetchQuery } from "@airstack/node" ;
init ( "YOUR_AIRSTACK_API_KEY" );
const query = `YOUR_QUERY` ; // Replace with GraphQL Query
const { data , error } = await fetchQuery (query);
console .log ( "data:" , data);
console .log ( "error:" , error);
Copy import asyncio
from airstack . execute_query import AirstackClient
api_client = AirstackClient (api_key = "YOUR_AIRSTACK_API_KEY" )
query = """YOUR_QUERY""" # Replace with GraphQL Query
async def main ():
execute_query_client = api_client . create_execute_query_object (
query = query)
query_response = await execute_query_client . execute_query ()
print (query_response.data)
asyncio . run ( main ())
Other Programming Languages
To access the Airstack APIs in other languages, you can use https://api.airstack.xyz/gql as your GraphQL endpoint.
đ¤ AI Natural Language â Airstack provides an AI solution for you to build GraphQL queries to fulfill your use case easily. You can find the AI prompt of each query in the demo's caption or title for yourself to try.
Get NFT Balances of User(s)
You can use Airstack to fetch NFT balance of user(s) across multiple chains, e.g. Ethereum, Base, Degen Chain, and other Airstack-supported chains , by using the TokenBalances
API and providing an array of users' 0x address, ENS domain, cb.id, Lens profile, or Farcaster fname/fid to owner
input:
Try Demo
Code
Query Response
Copy query MyQuery {
Ethereum : TokenBalances(
input: {
filter : {
owner : {
_in : [
"0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
"vitalik.eth"
"lens/@vitalik"
"fc_fname:vitalik"
]
}
tokenType : { _in : [ERC1155, ERC721] }
}
blockchain : ethereum
limit : 50
}
) {
TokenBalance {
owner {
identity
}
amount
tokenAddress
tokenId
tokenType
tokenNfts {
contentValue {
image {
extraSmall
small
medium
large
original
}
}
}
}
pageInfo {
nextCursor
prevCursor
}
}
Base : TokenBalances(
input: {
filter : {
owner : {
_in : [
"0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
"vitalik.eth"
"lens/@vitalik"
"fc_fname:vitalik"
]
}
tokenType : { _in : [ERC1155, ERC721] }
}
blockchain : base
limit : 50
}
) {
TokenBalance {
owner {
identity
}
amount
tokenAddress
tokenId
tokenType
tokenNfts {
contentValue {
image {
extraSmall
small
medium
large
original
}
}
}
}
pageInfo {
nextCursor
prevCursor
}
}
}
Copy {
"data" : {
"Ethereum" : {
"TokenBalance" : [
{
"owner" : {
"identity" : "0xd8da6bf26964af9d7eed9e03e53415d37aa96045"
} ,
"amount" : "1" ,
"tokenAddress" : "0xe361f10965542ee57d39043c9c3972b77841f581" ,
"tokenId" : "2575" ,
"tokenType" : "ERC721" ,
"tokenNfts" : {
"contentValue" : {
"image" : {
"extraSmall": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/extra_small.png",
"small": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/small.png",
"medium": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/medium.png",
"large": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/large.png",
"original": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/original_image.png"
}
}
}
}
// Other Ethereum NFTs held by vitalik
] ,
"pageInfo" : {
"nextCursor": "eyJMYXN0VmFsdWVzTWFwIjp7Il9pZCI6eyJWYWx1ZSI6IjEweDM0M2Y5OTllYWFjZGZhMWYyMDFmYjhlNDNlYmIzNWM5OWQ5YWUwYzEweGQ4ZGE2YmYyNjk2NGFmOWQ3ZWVkOWUwM2U1MzQxNWQzN2FhOTYwNDU1NTM4IiwiRGF0YVR5cGUiOiJzdHJpbmcifSwibGFzdFVwZGF0ZWRUaW1lc3RhbXAiOnsiVmFsdWUiOiIxNjk0NTc4MjgzIiwiRGF0YVR5cGUiOiJEYXRlVGltZSJ9fSwiUGFnaW5hdGlvbkRpcmVjdGlvbiI6Ik5FWFQifQ==",
"prevCursor" : ""
}
} ,
"Base" : {
"TokenBalance" : [
{
"owner" : {
"identity" : "0xd8da6bf26964af9d7eed9e03e53415d37aa96045"
} ,
"amount" : "1" ,
"tokenAddress" : "0xab54b8bd1118d535beecf43bf9c7d163879cf967" ,
"tokenId" : "2" ,
"tokenType" : "ERC1155" ,
"tokenNfts" : {
"contentValue" : {
"image" : {
"extraSmall": "https://assets.airstack.xyz/image/nft/8453/KEYM3ihZQ1f7hNMrnxylaC9aymzRDEpR6k24WvE1bOeYTCP3FBEY8v0XMCaJUXyzqno4Vvx93EOQrbiH+i4aKQ==/extra_small.jpg",
"small": "https://assets.airstack.xyz/image/nft/8453/KEYM3ihZQ1f7hNMrnxylaC9aymzRDEpR6k24WvE1bOeYTCP3FBEY8v0XMCaJUXyzqno4Vvx93EOQrbiH+i4aKQ==/small.jpg",
"medium": "https://assets.airstack.xyz/image/nft/8453/KEYM3ihZQ1f7hNMrnxylaC9aymzRDEpR6k24WvE1bOeYTCP3FBEY8v0XMCaJUXyzqno4Vvx93EOQrbiH+i4aKQ==/medium.jpg",
"large": "https://assets.airstack.xyz/image/nft/8453/KEYM3ihZQ1f7hNMrnxylaC9aymzRDEpR6k24WvE1bOeYTCP3FBEY8v0XMCaJUXyzqno4Vvx93EOQrbiH+i4aKQ==/large.jpg",
"original": "https://assets.airstack.xyz/image/nft/8453/KEYM3ihZQ1f7hNMrnxylaC9aymzRDEpR6k24WvE1bOeYTCP3FBEY8v0XMCaJUXyzqno4Vvx93EOQrbiH+i4aKQ==/original_image.jpg"
}
}
}
}
// Other Base NFTs held by vitalik
] ,
"pageInfo" : {
"nextCursor": "eyJMYXN0VmFsdWVzTWFwIjp7Il9pZCI6eyJWYWx1ZSI6ImMzMjllODM2ZWE0MzU2ZGViZWU1ZDc3MTg5MjlhNWRiYWJkZjhjNGEwYjJmMDY2M2Y1NmQxOTU2YzlkNzViNWYiLCJEYXRhVHlwZSI6InN0cmluZyJ9LCJsYXN0VXBkYXRlZFRpbWVzdGFtcCI6eyJWYWx1ZSI6IjE2OTg5ODA2MjIiLCJEYXRhVHlwZSI6IkRhdGVUaW1lIn19LCJQYWdpbmF0aW9uRGlyZWN0aW9uIjoiTkVYVCJ9",
"prevCursor" : ""
}
}
}
}
Get NFT Balances of User(s) on Specific Chain
You can use Airstack to fetch NFT balance of user(s) on a specific chain, e.g. Ethereum, by using the TokenBalances
API.
For the inputs, specify blockchain
to ethereum
and provide an array of users' 0x address, ENS domain, cb.id, Lens profile, or Farcaster fname/fid to owner
:
Try Demo
Code
Query Response
Copy query MyQuery {
TokenBalances(
input: {
filter : {
owner : {
_in : [
"0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
"vitalik.eth"
"lens/@vitalik"
"fc_fname:vitalik"
]
}
tokenType : { _in : [ERC1155, ERC721] }
}
blockchain : ethereum
limit : 50
}
) {
TokenBalance {
owner {
identity
}
amount
tokenAddress
tokenId
tokenType
tokenNfts {
contentValue {
image {
extraSmall
small
medium
large
original
}
}
}
}
pageInfo {
nextCursor
prevCursor
}
}
}
Copy {
"data" : {
"TokenBalances" : {
"TokenBalance" : [
{
"owner" : {
"identity" : "0xd8da6bf26964af9d7eed9e03e53415d37aa96045"
} ,
"amount" : "1" ,
"tokenAddress" : "0xe361f10965542ee57d39043c9c3972b77841f581" ,
"tokenId" : "2575" ,
"tokenType" : "ERC721" ,
"tokenNfts" : {
"contentValue" : {
"image" : {
"extraSmall": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/extra_small.png",
"small": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/small.png",
"medium": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/medium.png",
"large": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/large.png",
"original": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/original_image.png"
}
}
}
}
// Other Ethereum NFTs held by vitalik
] ,
"pageInfo" : {
"nextCursor": "eyJMYXN0VmFsdWVzTWFwIjp7Il9pZCI6eyJWYWx1ZSI6IjEweDM0M2Y5OTllYWFjZGZhMWYyMDFmYjhlNDNlYmIzNWM5OWQ5YWUwYzEweGQ4ZGE2YmYyNjk2NGFmOWQ3ZWVkOWUwM2U1MzQxNWQzN2FhOTYwNDU1NTM4IiwiRGF0YVR5cGUiOiJzdHJpbmcifSwibGFzdFVwZGF0ZWRUaW1lc3RhbXAiOnsiVmFsdWUiOiIxNjk0NTc4MjgzIiwiRGF0YVR5cGUiOiJEYXRlVGltZSJ9fSwiUGFnaW5hdGlvbkRpcmVjdGlvbiI6Ik5FWFQifQ==",
"prevCursor" : ""
}
}
}
}
Get Only ERC721/1155 NFT Balances of User(s)
You can use Airstack to fetch only either ERC721 or ERC1155 NFT balance of user(s) by using the TokenBalances
API.
For the inputs, specify tokenType
to ERC721
and provide an array of users' 0x address, ENS domain, cb.id, Lens profile, or Farcaster fname/fid to owner
:
Try Demo
Code
Query Response
Copy query MyQuery {
Ethereum : TokenBalances(
input: {
filter : {
owner : {
_in : [
"0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
"vitalik.eth"
"lens/@vitalik"
"fc_fname:vitalik"
]
}
tokenType : { _in : [ERC721] }
}
blockchain : ethereum
limit : 50
}
) {
TokenBalance {
owner {
identity
}
amount
tokenAddress
tokenId
tokenType
tokenNfts {
contentValue {
image {
extraSmall
small
medium
large
original
}
}
}
}
pageInfo {
nextCursor
prevCursor
}
}
Base : TokenBalances(
input: {
filter : {
owner : {
_in : [
"0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
"vitalik.eth"
"lens/@vitalik"
"fc_fname:vitalik"
]
}
tokenType : { _in : [ERC721] }
}
blockchain : base
limit : 50
}
) {
TokenBalance {
owner {
identity
}
amount
tokenAddress
tokenId
tokenType
tokenNfts {
contentValue {
image {
extraSmall
small
medium
large
original
}
}
}
}
pageInfo {
nextCursor
prevCursor
}
}
}
Copy {
"data" : {
"Ethereum" : {
"TokenBalance" : [
{
"owner" : {
"identity" : "0xd8da6bf26964af9d7eed9e03e53415d37aa96045"
} ,
"amount" : "1" ,
"tokenAddress" : "0xe361f10965542ee57d39043c9c3972b77841f581" ,
"tokenId" : "2575" ,
"tokenType" : "ERC721" ,
"tokenNfts" : {
"contentValue" : {
"image" : {
"extraSmall": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/extra_small.png",
"small": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/small.png",
"medium": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/medium.png",
"large": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/large.png",
"original": "https://assets.airstack.xyz/image/nft/8f58Hf72fwHyRNcwwg4qm1s1lnMMqcTNPtigmujnbqExq9Wt5XW0JEqPWZQdV3hICnCYr250gkuHMB5a9H+nUw==/original_image.png"
}
}
}
}
// Other ERC721 Ethereum NFTs held by vitalik
] ,
"pageInfo" : {
"nextCursor": "eyJMYXN0VmFsdWVzTWFwIjp7Il9pZCI6eyJWYWx1ZSI6IjEweDM0M2Y5OTllYWFjZGZhMWYyMDFmYjhlNDNlYmIzNWM5OWQ5YWUwYzEweGQ4ZGE2YmYyNjk2NGFmOWQ3ZWVkOWUwM2U1MzQxNWQzN2FhOTYwNDU1NTM4IiwiRGF0YVR5cGUiOiJzdHJpbmcifSwibGFzdFVwZGF0ZWRUaW1lc3RhbXAiOnsiVmFsdWUiOiIxNjk0NTc4MjgzIiwiRGF0YVR5cGUiOiJEYXRlVGltZSJ9fSwiUGFnaW5hdGlvbkRpcmVjdGlvbiI6Ik5FWFQifQ==",
"prevCursor" : ""
}
} ,
"Base" : {
"TokenBalance" : [
{
"owner" : {
"identity" : "0xe3a2a53e6bc71bc5ec34313b5aa783f4733bc419"
} ,
"amount" : "1" ,
"tokenAddress" : "0xf1788f434658347095a8e1a5db4414134d364d36" ,
"tokenId" : "5283" ,
"tokenType" : "ERC721" ,
"tokenNfts" : {
"contentValue" : {
"image" : {
"extraSmall": "https://assets.airstack.xyz/image/nft/8453/xeoepiJcK8a1aBbWMmG+g74XtIBrNqUqeB5RG51gQ1NIPUKy620oiRH9F+8JAUf5GgQ6A+cwcAaWsaRU6nXfcA==/extra_small.mp4",
"small": "https://assets.airstack.xyz/image/nft/8453/xeoepiJcK8a1aBbWMmG+g74XtIBrNqUqeB5RG51gQ1NIPUKy620oiRH9F+8JAUf5GgQ6A+cwcAaWsaRU6nXfcA==/small.mp4",
"medium": "https://assets.airstack.xyz/image/nft/8453/xeoepiJcK8a1aBbWMmG+g74XtIBrNqUqeB5RG51gQ1NIPUKy620oiRH9F+8JAUf5GgQ6A+cwcAaWsaRU6nXfcA==/medium.mp4",
"large": "https://assets.airstack.xyz/image/nft/8453/xeoepiJcK8a1aBbWMmG+g74XtIBrNqUqeB5RG51gQ1NIPUKy620oiRH9F+8JAUf5GgQ6A+cwcAaWsaRU6nXfcA==/large.mp4",
"original": "https://assets.airstack.xyz/image/nft/8453/xeoepiJcK8a1aBbWMmG+g74XtIBrNqUqeB5RG51gQ1NIPUKy620oiRH9F+8JAUf5GgQ6A+cwcAaWsaRU6nXfcA==/original_image.mp4"
}
}
}
}
// Other ERC721 Base NFTs held by vitalik
] ,
"pageInfo" : {
"nextCursor": "eyJMYXN0VmFsdWVzTWFwIjp7Il9pZCI6eyJWYWx1ZSI6ImMzMjllODM2ZWE0MzU2ZGViZWU1ZDc3MTg5MjlhNWRiYWJkZjhjNGEwYjJmMDY2M2Y1NmQxOTU2YzlkNzViNWYiLCJEYXRhVHlwZSI6InN0cmluZyJ9LCJsYXN0VXBkYXRlZFRpbWVzdGFtcCI6eyJWYWx1ZSI6IjE2OTg5ODA2MjIiLCJEYXRhVHlwZSI6IkRhdGVUaW1lIn19LCJQYWdpbmF0aW9uRGlyZWN0aW9uIjoiTkVYVCJ9",
"prevCursor" : ""
}
}
}
}
Get NFT Balances of User(s) on Specific NFT Collection(s)
You can use Airstack to fetch NFT balance of user(s) on a specific NFT collection, e.g. Ethereum Name Service , by using the TokenBalances
API.
For the inputs, specify tokenAddress
with the NFT collection address and provide an array of users' 0x address, ENS domain, cb.id, Lens profile, or Farcaster fname/fid to owner
:
Try Demo
Code
Query Response
Copy query MyQuery {
TokenBalances(
input: {
filter : {
tokenAddress : { _eq : "0x57f1887a8BF19b14fC0dF6Fd9B2acc9Af147eA85" }
owner : {
_in : [
"0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045"
"vitalik.eth"
"lens/@vitalik"
"fc_fname:vitalik"
]
}
}
blockchain : ethereum
}
) {
TokenBalance {
id
chainId
blockchain
tokenAddress
tokenId
amount
formattedAmount
lastUpdatedBlock
lastUpdatedTimestamp
tokenType
}
}
}
Copy {
"data" : {
"TokenBalances" : {
"TokenBalance" : [
{
"id": "10x57f1887a8bf19b14fc0df6fd9b2acc9af147ea850xd8da6bf26964af9d7eed9e03e53415d37aa9604595546147854435590899330841447456946408949540847996520093152162339362490680613",
"chainId" : "1" ,
"blockchain" : "ethereum" ,
"tokenAddress" : "0x57f1887a8bf19b14fc0df6fd9b2acc9af147ea85" ,
"tokenId" : "95546147854435590899330841447456946408949540847996520093152162339362490680613" ,
"amount" : "1" ,
"formattedAmount" : 1 ,
"lastUpdatedBlock" : 17980604 ,
"lastUpdatedTimestamp" : "2023-08-23T23:10:59Z" ,
"tokenType" : "ERC721"
}
// Other ENS NFT held by vitalik
]
}
}
}
Developer Support
If you have any questions or need help regarding fetching NFT balances data, please join our Airstack's Telegram group.
More Resources