Skip to content

Latest commit

 

History

History
139 lines (86 loc) · 6.95 KB

README.md

File metadata and controls

139 lines (86 loc) · 6.95 KB

🟡 Namada Indexer

Status

  • 🔧 - This project is a work in progress.
  • 🚧 - Functionality is not guaranteed at this stage.
  • ⚠️ - Use at your own risk.

About

This repository, Namada Indexer, is distinct from and incomparable to the similarly named Namada MASP Indexer.

Note that: Namada Indexer != Namada MASP Indexer && Namada MASP Indexer != Namada Indexer.

The Namada Indexer is a collection of microservices that crawls data from a Namada Node, stores it in a PostgreSQL database, and makes it accessible via a REST API.

The primary goal of the indexer is to retrieve and store the data necessary for Namadillo (the Namada Interface) to operate. Consequently, the indexer does not store historical data, except for the Transactions Service, which indexes all transactions starting from block 1 and is not used by Namadillo.

Namadillo Integration

When using this project as a backend for Namadillo, always ensure you check out the latest tag. The main branch may contain an incompatible set of APIs.

Contribution

We welcome contributions to this project! If you'd like to help, feel free to pick an issue labeled as bug or good-first-issue. If you want to propose a new feature, please open an issue first so we can discuss it.

  • For new features, target the main branch.
  • For bug fixes, check out the latest maintenance branch (e.g., 1.0.0-maint) and target your changes there.

Architecture

The Namada Indexer is composed of a set of microservices, with each component residing in its own crate. Each microservice is responsible for indexing specific data from the blockchain and storing it in the PostgreSQL database.

Microservices & Containers

  • namada/chain-indexer: Processes blocks sequentially and extracts information from transactions (e.g., balances).

  • namada/governance-indexer: Tracks new proposals and their corresponding votes.

  • namada/parameters-indexer: Retrieves the chain parameters.

  • namada/pos-indexer: Retrieves the validator set at the start of each new epoch.

  • namada/rewards-indexer: Fetches Proof-of-Stake rewards for each new epoch.

  • namada/transactions-indexer: Processes transactions starting from block height 0 (or the last successfully processed block height).

  • namada/webserver-indexer: The webserver serves indexed data via a REST API, enabling external applications and users to access blockchain data in a structured and accessible way. It listens on port 5001.

  • docker.dragonflydb.io/dragonflydb/dragonfly: This container runs a DragonflyDB instance, an advanced in-memory key-value store that acts as a caching layer. It listens on port 6379 and stores frequently accessed or temporary data, improving system performance by reducing the need for repeated database queries.

  • postgres:16-alpine: This container runs a PostgreSQL instance, serving as the primary database for storing indexed data fetched by the microservices. It listens on port 5433 and provides a reliable and scalable storage backend for the project.

Architecture

🚀 Getting Started

Follow these instructions to set up the project locally. The steps below will guide you through the process of getting a local copy up and running.

It is strongly recommended to change the default username and password for your PostgreSQL database for security purposes. Update these credentials in both the .env file and the docker-compose.yml file to reflect the changes.

🐳 Installation with Docker

Prerequisites

Before starting, ensure you have the necessary tools and dependencies installed. Below are the steps to set up the required environment.

  • Packages: Install prerequisite packages from the APT repository.
apt-get install -y curl apt-transport-https ca-certificates software-properties-common git nano just build-essential

Usage

Ensure you have the latest repository cloned to maintain compatibility with other Namada interfaces. Use the following commands to clone the repository and navigate into its directory.

git clone https://github.com/anoma/namada-indexer.git
cd namada-indexer

Create the .env file in the root of the project. You can use the .env.sample file as a reference.

cp .env.sample .env
  • The TENDERMINT_URL variable must point to a Namada RPC URL, which can be either public or local. For a public RPC URL, refer to the Namada Ecosystem Repository. If running the Namada Node locally, use the preconfigured http://host.docker.internal:26657.
  • When running locally, ensure that CometBFT allows RPC calls by setting the the configuration in your config.toml file.

Build the required Docker containers for the project.

docker compose build

Launch the Namada Indexer using the just command, which orchestrates the Docker containers.

# Run the Docker containers in the foreground, displaying all logs and keeping the terminal active until stopped.
just docker-up

# Run the Docker containers in detached mode, starting them in the background without showing logs in the terminal.
just docker-up-d

Installation without Docker

If you prefer not to use Docker, you can follow the instructions below to set up and run the services manually.

  • Install Rust and Cargo on your system. Refer to the official Rust installation guide.

  • Update the .env file with values that match your setup.

  • Use the run.sh script located inside each package to start the services.

    • The PoS package must always be running.
    • Other services can be run as needed based on your requirements.

REST API

The API endpoints are described in the swagger.yml file located in the project root. A hosted HTML version of the API documentation is available at Namada Interface Indexer REST API.

Populating the Database for Testing

Instead of fetching data from a running network, you can populate the database with random data for testing purposes. Build the project using the following command.

cargo build
# Run the seeder script to populate the database
cd seeder && cargo run -- --database-url postgres://postgres:[email protected]:5433/namada-indexer

After populating the database, you can run the webserver to access the data via the API. To query your PostgreSQL database, ensure the PostgreSQL client is installed.

apt-get install -y postgresql-client