No introduction found. Create it?
Install with:
helm repo add app-template oci://ghcr.io/bjw-s-labs/charts/
helm install slskd app-template/app-template -f values.yamlSee examples from other people.
| Name | Repo | Stars | Version | Timestamp |
|---|---|---|---|---|
| slskd | ahinko/home-ops | 277 | 4.6.2 | 13 days ago |
| slskd | carpenike/k8s-gitops | 310 | 4.0.1 | 9 months ago |
See the most popular values for this chart:
| Key | Types |
|---|---|
| string | |
| number | |
| boolean | |
| string | |
| number | |
| boolean | |
controllers.slskd.containers.app.env.TZ (12) ${TIMEZONE} | string |
| boolean | |
controllers.slskd.containers.app.env.SLSKD_DOWNLOADS_DIR (2) /media/downloads/slskd/complete | string |
controllers.slskd.containers.app.env.SLSKD_INCOMPLETE_DIR (2) /media/downloads/slskd/incomplete | string |
controllers.slskd.containers.app.env.SLSKD_SHARE_FILTER (2) Thumbs.db$;\.DS_Store$ | string |
controllers.slskd.containers.app.env.SLSKD_SHARED_DIR (2) /media/downloads/slskd/shared | string |
| string | |
controllers.slskd.containers.app.env.WRTAG_URL (2) wrtag.media.svc.cluster.local | string |
controllers.slskd.containers.app.env.BEETS_HOST (1) beets.default.svc.cluster.local | string |
controllers.slskd.containers.app.env.SLSKD_CONFIG (1) /tmp/slskd.yaml | string |
| boolean | |
| boolean | |
| boolean | |
| number | |
| number | |
| number | |
| number | |
| number | |
| number | |
| number | |
| string | |
controllers.slskd.containers.app.image.repository (17) ghcr.io/slskd/slskd | string |
controllers.slskd.containers.app.image.tag (17) 0.24.4@sha256:4031fc99b824ed2eec3bdbd92914fe6071539f3f71f0742052276afc2c69353d | string |
| boolean | |
| number | |
| number | |
| number | |
| string | |
| number | |
| number | |
| boolean | |
| boolean | |
| boolean | |
| number | |
| string | |
| number | |
| number | |
| number | |
| number | |
| boolean | |
| number | |
| number | |
| string | |
| string | |
| string | |
| boolean | |
| string | |
| boolean | |
| number | |
| boolean | |
| number | |
| string | |
| string | |
controllers.slskd.type (5) statefulset | string |
| boolean | |
| string | |
| boolean | |
controllers.slskd.initContainers.coredns.args[] (2) - -conf | string |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
controllers.slskd.initContainers.gluetun.env.FIREWALL_OUTBOUND_SUBNETS (2) 10.96.0.0/12,10.244.0.0/16 | string |
| string | |
| string | |
| string | |
| string | |
| string | |
controllers.slskd.initContainers.gluetun.env.VPN_PORT_FORWARDING_UP_COMMAND (1) /config/update-port.sh | string |
| number | |
| string | |
controllers.slskd.initContainers.gluetun.image.repository (2) ghcr.io/qdm12/gluetun | string |
| string | |
controllers.slskd.initContainers.gluetun.lifecycle.postStart.exec.command[] (2) - /bin/sh | string |
| boolean | |
| boolean | |
| string | |
| number | |
| boolean | |
| boolean | |
| string | |
| number | |
| boolean | |
| boolean | |
| string | |
| number | |
| number | |
| string | |
| string | |
| boolean | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
| number | |
controllers.slskd.strategy (1) Recreate | string |
| number | |
| boolean | |
| number | |
| number | |
| string | |
| boolean | |
| number | |
service.app.forceRename (8) {{ .Release.Name }} | string |
| boolean | |
service.app.annotations."lbipam.cilium.io/ips" (4) ${SLSKD_ADDRESS} | string |
| string | |
service.app.type (4) LoadBalancer | string |
service.app.ipFamilyPolicy (1) PreferDualStack | string |
| number | |
| string | |
service.soulseek.type (7) LoadBalancer | string |
| string | |
| string | |
service.soulseek.ipFamilies[] (1) - IPv4 | string |
service.soulseek.ipFamilyPolicy (1) PreferDualStack | string |
| number, string | |
| string | |
| number, string | |
| boolean | |
| number, string | |
| string | |
| boolean | |
defaultPodOptions.annotations."k8s.v1.cni.cncf.io/networks" (1) [{
"name": "vpn",
"namespace": "network",
"ips": ["10.10.31.10/24"]
}] | string |
persistence.config-file.type (16) configMap | string |
persistence.config-file.globalMounts[].path (15) /config/slskd.yml | string |
| string | |
| boolean | |
persistence.config-file.name (13) slskd-configmap | string |
| number | |
| string | |
persistence.config-file.advancedMounts.slskd.gluetun[].path (1) /config/slskd.yaml | string |
persistence.config-file.advancedMounts.slskd.gluetun[].subPath (1) slskd.yaml | string |
persistence.tmp.type (16) emptyDir | string |
| string | |
persistence.media.globalMounts[].subPath (8) Downloads/soulseek | string |
| string | |
persistence.media.path (11) /volume1/Media/ | string |
persistence.media.server (11) lilnas.home.arpa | string |
persistence.media.existingClaim (5) slskd-downloads-pvc | string |
| boolean | |
| string | |
persistence.config.accessMode (2) ReadWriteOnce | string |
| string | |
persistence.config.type (2) persistentVolumeClaim | string |
persistence.coredns.advancedMounts.slskd.coredns[].path (2) /etc/coredns/Corefile | string |
| string | |
| boolean | |
persistence.coredns.name (2) slskd-coredns | string |
persistence.coredns.type (2) configMap | string |
| number | |
persistence.scripts.globalMounts[].path (2) /scripts/wrtag.sh | string |
| boolean | |
| string | |
persistence.scripts.name (2) {{ .Release.Name }} | string |
persistence.scripts.type (2) configMap | string |
| string | |
persistence.data.path (1) /mnt/user/data/soulseek | string |
persistence.data.server (1) aincrad.home.vzkn.eu | string |
| string | |
persistence.media-shared.globalMounts[].path (1) /media/music | string |
| boolean | |
persistence.media-shared.path (1) /media/music | string |
persistence.media-shared.server (1) nas.servers.internal | string |
| string | |
route.app.hostnames[] (14) - {{ .Release.Name }}.${SECRET_DOMAIN} | string |
route.app.parentRefs[].name (14) envoy-internal | string |
| string | |
| string | |
| number | |
| string | |
| string | |
| string | |
| string | |
route.app.annotations."gethomepage.dev/icon" (4) sh-slskd-light.png | string |
| string | |
route.app.annotations."gethomepage.dev/description" (3) Soulseek client | string |
route.app.annotations."gatus.home-operations.com/endpoint" (1) group: downloads | string |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
route.main.hostnames[] (2) - soulseek.${SECRET_DOMAIN} | string |
route.main.parentRefs[].name (2) internal | string |
| string | |
| string | |
| string | |
| number | |
| string | |
| string | |
| string | |
| string | |
| string | |
| string | |
configMaps.config.data."slskd.yml" (2) directories:
downloads: /media/downloads/soulseek/complete
incomplete: /media/downloads/soulseek/incomplete
permissions:
file:
mode: 750
shares:
directories:
- /media/downloads/soulseek/shared
filters:
- \.ini$
- Thumbs.db$
- \.DS_Store$ | string |
configMaps.config.data."slskd.yaml" (1) soulseek:
listenPort: 50429
directories:
downloads: /mnt/media/downloads/soulseek/complete
incomplete: /mnt/media/downloads/soulseek/incomplete
permissions:
file:
mode: 750
shares:
directories:
- /mnt/media/downloads/soulseek/shared
filters:
- \.ini$
- Thumbs.db$
- \.DS_Store$ | string |
configMaps.config.data."update-port.sh" (1) #!/bin/sh
set -eu
: "${PORT:?PORT environment variable is required}"
IN="/config/slskd.yaml"
OUT="/tmp/slskd.yaml"
# Basic sanity check: numeric port, valid range.
case "$PORT" in
''|*[!0-9]*)
echo "ERROR: PORT must be an integer, got: $PORT" >&2
exit 2
;;
esac
if [ "$PORT" -lt 1 ] || [ "$PORT" -gt 65535 ]; then
echo "ERROR: PORT must be in range 1..65535, got: $PORT" >&2
exit 2
fi
if [ ! -r "$IN" ]; then
echo "ERROR: input config not readable: $IN" >&2
exit 1
fi
tmp="$(mktemp "${OUT}.XXXXXX")"
cleanup() { rm -f "$tmp"; }
trap cleanup EXIT INT TERM
# Replace the whole listenPort line, keeping indentation and key.
# If no listenPort line exists, we fail loudly (otherwise you'd think it worked).
sed -E "s/^([[:space:]]*listenPort:).*/\1 ${PORT}/" "$IN" > "$tmp"
if ! grep -Eq '^[[:space:]]*listenPort:[[:space:]]*[0-9]+' "$tmp"; then
echo "ERROR: listenPort: key not found or not updated in $IN" >&2
exit 3
fi
# Make it the target file atomically.
mv -f "$tmp" "$OUT"
trap - EXIT INT TERM
# Match the ownership expected by the app container.
chown 2000:2000 "$OUT"
echo "Updated listenPort to $PORT in $OUT" | string |
ingress.app.className (1) internal-nginx | string |
ingress.app.hosts[].host (1) slskd.holthome.net | string |
| string | |
| string | |
| string |