This is the backend service for the Iroha 2 Block Explorer Web application. It is written in Rust and provides a classic HTTP-API way to observe data in Iroha 2.
Note that the current implementation is more of a draft and is not production ready. This implementation maintains an in-memory normalised SQLite database that reflects the history of blocks (transactions, instructions) in Iroha and its current world state (domains, accounts, assets). The database is re-created from scratch on each update in Iroha, which is not suitable for a large scale. The rationale of using an SQL-based solution is that currently, Iroha Query API is limited and cannot provide some features that are necessary for efficient Explorer implementation (e.g. selects and joins). However, having an SQL-based querying allows creating a set of endpoints to serve the frontend needs efficiently, allowing at least the frontend implementation as desired.
Prerequisites: Rust toolchain.
Install from this repo remotely:
cargo install --git https://github.com/soramitsu/iroha2-block-explorer-backend
iroha_explorer helpOr build and run locally from the repo with:
cargo run --release -- helpUse help for detailed usage documentation. In short:
- serveto run the server
- scanto scan Iroha ones and save into a database (for troubleshooting)
- pass --torii-urls,--account, and--account-private-keyoptions to configure connection to Iroha
For example:
# via ENVs; also could be passed as CLI args
export IROHA_EXPLORER_ACCOUNT=<account id>
export IROHA_EXPLORER_ACCOUNT_PRIVATE_KEY=<acount private key>
# At least one URL is required, the rest are for telemetry gathering
export IROHA_EXPLORER_TORII_URLS=http://localhost:8080,http://localhost:8081
iroha_explorer serve --port 4123
iroha_explorer scan ./scanned.sqliteWith the running server, open /api/docs path (e.g. http://localhost:4123/api/docs) for API documentation.
Iroha Explorer supports gathering telemetry from multiple nodes. You have to provide API URLs (Torii URLs) of each peer for that:
iroha_explorer serve --torii-urls http://localhost:8080,http://localhost:8081,http://localhost:8082The documentation of the telemetry endpoints is available in the OpenAPI Documentation.
To configure logging, use RUST_LOG env var. For example:
RUST_LOG=iroha_explorer=debug,sqlx=debugtest "$(curl -fsSL localhost:4000/api/health)" = "healthy" && echo OK || echo FAILOnly available in debug builds.
Serve test data without connecting to Iroha:
cargo run -- serve-testNote: telemetry data will be unavailable in this case.
Iroha Explorer aims to support only the latest version of Iroha. Currently it is v2.0.0-rc.2.x.
For reference:
| Iroha | Iroha Explorer Backend (tags) | Iroha Explorer Web (tags) | 
|---|---|---|
| v2.0.0-rc.2.x | v0.2.x | v0.2.0 | 
| v2.0.0-rc.1.x1 | v0.1.0 | v0.1.0 | 
Footnotes
- 
Iroha versions rc.1.3andrc.1.4are not compatible with Explorer because of accidental breaking changes introduced in Iroha itself. Use versionrc.1.5. ↩