mit einem Klick
indexing-schema
// Use when defining or editing schema.graphql. Entity types, scalar types, enums, relationships, @derivedFrom, @index, @config directives, array rules, naming conventions, and schema-to-TypeScript type mapping.
// Use when defining or editing schema.graphql. Entity types, scalar types, enums, relationships, @derivedFrom, @index, @config directives, array rules, naming conventions, and schema-to-TypeScript type mapping.
Use when writing or editing event handlers. Handler registration, context API (entity CRUD, getWhere queries, chain, log), spread updates, indexer runtime API, and common pitfalls.
Migrate a TheGraph subgraph to Envio HyperIndex using TDD. Covers schema conversion (remove @entity, Bytes->String, @derivedFrom), handler translation (save->set, store.get->context.get, templates->contractRegister), and verification against subgraph data.
| name | indexing-schema |
| description | Use when defining or editing schema.graphql. Entity types, scalar types, enums, relationships, @derivedFrom, @index, @config directives, array rules, naming conventions, and schema-to-TypeScript type mapping. |
@entity decorator (unlike TheGraph)id: ID! as first field_id suffix for relationships: token_id: String! not token: Token!| Schema Type | TypeScript Type | Notes |
|---|---|---|
ID! | string | Required on every entity |
String! | string | |
Int! | number | |
Float! | number | |
Boolean! | boolean | |
BigInt! | bigint | Use @config(precision: N) for custom precision |
BigDecimal! | BigDecimal | Use @config(precision: N, scale: M) |
Bytes! | string | Hex-encoded |
Timestamp! | Date | |
Json! | any |
enum Status {
Active
Inactive
Paused
}
type Pool {
id: ID!
status: Status!
allowedStatuses: [Status!]! # enum arrays supported
}
Virtual reverse-lookup — cannot access in handlers, only in API queries:
type Pool {
id: ID!
swaps: [Swap!]! @derivedFrom(field: "pool")
}
type Swap {
id: ID!
pool_id: String! # the FK field
}
The field argument must reference an _id relationship field on the derived entity.
Single-field index for faster queries:
type Transfer {
id: ID!
from: String! @index
to: String! @index
timestamp: BigInt! @index
}
Composite index with optional DESC direction:
type Trade @index(fields: ["poolId", ["date", "DESC"]]) {
id: ID!
poolId: String!
date: BigInt!
volume: BigDecimal!
}
["field", "DESC"] for descending@derivedFrom fields are automatically indexed@index fields are queryable via context.Entity.getWhere()Customize precision for numeric types:
type Token {
id: ID!
totalSupply: BigInt! @config(precision: 100)
price: BigDecimal! @config(precision: 30, scale: 15)
}
BigInt default precision: 76 digitsBigDecimal default: precision 76, scale 32[Type!]! — non-nullable elements, non-nullable array[Type]! (nullable elements), nested arrays, [Boolean!]!, [Timestamp!]!@derivedFrom — bare [Swap!]! without it causes a codegen errorenum PoolType {
UniswapV2
UniswapV3
}
type Pool @index(fields: ["token0_id", "token1_id"]) {
id: ID!
poolType: PoolType!
token0_id: String!
token1_id: String!
reserve0: BigInt!
reserve1: BigInt!
totalValueLocked: BigDecimal! @config(precision: 30, scale: 15)
swaps: [Swap!]! @derivedFrom(field: "pool")
}
type Swap {
id: ID!
pool_id: String! @index
sender: String! @index
amount0In: BigInt!
amount1In: BigInt!
timestamp: BigInt! @index
}
Full reference: https://docs.envio.dev/docs/HyperIndex-LLM/hyperindex-complete