Skip to main content

How to retrieve a Collection using Ternoa Indexer

Ternoa indexer is a record of the Ternoa Chain data. You can query data for some specific entities (NFT, Collection, Marketplace(...)) using GraphQL. In this exemple, we use the graphql-request library.

Step 1: CollectionEntity query preparation​

You first need to prepare a stringified query to get Collection data from a specific collection id. Here are detailed the paramaters available for the CollectionEntity:

`collectionId`: The collection id.- String
`owner`: The collection owner; null if the collection is burned. - String | null
`offchainData`: The collection off-chain data (e.g. IPFS CID hash, a link or any string). - String
`nfts`: An array of the NFT ids in the collection - String[]
`nbNfts`: The number of NFT in the collection. - Number
`limit`: The collection limit if set; null otherwise. - Number | null
`hasReachedLimit`: true if the Collection has reach its limit; false otherwise. - Boolean
`isClosed`: - Boolean flag: true if the Collection is a closed; false otherwise. - Boolean
`timestampCreated`: The creation timestamp. - Date
`timestampBurned`: The burning timestamp. - Date | null
`timestampClosed`: The closing timestamp.- Date | null
`timestampLimited`: The limit setting timestamp. - Date | null

For example, if we want to get the Collection: owner / id; we have to prepare the following query by replacing COLLECTION_ID with the collection id you want to get the information from (e.g. the collection id from the Collection minted previously in "How to mint a Collection on-chain"):

{
collectionEntity(id: "_COLLECTION_ID_") {
owner
collectionId
offchainData
}
}

Step 2: Sending the request to the Indexer​

Once the query is ready, you can make the request to our Indexer instances by providing both the indexer endpoint and the query.

Replace COLLECTION_ID in the following code snippet with the collection ID previouly generated in "How to mint a Collection on-chain"):

import { request, gql } from "graphql-request";

const COLLECTION_ID = 0;
const query = (id: number) => gql`
{
collectionEntity(id: "${id}") {
owner
collectionId
offchainData
}
}
`;

const getCollectionData = async () => {
try {
const response = await request<{ collectionEntity: CollectionType }>(
"https://indexer-alphanet.ternoa.dev",
query(COLLECTION_ID)
);
console.log(response);
} catch (error) {
console.error(error);
}
};

type CollectionType = {
owner: string;
offchainData: string;
collectionId: string;
};

The getCollectionData function is an asynchronous function that sends a GraphQL request using the request function from the "graphql-request" library. Here we are using the Ternoa Alphanet instance at "https://indexer-alphanet.ternoa.dev" with the Collection ID 0 as the query parameter (you can try with your id). The response from the server is an object with a property collectionEntity that has the data of the requested Collection entity.

The response for the collection id 0 the the Alphanet Network is:

{
"data": {
"collectionEntity": {
"owner": "5DoaPm79MrWUQpFSDBhpmotRp344dc9eM4NV8aRb3vHEuzxH",
"collectionId": "0",
"offchainData": "test"
}
}
}

How to retrieve the last Collection minted using Ternoa Indexer​

Ternoa Indexer comes with filtering and ordering options. Instead of requesting a single CollectionEntity with a specific collection ID, you can filter all CollectionEnties:

{
collectionEntities(orderBy: [TIMESTAMP_CREATE_DESC]) {
nodes {
owner
collectionId
timestampCreate
}
}
}

The NFT in the response will be ordered by creation timestamp descendent with orderBy: [TIMESTAMP_CREATE_DESC].

The response on the the Alphanet Network when this document is written is:

{
"data": {
"collectionEntities": {
"nodes": [
{
"owner": "5DZimWjGDoeEtaUJo5DaFZQdHWGBd3wHjZokDqZjCzYFEuYb",
"collectionId": "585",
"timestampCreate": "2023-02-22T12:17:00.001"
},
{
"owner": "5DZimWjGDoeEtaUJo5DaFZQdHWGBd3wHjZokDqZjCzYFEuYb",
"collectionId": "584",
"timestampCreate": "2023-02-22T12:16:48.001"
},
...
]
}
}
}

The last Collection minted on the Ternoa chain is the collection 585.

Support​

If you face any trouble, feel free to reach out to our community engineers in our Discord.