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.15.tar.gz (193.9 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.15-py3-none-any.whl (267.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: xian_tech_abci-0.8.15.tar.gz
  • Upload date:
  • Size: 193.9 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.15.tar.gz
Algorithm Hash digest
SHA256 966d2f3811a5d19aa700df795c58e79adecd2851f3815b5b98e790a5f8fc131d
MD5 3ee433cde3939ebbb5e1dd18657b4c08
BLAKE2b-256 8621770e59b5723d6e5119aa9452e2670b4fc1d6ddbf6cfcd2d957be9098f318

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: xian_tech_abci-0.8.15-py3-none-any.whl
  • Upload date:
  • Size: 267.3 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.15-py3-none-any.whl
Algorithm Hash digest
SHA256 e5468b2742fde883016b4fac87202f36aa7535eeac5559a0a3f760bbd6f76dac
MD5 9a0f554de86ea7bdd08ca6e21e73524c
BLAKE2b-256 aa75a4d79bbd3e00aeaf3d108acba630073c1beaca026cdd373e88cd8d781ce3

See more details on using hashes here.

Provenance

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