745a6767026c9d31676b84426d12ab46fd5d210a
All checks were successful
images / hermes (push) Successful in 15m40s
Confirmed against upstream: dashboard binds 0.0.0.0:9119 by default (HERMES_DASHBOARD_HOST/PORT), so bridge + PublishPort=5100:9119 needs no override. LLM backend uses Hermes' `custom` OpenAI-compatible provider pointed at the local sovereign inference (hanzalova.internal:31313/v1). Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com> Claude-Session: https://claude.ai/code/session_011D3YeWKpjg5bT488fVanCH
lair/containers
Container images required by lair infrastructure, built and published to the
Gitea registry at git.lair.cafe. Convention follows
gongfoo's images/ setup.
Layout
images/<name>/ one directory per image
Containerfile (when we author the image ourselves)
build.sh local build helper
readme.md what it is and how it's built
.gitea/workflows/
images.yml builds + publishes every image, on push / daily / dispatch
Images
| Image | Published as | Source |
|---|---|---|
| hermes | git.lair.cafe/lair/hermes:{version,latest} |
built from NousResearch/hermes-agent's Dockerfile at the latest release tag |
How builds work
- Trigger: push under
images/**, a daily cron poll, or manual dispatch. - Release-tracking: each image job resolves the upstream's latest release via
its API and builds that exact ref. For upstreams that ship their own Dockerfile
(hermes) we build directly from the upstream git context; for images we author,
the version is passed as a
--build-argwith the Containerfile pin as fallback. - Self-healing: a build runs only when the resolved version isn't already in the registry — and because the registry (not a committed pin) is the source of truth, a failed build simply retries on the next poll instead of stranding a stale image. (Lesson borrowed from gongfoo.)
Adding an image
mkdir images/<name>, add aContainerfile(or build from an upstream context) +build.sh+readme.md.- Add a job to
.gitea/workflows/images.ymlthat logs in, buildsgit.lair.cafe/lair/<name>:latest, and pushes. - Consumers pull
git.lair.cafe/lair/<name>:latestwithAutoUpdate=registry.
Required secret
| Secret | Purpose |
|---|---|
REGISTRY_TOKEN |
Gitea token with write:package for git.lair.cafe; used as podman login -u $GITEA_ACTOR -p $REGISTRY_TOKEN. Set in this repo's (or the lair org's) Actions secrets. |
Build jobs run on self-hosted runners labelled metal + podman.
Description
Languages
Shell
58.7%
Dockerfile
41.3%