Skip to main content

Flash images onto target disks, locally or over PXE

Project description

bty mascot - a blue bat holding a PXE handshake card and a disk labelled .qcow2 / .img / .raw

bty - flash images onto target disks, from local or network sources

CI Docs Documentation PyPI Python Container License: GPL v3

Image-flash provisioning toolkit for bare-metal and virtual targets. Writes pre-built ("cooked") system images onto target disks. Three delivery shapes from the same runtime: a self-contained USB live stick, a USB stick pulling from a network-shared image catalog, or a PXE-boot server that flashes targets unattended. Configures the deployed system on first boot via cloud-init or CIJOE workflows.

bty is one Python package: the bty module, distributed on PyPI as bty-lab, with three console-script entry points:

  • bty: main CLI (image inspection, target discovery, flashing, provisioning).
  • bty-tui: terminal UI (requires the tui extra). With --server URL it doubles as a remote-flash client against a running bty-web.
  • bty-web: HTTP server with browser UI (requires the web extra).

Plus a sibling appliance-image builder under bty-media/ that produces four variants from a shared rootfs overlay: the bootable USB live image (usb-x86), the x86 server appliance (server-x86), the Raspberry Pi 4 / 5 server appliance (server-rpi), and the PXE-chain network-flash live env (netboot-x86).

For a low-friction trial of the bty-web UI without flashing anything, a multi-arch container is published to ghcr.io/safl/bty-web on every release:

docker run -d --name bty-web -p 8080:8080 -v bty-data:/var/lib/bty \
  ghcr.io/safl/bty-web:latest
# -> http://localhost:8080/ui   (login: bty / bty)

Image catalog only - no DHCP / TFTP / PXE proxy in the container (those need bare-metal LAN access; use the appliance for that). See docs/src/walkthrough-server-docker.md for bind-mount permissions, env vars, and password rotation.

Install

pipx install bty-lab            # CLI, zero third-party Python deps
pipx install "bty-lab[tui]"     # adds the bty-tui terminal UI
pipx install "bty-lab[web]"     # adds the bty-web HTTP server
pipx install "bty-lab[all]"     # everything

The CLI flow (bty list disks, bty inspect image, bty flash --dry-run) needs only Python 3.11+ and stdlib; full flashing (bty flash --yes) relies on system binaries (dd, qemu-img, zstd, lsblk, etc.) the operator's distribution is expected to provide.

Status

Pre-1.0 but actively shipping. Wheels (PyPI), appliance images (GitHub Releases), and the bty-web container (ghcr.io/safl/bty-web) all publish on every tag, and the server + client + PXE-chain end-to-end flow runs in CI on every push. The CLI surface (bty list, bty inspect, bty flash) and the bty-web HTTP/iPXE/PAM- auth surfaces are stable enough to use in homelab / CI fleets. Wire formats and CLI flags may still shift between minor versions until 1.0; the schema_version field on --json output and the Machine wire type are the things to watch. See PLAN.md for the milestone-by-milestone roadmap.

Planning and design

  • PLAN.md: roadmap and design intent.
  • docs/: full documentation (Sphinx + MyST).

Development

uv is the project's dependency manager. Install it via pipx if you don't already have it:

pipx install uv

Then sync the dev environment:

uv sync --all-extras --group dev

Run the test suite, linter, and type-checker:

uv run pytest
uv run ruff check
uv run mypy src

Documentation

The docs tooling installs as a separate pipx app:

pipx install ./docs/tooling

Then, from inside docs/:

bty-docs-serve              # live-rebuild dev server on :8000
bty-docs-build-html         # one-shot HTML build
bty-docs-build-pdf          # one-shot PDF build (requires LaTeX)

License

GPL-3.0-only.

Project details


Release history Release notifications | RSS feed

This version

0.7.8

Download files

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

Source Distribution

bty_lab-0.7.8.tar.gz (3.0 MB view details)

Uploaded Source

Built Distribution

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

bty_lab-0.7.8-py3-none-any.whl (686.7 kB view details)

Uploaded Python 3

File details

Details for the file bty_lab-0.7.8.tar.gz.

File metadata

  • Download URL: bty_lab-0.7.8.tar.gz
  • Upload date:
  • Size: 3.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for bty_lab-0.7.8.tar.gz
Algorithm Hash digest
SHA256 24e252b73bf7bc2c58c0ad9aab9f69229c57399e1ba12476225ec4fc8f140b31
MD5 35e66b1ebf7a7c4dd17174f87267373d
BLAKE2b-256 8aedb0ac6f54565a70aaaa2e19fe969ab60f118dd4babbaa3a12ec6d40614e52

See more details on using hashes here.

Provenance

The following attestation bundles were made for bty_lab-0.7.8.tar.gz:

Publisher: release.yml on safl/bty

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

File details

Details for the file bty_lab-0.7.8-py3-none-any.whl.

File metadata

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

File hashes

Hashes for bty_lab-0.7.8-py3-none-any.whl
Algorithm Hash digest
SHA256 2f5beab8ba8fd37eee7f2e0f3f88ad21f9ce532801a0b3e06e989bb0a47d5e1d
MD5 2dea1270d9b7e705b0739665b38926fe
BLAKE2b-256 6912f5c47153e3e8246e9015a4888666ddaaff4dc6552a88ce2c9ae29ccfd4e0

See more details on using hashes here.

Provenance

The following attestation bundles were made for bty_lab-0.7.8-py3-none-any.whl:

Publisher: release.yml on safl/bty

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