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

Optional extras:

  • vm — enables the xian_vm_v1 bindings.
  • native — enables native admission helpers for development and release validation.

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.13.tar.gz (183.8 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.13-py3-none-any.whl (256.2 kB view details)

Uploaded Python 3

File details

Details for the file xian_tech_abci-0.8.13.tar.gz.

File metadata

  • Download URL: xian_tech_abci-0.8.13.tar.gz
  • Upload date:
  • Size: 183.8 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.13.tar.gz
Algorithm Hash digest
SHA256 51a151a9a30f2fff626dc7bb3303da11465ff888c4b8c7ae3157942e7c48e5eb
MD5 7bdb1fced2cbdf3640079da54a6b89ff
BLAKE2b-256 43d1d30f87d2739a61b6e7478ea96699ae90736cf1312035d57cd47ad7485cd0

See more details on using hashes here.

Provenance

The following attestation bundles were made for xian_tech_abci-0.8.13.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.13-py3-none-any.whl.

File metadata

  • Download URL: xian_tech_abci-0.8.13-py3-none-any.whl
  • Upload date:
  • Size: 256.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for xian_tech_abci-0.8.13-py3-none-any.whl
Algorithm Hash digest
SHA256 bb2332900b90dd7d39ddef8b436d34d60401bb92cc44d6607214f6a6ecd009c4
MD5 6eaf159f66d0df071ec44667c831fc76
BLAKE2b-256 dd6bd98d9d469857997f03935fbf2c391e229893fbbef93c6c7ce2da4fbe160d

See more details on using hashes here.

Provenance

The following attestation bundles were made for xian_tech_abci-0.8.13-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