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.6.tar.gz (7.6 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.6-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: dekeyrej_plain_pages-0.9.6.tar.gz
  • Upload date:
  • Size: 7.6 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.6.tar.gz
Algorithm Hash digest
SHA256 b62c563e014e96929abb5d4d2b2f70321931021da9b15eb3564c34d28113b7dc
MD5 e46c746759e8489b6ee4a9f75734efd6
BLAKE2b-256 3f6f2cdb6cd7badc73a1bdf36750376ee6aaa87afba9e9c2f70dbfaabb81e572

See more details on using hashes here.

Provenance

The following attestation bundles were made for dekeyrej_plain_pages-0.9.6.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.6-py3-none-any.whl.

File metadata

File hashes

Hashes for dekeyrej_plain_pages-0.9.6-py3-none-any.whl
Algorithm Hash digest
SHA256 3f6d682581229be2823478bc2d60289e3b3ab4fcbb5145e7e61605fd5fa94715
MD5 a5368eb47423c40bcf97ba9909d57cc1
BLAKE2b-256 4863659f7389ae065bb52b8edb11a671db75b1a3e9df7400dded15fc4140b5e0

See more details on using hashes here.

Provenance

The following attestation bundles were made for dekeyrej_plain_pages-0.9.6-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