Skip to main content

base classes for microservice servers and matrix display pages

Project description

plain_pages

Minimalist base classes for microservice servers and matrix display pages.

plain_pages is a lightweight Python package that provides two foundational classes—ServerPage and DisplayPage—designed to orchestrate real-time data collection and visual display in homelab environments. It’s built for clarity, composability, and just enough abstraction to stay out of your way.

✨ Why plain_pages?

This project grew out of a desire to keep things simple—but not simplistic. In a homelab where services talk over Redis, update displays via RGB matrices, and pull secrets from Vault or Kubernetes, plain_pages offers a clean interface for:

  • Scheduling periodic updates
  • Fetching and publishing data
  • Rendering to LED panels or web displays
  • Managing secrets and state with minimal ceremony

🧱 Core Components

ServerPage

A base class for microservices that:

  • Reads secrets from Vault, Kubernetes, or environment
  • Connects to Redis and a backing database (Postgres, SQLite, MongoDB)
  • Periodically fetches data from external APIs
  • Writes state to the backing database, and
  • Publishes updates via Redis pub/sub
  • Supports liveness probes and production/development modes

DisplayPage

A base class for display clients that:

  • Reads data from the database
  • Tracks freshness and avoids redundant redraws
  • Provides helper methods for text alignment, color formatting, and time parsing
  • Supports both RGB LED matrix output and static image generation (for testing without RGB LED hardware)

🌕 Example: Moon Phase Tracker

The examples/moon_clock/ directory (coming soon) includes:

  • MoonServer: Fetches sun/moon data from MET Norway’s API and publishes it
  • MoonDisplay: Renders current time, moon phase, and next moonrise/set on an RGB matrix
  • clientdisplay.py: Drives the LED panel and handles display cycling, pause/play, and override logic via Redis

📦 Installation

pip install dekeyrej-plain-pages

🛠️ Usage

from pages.serverpage import ServerPage
from pages.displaypage import DisplayPage

class MyServer(ServerPage):
    def update(self):
        # Fetch data, write to DB, publish to Redis
        pass

class MyDisplay(DisplayPage):
    def display(self):
        # Render data to matrix or image
        pass

🔐 Secrets & Config

ServerPage supports multiple secret sources from dekeyrej-secretmanager:

  • KubeVault - encrypted Kubernetes Secrets with Vault Transit decrypt
  • Kubernetes Secrets
  • Vault static keys - coming soon!
  • Environment variables
  • Local JSON files

🧪 Status

This project is under active development. Expect updates, refinements, and the occasional moonbeam.

📄 License

MIT License. See LICENSE for details.

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

dekeyrej_plain_pages-0.9.7.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

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

dekeyrej_plain_pages-0.9.7-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file dekeyrej_plain_pages-0.9.7.tar.gz.

File metadata

  • Download URL: dekeyrej_plain_pages-0.9.7.tar.gz
  • Upload date:
  • Size: 7.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for dekeyrej_plain_pages-0.9.7.tar.gz
Algorithm Hash digest
SHA256 a5ea8caf55241ba7226b4cf107c50c4207a2096f882e0b4f9711e8e7c7e4909e
MD5 3d978f86ac649a8dbbc85a7feb64800c
BLAKE2b-256 097b38496a1cfebc50e2c4c808cf1810695f42a951662959eabf687646e32231

See more details on using hashes here.

Provenance

The following attestation bundles were made for dekeyrej_plain_pages-0.9.7.tar.gz:

Publisher: publish-to-test-pypi.yml on dekeyrej/plain_pages

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

File details

Details for the file dekeyrej_plain_pages-0.9.7-py3-none-any.whl.

File metadata

File hashes

Hashes for dekeyrej_plain_pages-0.9.7-py3-none-any.whl
Algorithm Hash digest
SHA256 b005d6eb1b323334d30a86451cf1ce2a3ea68578e75fe565fbb135d738adeb3f
MD5 99c3b1e4ac3f43bdb23d2cf8670b56d5
BLAKE2b-256 fa8db386ef2a70857f86889cb4af74b4d4b1c1bbb3654d52f6e63a856ec3e662

See more details on using hashes here.

Provenance

The following attestation bundles were made for dekeyrej_plain_pages-0.9.7-py3-none-any.whl:

Publisher: publish-to-test-pypi.yml on dekeyrej/plain_pages

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