New Chain Integration
Reading time: 5 min
Chains can bring subgraph support to their ecosystem by starting a new graph-node
integration. Subgraphs are a powerful indexing tool opening a world of possibilities for developers. Graph Node already indexes data from the chains listed here. If you are interested in a new integration, there are 2 integration strategies:
- EVM JSON-RPC
- Firehose: All Firehose integration solutions include Substreams, a large-scale streaming engine based off Firehose with native
graph-node
support, allowing for parallelized transforms.
Note that while the recommended approach is to develop a new Firehose for all new chains, it is only required for non-EVM chains.
If the blockchain is EVM equivalent and the client/node exposes the standard EVM JSON-RPC API, Graph Node should be able to index the new chain.
For Graph Node to be able to ingest data from an EVM chain, the RPC node must expose the following EVM JSON-RPC methods:
eth_getLogs
eth_call
(for historical blocks, with EIP-1898 - requires archive node)eth_getBlockByNumber
eth_getBlockByHash
net_version
eth_getTransactionReceipt
, in a JSON-RPC batch requesttrace_filter
(optionally required for Graph Node to support call handlers)
is a next-generation extraction layer. It collects history in flat files and streams in real time. Firehose technology replaces those polling API calls with a stream of data utilizing a push model that sends data to the indexing node faster. This helps increase the speed of syncing and indexing.
The primary method to integrate the Firehose into chains is to use an RPC polling strategy. Our polling algorithm will predict when a new block will arrive and increase the rate at which it checks for a new block near that time, making it a very low-latency and efficient solution. For help with the integration and maintenance of the Firehose, contact the . New chains and their integrators will appreciate the and massive parallelized indexing capabilities that Firehose and Substreams bring to their ecosystem.
NOTE: All integrations done by the StreamingFast team include maintenance for the Firehose replication protocol into the chain's codebase. StreamingFast tracks any changes and releases binaries when you change code and when StreamingFast changes code. This includes releasing Firehose/Substreams binaries for the protocol, maintaining Substreams modules for the block model of the chain, and releasing binaries for the blockchain node with instrumentation if need be.
For EVM chains, there exists a deeper level of data that can be achieved through the geth
, a collaboration between Go-Ethereum and StreamingFast, in building a high-throughput and rich transaction tracing system. The Live Tracer is the most comprehensive solution, resulting in block details. This enables new indexing paradigms, like pattern matching of events based on state changes, calls, parent call trees, or triggering of events based on changes to the actual variables in a smart contract.
NOTE: This improvement upon the Firehose requires chains make use of the EVM engine geth version 1.13.0
and up.
While the JSON-RPC and Firehose are both suitable for subgraphs, a Firehose is always required for developers wanting to build with . Supporting Substreams allows developers to build for the new chain, and has the potential to improve the performance of your subgraphs. Additionally, Firehose — as a drop-in replacement for the JSON-RPC extraction layer of graph-node
— reduces by 90% the number of RPC calls required for general indexing.
- All those
getLogs
calls and roundtrips get replaced by a single stream arriving into the heart ofgraph-node
; a single block model for all subgraphs it processes.
NOTE: A Firehose-based integration for EVM chains will still require Indexers to run the chain's archive RPC node to properly index subgraphs. This is due to the Firehose's inability to provide smart contract state typically accessible by the eth_call
RPC method. (It's worth reminding that eth_calls
are not a good practice for developers)
Configuring Graph Node is as easy as preparing your local environment. Once your local environment is set, you can test the integration by locally deploying a subgraph.
Modify to include the new network name and the EVM JSON-RPC compliant URL
Do not change the env var name itself. It must remain
ethereum
even if the network name is different.
- Install
- Create a simple example subgraph. Some options are below:
- Adapt the resulting
subgraph.yaml
by changingdataSources.network
to the same name previously passed on to Graph Node. - Create your subgraph in Graph Node:
graph create $SUBGRAPH_NAME --node $GRAPH_NODE_ENDPOINT
- Publish your subgraph to Graph Node:
graph deploy $SUBGRAPH_NAME --ipfs $IPFS_ENDPOINT --node $GRAPH_NODE_ENDPOINT
Graph Node should be syncing the deployed subgraph if there are no errors. Give it time to sync, then send some GraphQL queries to the API endpoint printed in the logs.
For StreamingFast-led Firehose/Substreams integrations, basic support for foundational Substreams modules (e.g. decoded transactions, logs and smart-contract events) and Substreams codegen tools are included. These tools enable the ability to enable . Follow the and run substreams codegen subgraph
to experience the codegen tools for yourself.