fix(nzbget): render newshosting creds via init container

nzbget does not expand OS env vars in nzbget.conf (its ${...} only
references other nzbget options), so the previous secretKeyRef-as-env
approach left the literal ${NEWSHOSTING_USER} in the config and auth
failed with 400 DENIED.

Add initContainers support to the chart and an init step that seds the
Server1 (newshosting) block into nzbget.conf on every start: non-secret
settings in git, username/password from the usenet-creds Secret. Rotating
the secret + restarting re-renders the creds; no password lands in git.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
gilgamezh
2026-06-05 09:22:01 +02:00
parent 6247b140bc
commit 5e1a919721
2 changed files with 47 additions and 14 deletions
@@ -21,6 +21,10 @@ spec:
spec: spec:
volumes: volumes:
{{ toYaml .Values.volumes | indent 6 }} {{ toYaml .Values.volumes | indent 6 }}
{{- with .Values.initContainers }}
initContainers:
{{ toYaml . | indent 8 }}
{{- end }}
containers: containers:
- name: {{ .Chart.Name }} - name: {{ .Chart.Name }}
image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}" image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
+43 -14
View File
@@ -22,20 +22,49 @@ env:
value: "http://gluetun.default.svc.cluster.local:8888" value: "http://gluetun.default.svc.cluster.local:8888"
- name: NO_PROXY - name: NO_PROXY
value: "localhost,127.0.0.1,.svc,.cluster.local" value: "localhost,127.0.0.1,.svc,.cluster.local"
# Newshosting usenet provider credentials, sourced from the out-of-band
# `usenet-creds` Secret (not in git, same pattern as gluetun-wireguard). # nzbget cannot read server credentials from environment variables (its
# Referenced in nzbget.conf as ${NEWSHOSTING_USER} / ${NEWSHOSTING_PASS} # ${...} config syntax only references other nzbget options, not env). So an
# so the password never lives in plaintext in the config file. # init container renders the Server1 (newshosting) block into nzbget.conf on
- name: NEWSHOSTING_USER # every start: the non-secret settings live here in git, while the username
valueFrom: # and password come from the out-of-band `usenet-creds` Secret (same pattern
secretKeyRef: # as gluetun-wireguard — secret not committed). Rotating the secret + a pod
name: usenet-creds # restart re-renders the creds. No provider password is ever stored in git.
key: NEWSHOSTING_USER initContainers:
- name: NEWSHOSTING_PASS - name: render-newshosting
valueFrom: image: lscr.io/linuxserver/nzbget:latest
secretKeyRef: command:
name: usenet-creds - sh
key: NEWSHOSTING_PASS - -c
- |
f=/config/nzbget.conf
[ -f "$f" ] || { echo "nzbget.conf absent; main container will seed defaults"; exit 0; }
sed -i \
-e "s|^Server1.Active=.*|Server1.Active=yes|" \
-e "s|^Server1.Name=.*|Server1.Name=newshosting|" \
-e "s|^Server1.Host=.*|Server1.Host=news.newshosting.com|" \
-e "s|^Server1.Port=.*|Server1.Port=563|" \
-e "s|^Server1.Encryption=.*|Server1.Encryption=yes|" \
-e "s|^Server1.Connections=.*|Server1.Connections=30|" \
-e "s|^Server1.Username=.*|Server1.Username=${NEWSHOSTING_USER}|" \
-e "s|^Server1.Password=.*|Server1.Password=${NEWSHOSTING_PASS}|" \
"$f"
echo "rendered newshosting Server1 block into nzbget.conf"
env:
- name: NEWSHOSTING_USER
valueFrom:
secretKeyRef:
name: usenet-creds
key: NEWSHOSTING_USER
- name: NEWSHOSTING_PASS
valueFrom:
secretKeyRef:
name: usenet-creds
key: NEWSHOSTING_PASS
volumeMounts:
- name: plex-data
mountPath: /config
subPath: configs/nzbget
service: service:
type: ClusterIP type: ClusterIP