blumeops/containers/transmission/Dockerfile
Erich Blume c8b655f177 Build local containers for k8s services (#61)
## Summary
- Move devpi Dockerfile from argocd/manifests to containers/devpi/
- Add containers for: transmission, teslamate, miniflux, kiwix-serve, kubectl
- Update all k8s deployments to use local images (registry.ops.eblu.me/blumeops/*)
- All containers use v1.0.0 tag for initial release

## Containers Added
| Container | Source | Notes |
|-----------|--------|-------|
| devpi | python:3.12-slim | Existing, moved to containers/ |
| kubectl | alpine + download | For zim-watcher CronJob |
| miniflux | Go build from source | v2.2.16 |
| kiwix-serve | Download pre-built binary | v3.8.1 |
| transmission | alpine + apk install | Simpler than linuxserver image |
| teslamate | Elixir build from source | v2.2.0 |

## Deployment and Testing
- [ ] Build and tag devpi-v1.0.0
- [ ] Build and tag kubectl-v1.0.0
- [ ] Build and tag miniflux-v1.0.0
- [ ] Build and tag kiwix-serve-v1.0.0
- [ ] Build and tag transmission-v1.0.0
- [ ] Build and tag teslamate-v1.0.0
- [ ] Sync ArgoCD apps and verify services

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Reviewed-on: https://forge.ops.eblu.me/eblume/blumeops/pulls/61
2026-01-25 21:35:57 -08:00

27 lines
636 B
Docker

# Transmission BitTorrent daemon
# Simpler alternative to linuxserver image
FROM alpine:3.21
ARG TRANSMISSION_VERSION=4.0.6-r0
RUN apk add --no-cache \
transmission-daemon=${TRANSMISSION_VERSION} \
transmission-cli=${TRANSMISSION_VERSION} \
transmission-remote=${TRANSMISSION_VERSION} \
bash \
curl \
tzdata \
su-exec
# Create directories (user is created dynamically by start.sh based on PUID/PGID)
RUN mkdir -p /config /downloads/complete /downloads/incomplete
COPY start.sh /start.sh
RUN chmod +x /start.sh
EXPOSE 9091 51413/tcp 51413/udp
VOLUME ["/config", "/downloads"]
ENTRYPOINT ["/start.sh"]