Overview
The subgraph manifest, and all the files linked from it, is what is deployed to IPFS and hashed to produce a subgraph ID that can be referenced and used to retrieve your subgraph in The Graph.Format
Any data format that has a well-defined 1:1 mapping with the IPLD Canonical Format may be used to define a subgraph manifest. This includes YAML and JSON. Examples in this document are in YAML.Top-Level API
A Semver version indicating which version of this API is being used.
An optional description of the subgraph’s purpose.
An optional link to where the subgraph lives.
Each data source spec defines the data that will be ingested as well as the transformation logic to derive the state of the subgraph’s entities based on the source data.
Each data source template defines a data source that can be created dynamically from the mappings.
A list of feature names used by the subgraph. Required when
specVersion is 0.0.4 or higher.Schema
The path of the GraphQL IDL file, either local or on IPFS.
Data Source
The type of data source. Possible values:
ethereum/contract, near/account, cosmos/contract, arweave, starknet/contract.The name of the source data. Will be used to generate APIs in the mapping and also for self-documentation purposes.
For blockchains, this describes which network the subgraph targets.For Ethereum, this can be any of:
mainnet, sepolia, goerli, polygon, mumbai, arbitrum-one, arbitrum-sepolia, optimism, base, bsc, fantom, gnosis, avalanche, and others.Check the graph-cli code for the most up-to-date list.The source data on a blockchain such as Ethereum.
The transformation logic applied to the data prior to being indexed.
EthereumContractSource
The address of the source data in its respective blockchain. Optional for templates.
The name of the ABI for this Ethereum contract. Must reference an ABI defined in the
mapping.abis section.The block to start indexing this data source from. Defaults to genesis block (0).
Mapping
Ethereum Mapping
Must be
ethereum/events for Ethereum Events Mapping.Semver string of the version of the Mappings API that will be used by the mapping script.
The language of the runtime for the Mapping API. Possible values:
wasm/assemblyscript.A list of entities that will be ingested as part of this mapping. Must correspond to names of entities in the GraphQL IDL.
ABIs for the contract classes that should be generated in the Mapping ABI. Name is also used to reference the ABI elsewhere in the manifest.
Handlers for specific events, which will be defined in the mapping script.
A list of functions that will trigger a handler and the name of the corresponding handlers in the mapping.
Defines block filters and handlers to process matching blocks.
The path of the mapping script.
Each mapping is required to supply one or more handler type:
eventHandlers, callHandlers, or blockHandlers.Handler Types
EventHandler
An identifier for an event that will be handled in the mapping script. For Ethereum contracts, this must be the full event signature to distinguish from events that may share the same name.No alias types can be used. For example,
uint will not work, uint256 must be used.The name of an exported function in the mapping script that should handle the specified event.
A
0x prefixed hex string. If provided, events whose topic0 is equal to this value will be processed by the given handler.When topic0 is provided, only the topic0 value will be matched, and not the hash of the event signature. This is useful for processing anonymous events in Solidity.A list of predeclared
eth_calls that will be made before running the handler. Available from spec version 1.2.0.CallHandler
An identifier for a function that will be handled in the mapping script. For Ethereum contracts, this is the normalized function signature to filter calls by.
The name of an exported function in the mapping script that should handle the specified event.
BlockHandler
The name of an exported function in the mapping script that should handle the specified event.
Definition of the filter to apply. If none is supplied, the handler will be called on every block.
BlockHandlerFilter
The selected block handler filter. Options:
call: Only run the handler if the block contains at least one call to the data source contractpolling: Run the handler every N blocks (use witheveryfield)once: Run the handler once at initialization
For
polling filters, specifies how many blocks between handler invocations.Declaring Calls
Available from spec version 1.2.0. Struct field access available from spec version 1.4.0.
ethereum.call from the mappings.
Call Format
Each call is of the form<ABI>[<address>].<function>(<args>):
A label for the call for error messages.
The call specification string.
The name of an ABI from the
abis section.The address of a contract that follows the ABI.
The name of a view function in the contract.
The arguments to pass to the function.
Expression Types
TheExpr can be one of the following:
| Expression | Description |
|---|---|
event.address | The address of the contract that emitted the event |
event.params.<name> | A simple parameter from the event |
event.params.<name>.<index> | A field from a struct parameter by numeric index |
event.params.<name>.<fieldName> | A field from a struct parameter by field name (spec version 1.4.0+) |
Path
A path has one fieldpath, which either refers to a path of a file on the local dev machine or an IPLD link.
When using the Graph-CLI, local paths may be used during development, and then, the tool will take care of deploying linked files to IPFS and replacing the local paths with IPLD links at deploy time.
A path to a local file or IPLD link.
Data Source Templates
A data source template has all of the fields of a normal data source, except it does not include a contract address undersource. The address is a parameter that can later be provided when creating a dynamic data source from the template.
Grafting
A subgraph can be grafted on top of another subgraph, meaning that, rather than starting to index the subgraph from the genesis block, the subgraph is initialized with a copy of the given base subgraph, and indexing resumes from the given block.The subgraph ID of the base subgraph.
The block number up to which to use data from the base subgraph.
Features
Starting fromspecVersion 0.0.4, a subgraph must declare all feature names it uses to be considered valid.
A Graph Node instance will reject a subgraph deployment if:
- The
specVersionis equal to or higher than0.0.4AND - It hasn’t explicitly declared a feature it uses
Available Features
| Feature | Name |
|---|---|
| Non-fatal errors | nonFatalErrors |
| Full-text Search | fullTextSearch |
| Grafting | grafting |
| IPFS on Ethereum Contracts | ipfsOnEthereumContracts |
Complete Example
Best Practices
- Performance
- Reliability
- Maintainability
- Set appropriate
startBlockvalues to avoid unnecessary indexing from genesis - Use declared calls (available from spec 1.2.0) to parallelize RPC calls
- Limit the number of entities in your schema to what’s actually needed
- Use block handlers sparingly as they run on every block

