Skip to main content

Python-based ABCI server for CometBFT

Project description

xian-abci

xian-abci is the CometBFT-facing Xian node runtime. It owns deterministic chain execution, ABCI request handling, state export and snapshot flows, and the node-adjacent services (BDS indexing, metrics, the optional dashboard) that run alongside a Xian validator or full node.

The published PyPI package is xian-tech-abci. Console entrypoints (xian-abci, xian-dashboard, xian-configure-node, and the BDS / state helpers) are installed by the package and used both directly and from the operator-facing xian-cli.

Runtime Shape

flowchart LR
  CometBFT["CometBFT"] --> ABCI["ABCI handlers"]
  ABCI --> Executor["Transaction processor"]
  Executor --> Contracting["xian-contracting runtime"]
  Executor --> State["Chain state"]
  State --> BDS["BDS indexer"]
  State --> Snapshots["Export and snapshot tools"]
  ABCI --> Metrics["Metrics"]
  ABCI --> Dashboard["Optional dashboard"]
  CLI["xian-cli and xian-stack"] --> Entrypoints["xian-abci entrypoints"]

Quick Start

Bootstrap the development environment with uv:

UV_CACHE_DIR=/tmp/uv-cache uv sync --group dev

Inspect the available command surface:

uv run xian-abci --help
uv run xian-dashboard --help
uv run xian-configure-node --help
uv run xian-export-state --help
uv run xian-state-snapshot --help
uv run xian-bds-reindex --help
uv run xian-bds-snapshot --help
uv run xian-bds-spool --help
uv run xian-parallel-estimator-report --help

Optional extras:

  • vm — enables the xian_vm_v1 bindings.
  • native — enables native admission helpers for development and release validation.
  • zk — enables the native zk verifier required by nodes on chains with the zk runtime feature.

For a ready-made local network instead of wiring the node yourself, use xian-stack. This repo focuses on the runtime and backend tooling, not the full localnet UX.

Principles

  • Deterministic chain execution. The ABCI handlers, transaction execution, rewards, validators, and query behavior live here and must be deterministic across nodes.
  • Backend, not UX. Operator-facing lifecycle commands belong in xian-cli. This repo exposes importable helpers and backend-oriented CLIs only.
  • Universal node runtime. No network-specific genesis files, seeds, or snapshots. Committed chain assets live in xian-configs.
  • Contract semantics live elsewhere. Changes to contract execution semantics belong in xian-contracting, not here.
  • No Compose / orchestration. Container lifecycle and local-stack orchestration belong in xian-stack.

Local uv development requires a sibling checkout of ../xian-contracting. Full validation also uses sibling checkouts of ../xian-contracts, ../xian-configs, and ../xian-stack.

Key Directories

  • src/xian/ — repo-owned node runtime: ABCI handlers, services, utilities, and CLI entrypoints.
    • methods/ — ABCI request handlers (CheckTx, DeliverTx, Commit, …).
    • services/ — background services such as the simulator and BDS support.
    • cli/ — backend and developer entrypoints (configure-node, export-state, BDS helpers, …) wrapping importable helpers.
    • tools/ — one-off upgrade data and state-patch payloads. Treated as a transition area; new code should live as importable helpers under src/xian/.
    • dashboard/ — the optional operator dashboard.
  • src/abci/ — lower-level ABCI server and protocol glue.
  • protos/ — vendored CometBFT schemas plus supporting protobuf dependencies.
  • build_proto.py — regenerates checked-in protobuf Python stubs under src/.
  • scripts/ — repo-level validation and manual benchmark entrypoints.
  • tests/ — unit, ABCI-method, integration, governance, tools, and system coverage.
  • docs/ — architecture notes, API surface, safety invariants, snapshots / pruning model, governance, and backlog.

Validation

Preferred full validation entrypoint, used for releases:

./scripts/validate-release.sh

It defaults to Python 3.14 (override with XIAN_ABCI_VALIDATE_PYTHON) and runs:

  • ./scripts/validate-repo.sh
  • protobuf regeneration / stale-stub checks
  • the Python-vs-native processor fuzz parity coverage (tests/integration/test_vm_processor_fuzz.py)

Faster local loops:

UV_CACHE_DIR=/tmp/uv-cache uv run ruff check .
UV_CACHE_DIR=/tmp/uv-cache uv run ruff format --check .
UV_CACHE_DIR=/tmp/uv-cache uv run pytest
UV_CACHE_DIR=/tmp/uv-cache uv run pytest tests/unit/test_node_setup.py

CI provisions Postgres for the BDS-backed paths. To mirror that locally, expose Postgres at postgres://postgres:1234@localhost:5432/xian.

Related Docs

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

xian_tech_abci-0.8.17b1.tar.gz (259.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xian_tech_abci-0.8.17b1-py3-none-any.whl (331.0 kB view details)

Uploaded Python 3

File details

Details for the file xian_tech_abci-0.8.17b1.tar.gz.

File metadata

  • Download URL: xian_tech_abci-0.8.17b1.tar.gz
  • Upload date:
  • Size: 259.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for xian_tech_abci-0.8.17b1.tar.gz
Algorithm Hash digest
SHA256 2f5da650953a138d3aeaf3244eb1ea58a9b37f165ca1ccfd102ad9a4bd489ce8
MD5 ae750894b063821c5b30f2c6d421a767
BLAKE2b-256 4e6436a5d611b4074efe0961606ab1673012356c3cf43fa37d8f226ad20570bd

See more details on using hashes here.

Provenance

The following attestation bundles were made for xian_tech_abci-0.8.17b1.tar.gz:

Publisher: release.yml on xian-technology/xian-abci

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file xian_tech_abci-0.8.17b1-py3-none-any.whl.

File metadata

File hashes

Hashes for xian_tech_abci-0.8.17b1-py3-none-any.whl
Algorithm Hash digest
SHA256 b24dd318bbe77d9b54f3de92ee35e126f1e7e040ff05da77294a4cecf0730599
MD5 4d0d481bd5463c69820b47b5b2076fb6
BLAKE2b-256 c33154ba48768dd0f17a5f9599e787eb41c62183f3cbe7be6c0cce194a690990

See more details on using hashes here.

Provenance

The following attestation bundles were made for xian_tech_abci-0.8.17b1-py3-none-any.whl:

Publisher: release.yml on xian-technology/xian-abci

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page