Skip to main content

YAML Based homeLAB

Project description

#Labops - A declarative, YAML-based homelab manager

A declarative, YAML-based homelab manager. labops is a CLI tool designed to simplify, automate, and standardize the setup, configuration, and maintenance of your homelab infrastructure utilizing simple configuration files and powerful backend automation.

Features

Current Capabilities

  • Declarative YAML Configuration: Define your complete homelab environment comprehensively using simple YAML configuration files.
  • Host Management: Automated setup, initialization, and system updates for a variety of host operating systems (Alpine, Debian, RedHat) powered by integrated Ansible playbooks.
  • Proxmox LXC: Update Proxmox Linux Containers (LXC) natively (through Proxmox Root Host)

Roadmap & Future Scope

  • Docker Stack Management: Seamlessly deploy, spin up, and manage Docker Compose stacks across your nodes.
  • DNS Automation: Automated updating of internal DNS records.
  • Reverse Proxy Orchestration: Manage, update, and automate reverse proxy routes

How it Works

labops acts as a bridge between simple, human-readable YAML configurations and powerful Ansible Commands.

  1. Configuration parsing: It reads a declarative .yml inventory representing your homelab layout, target servers, credentials, and settings.
  2. Validation: It validates the YAML structure and data format to stop misconfigurations early.
  3. Execution: Based on the commands executed, it triggers internal Python routines or dispatches built-in Ansible playbooks targeting the defined hosts. This ensures consistent host setups, OS updates (Debian, RedHat, Alpine), and more without writing raw playbook files manually.

Installation

You can install labops easily via pip:

pipx install labops
#or
pip install labops

Since labops is a standalone CLI tool, using pipx is highly recommended to isolate its dependencies

Usage

Once installed, the labops command becomes available. Point it to your YAML configuration file (e.g., test-samples/homelab-complete.yml):

# View all available CLI commands
labops --help

# Example: Run a setup routine for all hosts
labops host update all

Development & Building

This project utilizes Dev Containers to provide a seamless, consistent development environment, and uses uv for lightning-fast Python package management.

1. Development Environment

To start developing locally without installing system-level dependencies:

  1. Open the project in VS Code (or any editor supporting Dev Containers).
  2. When prompted, click Reopen in Container (this builds your development environment with Python, Ansible, and other necessary CLI tools pre-installed).
  3. Once the container is running and your terminal is open, sync the dependencies and activate the virtual environment:
# Create the virtual environment and install dependencies + the labops CLI
uv sync

# Activate the virtual environment
source .venv/bin/activate

# Now you can run the CLI
labops --help

2. Building the Package

The package does not have to be manually updated to PyPi, as it utalizes github actions to build and publish it.

To build the standard Python distribution files locally (Wheel .whl and Source Distribution .tar.gz) for testing:

uv build

This will generate the artifacts inside the dist/ directory.

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

labops-0.3.2.tar.gz (110.3 kB view details)

Uploaded Source

Built Distribution

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

labops-0.3.2-py3-none-any.whl (35.2 kB view details)

Uploaded Python 3

File details

Details for the file labops-0.3.2.tar.gz.

File metadata

  • Download URL: labops-0.3.2.tar.gz
  • Upload date:
  • Size: 110.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for labops-0.3.2.tar.gz
Algorithm Hash digest
SHA256 f8fdb03779d386cbfcf8261c8f0ec3eb4fc2044fd1f3b355c8533c474bdea9d4
MD5 8aa66ba6f9905e0d6eb12da904b17d1f
BLAKE2b-256 1a6a25852fef5670b38a1837b227d0bec06b417626ac12bf5c6266ce85e78dee

See more details on using hashes here.

File details

Details for the file labops-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: labops-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 35.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for labops-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 dda263bfe8dad3d421aa4077a63eb9a5fdccd57135737dd4372c6f2eaed40581
MD5 6ffd52c33ccb9db7f3f396ef458c2b27
BLAKE2b-256 3d75e4ef3eddf79159e75e32a10f0f0f575e9d785ae7130bebbc01b19e402265

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