blumeops/containers/navidrome/Dockerfile
Erich Blume 0e2c10176d Harden zot registry, pt 1 (#231)
## 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
2026-02-20 22:50:01 -08:00

55 lines
1.5 KiB
Docker

# Navidrome music server
# Three-stage build: UI (Node), backend (Go+taglib), runtime (Alpine)
ARG CONTAINER_APP_VERSION=v0.60.3
ARG NAVIDROME_VERSION=${CONTAINER_APP_VERSION}
FROM node:22-alpine AS ui-build
ARG NAVIDROME_VERSION
RUN apk add --no-cache git
RUN git clone --depth 1 --branch ${NAVIDROME_VERSION} \
https://forge.ops.eblu.me/eblume/navidrome.git /app
WORKDIR /app/ui
RUN npm ci
RUN npm run build
FROM golang:alpine3.22 AS build
ARG NAVIDROME_VERSION
RUN apk add --no-cache build-base git taglib-dev zlib-dev
RUN git clone --depth 1 --branch ${NAVIDROME_VERSION} \
https://forge.ops.eblu.me/eblume/navidrome.git /app
WORKDIR /app
# Copy pre-built UI assets
COPY --from=ui-build /app/ui/build /app/ui/build
ENV CGO_ENABLED=1
ENV CGO_CFLAGS_ALLOW="--define-prefix"
RUN go build -tags=netgo \
-ldflags="-w -s -X github.com/navidrome/navidrome/consts.gitTag=${NAVIDROME_VERSION}" \
-o /navidrome .
FROM alpine:3.22
LABEL org.opencontainers.image.title=Navidrome
LABEL org.opencontainers.image.description="Navidrome is a self-hosted music server and streamer"
# Points to upstream canonical source, not the forge mirror used for builds
LABEL org.opencontainers.image.source=https://github.com/navidrome/navidrome
RUN apk add --no-cache ca-certificates tzdata taglib ffmpeg \
&& addgroup -g 1000 navidrome \
&& adduser -u 1000 -G navidrome -D navidrome
COPY --from=build /navidrome /usr/bin/navidrome
EXPOSE 4533
USER 1000
CMD ["/usr/bin/navidrome"]