apiVersion: v1 kind: ConfigMap metadata: name: jellyfin-network-config data: network.xml: | / true true 8096 8920 80 443 true true https://${JELLYFIN_HOST} --- apiVersion: apps/v1 kind: Deployment metadata: name: jellyfin spec: replicas: 1 selector: matchLabels: app: jellyfin template: metadata: labels: app: jellyfin spec: containers: - name: jellyfin image: jellyfin/jellyfin:latest ports: - containerPort: 8096 volumeMounts: - name: plex-media mountPath: /media - name: config mountPath: /config - name: network-config mountPath: /config/config/ network.xml subPath: network.xml volumes: - name: plex-media persistentVolumeClaim: claimName: media-nfs-pvc - name: config persistentVolumeClaim: claimName: plex-config-pvc - name: network-config configMap: name: jellyfin-network-config --- apiVersion: v1 kind: Service metadata: name: jellyfin-service spec: selector: app: jellyfin ports: - protocol: TCP port: 8096 targetPort: 8096 type: ClusterIP --- apiVersion: traefik.io/v1alpha1 kind: IngressRoute metadata: name: jellyfin-ingress annotations: traefik.ingress.kubernetes.io/router.middlewares: jellyfin-headers@kubernetescrd spec: entryPoints: - websecure routes: - match: Host(`${JELLYFIN_HOST}`) kind: Rule services: - name: jellyfin-service port: 8096 tls: secretName: jellyfin-tls-secret --- apiVersion: traefik.io/v1alpha1 kind: Middleware metadata: name: jellyfin-headers spec: headers: customRequestHeaders: X-Forwarded-Proto: "https" customResponseHeaders: X-Frame-Options: "SAMEORIGIN" --- apiVersion: cert-manager.io/v1 kind: Certificate metadata: name: jellyfin-cert spec: secretName: jellyfin-tls-secret issuerRef: name: acme-issuer kind: ClusterIssuer dnsNames: - ${JELLYFIN_HOST}