## Summary - Enable OIDC + API key authentication on zot with anonymous pull preserved - Enforce tag immutability for version tags - Adopt commit-SHA-based container image tagging Details in the [[harden-zot-registry]] Mikado chain (`mise run docs-mikado harden-zot-registry`). ## Test plan - [ ] Anonymous pull still works - [ ] Unauthenticated push fails (401) - [ ] CI container builds pass with new auth and tagging - [ ] `mise run services-check` passes 🤖 Generated with [Claude Code](https://claude.com/claude-code) Reviewed-on: https://forge.ops.eblu.me/eblume/blumeops/pulls/231
2 KiB
2 KiB
| title | modified | tags | ||||
|---|---|---|---|---|---|---|
| Pin Container Versions | 2026-02-20 |
|
Pin Container Versions
Ensure every container has an explicit, parseable version declaration so that add-container-version-sync-check has something to validate against.
Context
Discovered during analysis of adopt-commit-based-container-tags: containers needed a uniform, parseable version declaration for the sync check. Most containers already had version ARGs (miniflux, navidrome, ntfy, etc.), but with inconsistent naming (NAVIDROME_VERSION, MINIFLUX_VERSION, etc.), and several containers (devpi, cv, quartz, nettest) had none.
What Was Done
Every container Dockerfile now declares ARG CONTAINER_APP_VERSION=X.Y.Z as its first ARG, providing a uniform parsing target. Containers that use the version in build commands chain it to a semantic ARG:
ARG CONTAINER_APP_VERSION=v0.60.3
ARG NAVIDROME_VERSION=${CONTAINER_APP_VERSION}
Specific changes:
- devpi: Pinned devpi-server==6.19.1 and devpi-web==5.0.1
- cv:
CONTAINER_APP_VERSION=1.0.3(matches latest Forgejo package release) - quartz:
CONTAINER_APP_VERSION=1.28.2(pinned nginx:1.28.2-alpine base) - nettest:
CONTAINER_APP_VERSION=0.1.0(internal, no upstream) - All others: Existing versions carried forward with new uniform ARG pattern
Key Files
| File | Change |
|---|---|
containers/*/Dockerfile |
Add ARG CONTAINER_APP_VERSION to all 13 containers |
service-versions.yaml |
Populate current-version for devpi, cv, docs |
Verification
- Every container Dockerfile has
ARG CONTAINER_APP_VERSION=X.Y.Z - ARG chaining tested with Docker build (nginx:1.28.2-alpine)
- devpi container pins pip package versions
- cv version matches Forgejo package release (1.0.3)
- quartz pins nginx base image to stable (1.28.2)
Related
- add-container-version-sync-check — Parent: needs parseable versions for sync check
- adopt-commit-based-container-tags — Grandparent goal