Skip to content

seandotau/subql-helloworld

 
 

Repository files navigation

What is SubQuery?

SubQuery powers the next generation of Polkadot dApps by allowing developers to extract, transform and query blockchain data in real time using GraphQL. In addition to this, SubQuery provides production quality hosting infrastructure to run these projects in.

SubQuery Example - Hello World

This subquery example indexes the timestamp of each finalized block and it is an example of a CallHandler. By processing the timestamp.set extrinsic, and extracting the first arguments of it, we can retrieve the timestamp.

Getting Started

1. Clone the entire subql-example repository

git clone https://github.com/subquery/subql-helloworld.git

2. Install dependencies

cd subql-helloworld
yarn

3. Generate types

yarn codegen

4. Build the project

yarn build

5. Run locally

docker-compose pull & docker-compose up

5. Example query to run

query{
  starterEntities(last:5, orderBy:BLOCK_HEIGHT_ASC){
    nodes{
      blockHeight
    }
  }
}

Understanding this project

As mentioned above, this project has a function called handleBlock. It uses a BlockHandler which is defined in the manifest file (project.yaml) as "kind: substrate/BlockHandler"

The schema.graphql file defines the variables blockHeight which is mandatory and of type Int.

If we examine the function handleBlock in more detail, you can see that this function takes one argument of type SubstrateBlock. It then creates a new instance of StarterEntity passing in the block.block.header.hash argument as a string and assigning this to the variable record.

Next, the blocknumber is converted to a number via toNumber() and assigned to record.blockHeight which is a StarterEntity meaning that the fields within are accessed with a dot.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 100.0%