Grants Stack Indexer v2 is a tool designed to index blockchain events generated by Allo contracts, making the data accessible over HTTP in JSON format. The data is organized in a structure that enables efficient querying and easy access to key components of the protocol.
This repository is a monorepo that contains 8 packages and 3 applications:
-
@grants-stack-indexer/indexer: An Envio indexer service that collects relevant events from Allo contracts. It is designed to run on the Envio hosted platform and includes a Dockerfile for deployment.
-
@grants-stack-indexer/processing: This service runs the core processing pipeline, coordinating components from various packages to process blockchain events. It manages an Orchestrator per chain.
-
@grants-stack-indexer/scripts: Contains scripts for managing the database schema and migrations. It includes scripts for running migrations and resetting the database schema.
-
@grants-stack-indexer/chain-providers: Provides wrappers of the Viem library to interact with EVM-based blockchains. It includes utilities for reading contracts and making batch requests.
-
@grants-stack-indexer/data-flow: Manages the flow of data between different components of the indexer. It includes core components for the processing pipeline.
-
@grants-stack-indexer/indexer-client: A client library for interacting with blockchain event indexing services. It provides methods to fetch events by block number and log index.
-
@grants-stack-indexer/metadata: Handles metadata related to the indexed events. It provides a metadata provider to retrieve metadata from IPFS.
-
@grants-stack-indexer/pricing: Manages pricing data and calculations. It includes providers to get the price of a token at a specific timestamp using chainId and token address.
-
@grants-stack-indexer/processors: Contains various data processors used in the indexing pipeline. It includes processors for handling Allo, Strategy, and Registry events.
-
@grants-stack-indexer/repository: Manages the storage and retrieval of indexed data. It implements the Repository pattern to abstract database operations.
-
@grants-stack-indexer/shared: Provides shared utilities, types, constants, and logger. It is designed to be used across the packages of the monorepo to ensure consistency and reusability.
Ensure you have the following installed on your machine:
- Copy the Example Environment File and edit the
.env
file
cp .env.example .env
- Build and start the services in detached mode:
docker-compose up -d --build
- Copy the Example Environment File on
scripts/migrations
and edit the.env
file
cp scripts/migrations/.env.example scripts/migrations/.env
- After starting Docker Compose, run the following command to apply the database migrations:
pnpm db:migrate
- Copy the Example Environment File on
apps/processing
and edit the.env
file
cp apps/processing/.env.example apps/processing/.env
- Start the Processing service with:
pnpm dev
Once the setup is completed you can access Hasura by navigating to:
http://localhost:8082/
Use the default password: my-admin-secret
.
Wonderland is a team of top Web3 researchers, developers, and operators who believe that the future needs to be open-source, permissionless, and decentralized.
DeFi sucks, but Wonderland is here to make it better.
We follow the Conventional Commits specification.
This project is licensed under the MIT License. See the LICENSE
file for more details.