Skip to content

Latest commit

 

History

History

blockchain-indexer

Lisk Service Blockchain Indexer

The Blockchain Indexer service, in the indexing mode, is primarily responsible to index all the blockchain information, based on the scheduled jobs by the Blockchain Coordinator. In the data service mode, it serves user request queries made via the RESTful API or WebSocket-based RPC calls. It can run both the indexer and data service modes simultaneously, and is enabled by default.

This microservice encapsulates most of the business logic for the Lisk Service API. By default, it only implements the business logic for all the available commands from the Lisk SDK. The applyTransaction and revertTransaction hooks implement the indexing logic and are specific to each available command. The applyTransaction is triggered when processing an included transaction within a new block while (usually) indexing the chain_newBlock event. The revertTransaction hook is triggered when processing an included transaction within a deleted block while processing the chain_deleteBlock event. All the implemented hooks are grouped here. Command specific hooks are always implemented within a single file and are grouped by the module. When interested in extending Lisk Service and implementing hooks for your custom modules, please check the Extending Indexer section below.

Note that this installation instruction is required only for development activities. For a regular Lisk Service user the official documentation is sufficient to run an instance. The global readme file present in the root directory describes running all the microservices at once.

Installation

Prerequisites

Please refer to the README in the project root directory.

Installation

Clone the Lisk Service Repository:

git clone https://github.com/LiskHQ/lisk-service.git # clone repository
cd lisk-service/services/blockchain-indexer # move into blockchain-indexer microservice directory
npm ci # install required Node.js dependencies

Configuration

To configure the different microservices, there are several environment variables the user can define to customize the configurations.

A list of the most commonly used environment variables is presented below:

  • SERVICE_BROKER: URL of the microservice message broker (Redis).
  • SERVICE_INDEXER_MYSQL: Connection string of the MySQL instance that the microservice connects to.
  • SERVICE_MESSAGE_QUEUE_REDIS: URL of the job queue to process the scheduled indexing jobs by the Blockchain Coordinator (Redis).
  • SERVICE_INDEXER_REDIS_VOLATILE: URL of the volatile cache storage (Redis).
  • ENABLE_DATA_RETRIEVAL_MODE: Boolean flag to enable the Data Service mode.
  • ENABLE_INDEXING_MODE: Boolean flag to enable the Data Indexing mode.
  • ENABLE_PERSIST_EVENTS: Boolean flag to permanently maintain the events in the MySQL database.

Management

Start

cd lisk-service/services/blockchain-indexer # move into the root directory of the blockchain-indexer microservice
npm start # start the microservice with running nodes locally

Use the framework/bin/moleculer_client.js and framework/bin/moleculer_subscribe.js clients to test particular service endpoints.

If you want to run a production variant of the service, use Docker or PM2. This will automatically recover the process when it fails.

Stop

Press Ctrl+C in the terminal to stop the process.

Extending Indexer

The applyTransaction and revertTransaction hooks are arranged per command in a file and are grouped by the module that they belong to.
Existing hooks are located in the shared/indexer/transactionProcessor directory.

When implementing the custom hooks please adhere to the following:

  • Create a sub-directory with the module name. For example: token.
  • Add index.js under the above directory.
    • Export a MODULE_NAME variable. The value must match the module name as registered within the application.
  • Create a file specific to the command for which you need to implement the custom hooks. For example: transfer.
    • Export a COMMAND_NAME variable. The value must match the command name as registered within the application.
    • Implement the custom logic for the applyTransaction and revertTransaction hooks.
    • Export the hooks.
  • To aid your development, please use the sample templates here.

Contributors

https://github.com/LiskHQ/lisk-service/graphs/contributors

License

Copyright 2016-2023 Lisk Foundation

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.