avalanche-indexer

command module
v0.5.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 11, 2021 License: Apache-2.0 Imports: 1 Imported by: 0

README

Avalanche Indexer

Blockchain data indexer and API for Avalanche network.

Requirements

  • PostgreSQL 12.x+
  • Go 1.16+
  • Access to Avalanchego full node

Installation

Please see the sections below for all available methods of installation.

Build from Source

Clone the repository:

# Setup home directory for source code
mkdir -p $GOPATH/src/github.com/figment-networks
cd $GOPATH/src/github.com/figment-networks

# Clone repository
git clone git@github.com:figment-networks/avalanche-indexer.git
cd avalanche-indexer

Install dependencies:

make setup

Build the binary:

make build
Binary Releases

See Github Releases page for details.

Please note that only Linux 64bit releases are published to Github

Docker

Build the docker image with:

make docker-build

Usage

$ avalanche-indexer --help

Usage of ./avalanche-indexer:
  -cmd string
    	Command to execute
  -config string
    	Path to configuration file
  -v	Show version

Executing commands:

avalanche-indexer -config=path/to/config.json -cmd=COMMAND

Available commands:

Name Description
status Print out current indexer and node status
migrate Perform database migration
sync Run a one-time indexer sync (for testing purposes)
worker Start the indexer sync worker
server Start the indexer API server

Configuration

You can configure the service using a config file or environment variables.

Config File

Example:

{
  "database_url": "postgres://localhost/avalanche-indexer",
  "log_level": "info",
  "rpc_endpoint": "http://localhost:9650",
  "sync_interval": "60s",
  "purge_interval": "5m",
  "server_addr": "localhost:8080",
  "network_id": 1,
  "evm_network_id": 1,
  "evm_chain_id": 43114
}

For Fuji (Testnet):

  • network_id: 5
  • evm_network_id: 1
  • evm_chain_id: 43113

For Mainnet:

  • network_id: 1
  • evm_network_id: 1
  • evm_chain_id: 43114

Running Application

Once you have created a database and specified all configuration options, you need to migrate the database. You can do that by running the command below:

avalanche-indexer -config path/to/config.json -cmd=migrate

Perform the indexer check:

avalanche-indexer -config path/to/config.josn -cmd=status

Perform the initial sync:

avalanche-indexer -config path/to/config.josn -cmd=sync

If the previous step did not produce any errors, you can start the indexer worker:

avalanche-indexer -config path/to/config.json -cmd=worker

Start the API server:

avalanche-indexer -config path/to/config.json -cmd=server

API Reference

Visit API reference page to view detailed responses.

Method Path Description
GET /health Healthcheck endpoint
GET /status App version info and sync status
GET /network_stats List of network stats for a time bucket
GET /validators List of active validators
GET /validators/:id Validator details
GET /delegations List of active delegations
GET /address/:id Get address balance (X-chain/P-chain)
GET /assets Get all available assets
GET /assets/:id Get asset details by ID
GET /chains List of existing chains
GET /chain_sync_statuses Get primary chain (X/P/C) sync statuses
GET /blocks Get blocks by chain
GET /blocks/:hash Get block by hash (P/C)
GET /transactions Transactions search
POST /transactions Alternative transaction search endpoint
GET /transactions/:hash Get transaction details by hash
GET /transaction_outputs/:id Get a transaction output details by ID
GET /transaction_types Get a summary of all transcation types
GET /events Events search
GET /events/:id Get an individual event details

License

Apache License v2.0

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
cli
cmd
avm
cvm
pvm

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL