Skip to main content

cBOX@ /Container Control — Bash-Bootstrap und Python-Werkzeug für nested LXC-Stacks (Proxmox VE 9 + Debian/Ubuntu). cBOX.at/YOU by XED.dev Tools via Collective Context (CC).

Project description

XED /CCC — cBOX@ /Container Control

Bash-Bootstrap und Werkzeuge für nested LXC-Stacks auf Proxmox VE 9 mit Debian 13 / Ubuntu 24.04+.

Status: Stufe 1 — firstboot.sh v0.7.0 (DE/EN-TUI, idempotent, ccc-Self-Install) + ccc v0.0.1 (Python-Skelett) Lizenz: MIT Distribution: https://ccc.xed.dev (Bash) · https://pypi.org/project/xed-ccc/ (Python)


Schnellstart

In jeder frischen Debian/Ubuntu-LXC-Box als root:

# Pre-Step (minimal-LXC-Templates haben kein curl vorinstalliert):
apt update && apt install -y curl ca-certificates

# firstboot.sh ausführen:
bash <(curl -s https://ccc.xed.dev/firstboot.sh)

Oder als One-Liner:

apt-get update -qq && apt-get install -y -qq --no-install-recommends curl ca-certificates && bash <(curl -s https://ccc.xed.dev/firstboot.sh)

Das setzt Zeitzone, Locales, Default-Editor und Basis-Pakete — alles via Whiptail-TUI im Debian-Installer-Stil. Idempotent: kann beliebig oft wiederholt werden.

UX-Pattern (seit v0.5.0)

  • Sechs-Phasen-State-Machine mit <Zurück>-Button: Sprache → Zeitzone → Locales → Default-Locale → Pakete → Übersicht. Im ersten Dialog ist Cancel = Abort-Confirmation, sonst Cancel = zurück zur vorherigen Phase.
  • DE/EN-Sprachwahl als allererster Dialog. Alle weiteren Whiptail-Texte sind übersetzt; info/ok/err-Logs bleiben deutsch.
  • Idempotente Pre-Selection beim Re-Run:
    • Locales: drei-wertige Erkennung via /etc/locale.gen (ACTIVE/DISABLED/ABSENT). User-Wille wird respektiert — abgewählte Locales kommen nicht als Default-ON wieder.
    • Pakete: Marker-Datei /var/lib/xed-ccc/firstboot.applied trennt allerersten Run (Skript-Defaults greifen) vom Re-Run (nur dpkg-Ist-Zustand zählt).
  • Deselect = Uninstall/Disable: bei Pakete mit Yesno-Confirmation (Daten-Verlust-Schutz), bei Locales ohne (reversibel).
  • Optionaler apt dist-upgrade + autoremove + autoclean-Schritt am Ende, nur wenn Updates verfügbar sind. Yesno-Prompt im interaktiven Modus, ENV DIST_UPGRADE=yes für Auto-Run.

Non-Interactive (CI / Auto-Provisioning)

TZ=UTC \
  LOCALES="de_AT.UTF-8 en_US.UTF-8" \
  DEFAULT_LOCALE=de_AT.UTF-8 \
  PKGS="htop curl wget sudo psmisc net-tools iproute2 iputils-ping gnupg nano" \
  bash <(curl -s https://ccc.xed.dev/firstboot.sh)

TTY-Hinweis

bash <(curl -s URL) (Process Substitution) bewahrt das TTY und erlaubt interaktive Whiptail-Dialoge. curl URL | bash (klassische Pipe) verbraucht stdin und erzwingt Non-Interactive-Mode mit ENV-Defaults.


Was firstboot.sh tut

Phase Inhalt
0 Pre-Flight (root-Check, Distro-Check, apt-Bootstrap, TTY-Detect)
1 Eingaben sammeln (Whiptail bei TTY, ENV-Vars sonst)
2 Zeitzone setzen (/etc/timezone + /etc/localtime)
3 Locales generieren + Default-Locale (update-locale/etc/default/locale)
4 Basis-Pakete installieren (--no-install-recommends)
5 EDITOR=nano in /etc/environment (idempotent via grep-vor-write)
5b Optional: apt dist-upgrade + autoremove + autoclean (Yesno)
6 Editor-Eintrag
7 XED /CCC Python-Tool installieren (Yesno) — apt python3-Stack + git clone + venv + symlink
8 Abschluss-Banner + Marker-Datei

Bewusst nicht enthalten: Bridge-/iptables-/nested-LXC-Setup. Das kommt mit lxc-host-setup.sh (Skript 2/3, geplant) als separates Skript für cBOX-Outer-Container.


Phase 2 — ccc (Python-Tool, ab v0.0.1)

Nach firstboot.sh kommt das Python-Tool für Rollen-Konfiguration — Pendant zu pct aus Proxmox, aber innerhalb der LXC-Box laufend.

Installation (zwei Wege)

# Variante A — automatisch via firstboot.sh Phase 7 (empfohlen für frische Boxen):
#   firstboot.sh fragt nach ccc-Installation, klont Repo nach /opt/xed-ccc/,
#   baut venv und symlinkt /usr/local/bin/ccc in einem Schritt.

# Variante B — PyPI (für SysOps die Python kennen, bestehende Boxen):
pipx install xed-ccc      # isolierte Tool-Installation (empfohlen)
pip install xed-ccc       # System-Python (mit pep668-bypass)

Updates (nach Erst-Installation):

# Variante A — firstboot.sh Re-Run (Phase 7 macht fetch+reset im /opt/xed-ccc/):
bash <(curl -s https://ccc.xed.dev/firstboot.sh)

# Variante B — pipx-Pfad:
pipx upgrade xed-ccc

# Geplant — Self-Update als Python-Verb:
ccc update

Verben (analog pct)

ccc list                  # verfügbare Rollen mit Status
ccc create pmDESK         # Rolle in aktueller Box installieren
ccc create pmDESK --dry-run  # nur Plan zeigen
ccc menu                  # interaktive TUI (Stub, Textual kommt später)
ccc --version
ccc --help

Rollen-Roadmap

Rolle Beschreibung Status
pmDESK Debian/Ubuntu Gnome-Desktop (xrdp + Gnome-Stack) Stub (Plan)
lxcHOST Firewall + Public-IP + Outer-Container für nested LXC geplant
osNGINX Reverse-Proxy + WordOps geplant
commBOX Communication-Stack (Mail, DNS, Webmail) geplant

Roadmap

Skript Zweck Status
firstboot.sh Basis-Setup für jede frische Debian/Ubuntu-Box Stufe 1, live
lxc-host-setup.sh Outer-Container vorbereiten (Bridge, iptables, nested LXC) geplant
ccc-create.sh Inner-Container provisionieren (Bash v1) geplant
ccc (Python) CLI als Pendant zu pct (Typer + Pydantic) geplant
ccc-tui (Python) Textual-TUI als Pendant zum Proxmox-Webinterface geplant

Architektur und Designentscheidungen: siehe WHITEPAPER.md im Entwicklungs-Workspace (privat).


Designprinzipien

  • Vertrautheit > Eleganzcccpct semantisch, ccc-tui ≈ Proxmox-Webinterface
  • Drei-Skripte-Modell statt Universal-Skript mit Modus-Switch
  • Idempotenz (mailinabox-Stil) — curl ... | bash jederzeit wiederholbar
  • Kaizen — kleine Schritte, ausprobieren statt endlos planen
  • Bash für einmalige Setups, Python für wachsende Werkzeuge

Lizenz

MIT — siehe LICENSE.

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

xed_ccc-0.1.1.tar.gz (27.9 kB view details)

Uploaded Source

Built Distribution

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

xed_ccc-0.1.1-py3-none-any.whl (35.2 kB view details)

Uploaded Python 3

File details

Details for the file xed_ccc-0.1.1.tar.gz.

File metadata

  • Download URL: xed_ccc-0.1.1.tar.gz
  • Upload date:
  • Size: 27.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for xed_ccc-0.1.1.tar.gz
Algorithm Hash digest
SHA256 cdd24542625680a307537c3af2586fd1b2a1a2573bb7dfb776015529f8b935a1
MD5 45e300ef0201f9eb26b2823e36f0c1cf
BLAKE2b-256 e063ff30e99d4ca50f1d34deeaf2974617eae3769c75bdb52f2daea198f6f492

See more details on using hashes here.

File details

Details for the file xed_ccc-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: xed_ccc-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 35.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for xed_ccc-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 45a8cca98eb5ebd5ce4a68a28289e3babca028b8ee46ac09e75769eb034518fd
MD5 76a6f2ca95f52b97fcbf11b7e114589d
BLAKE2b-256 d777cd6c7c3f5ba0ca51036e3b4001777ee2b0c287cb1d2791d8cbf502f051f0

See more details on using hashes here.

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