diff --git a/media/deluge/config.yaml b/media/deluge/config.yaml new file mode 100644 index 0000000..1b8af61 --- /dev/null +++ b/media/deluge/config.yaml @@ -0,0 +1,8 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: deluge-config + namespace: media +data: + PUID: "1000" + PGID: "1000" diff --git a/media/deluge/deployment.yaml b/media/deluge/deployment.yaml new file mode 100644 index 0000000..7ec12be --- /dev/null +++ b/media/deluge/deployment.yaml @@ -0,0 +1,49 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: deluge + namespace: media +spec: + selector: + matchLabels: + app: deluge + template: + metadata: + labels: + app: deluge + spec: + containers: + - name: deluge + image: lscr.io/linuxserver/deluge:latest + envFrom: + - configMapRef: + name: deluge-config + optional: false + ports: + - containerPort: 8112 + name: http + protocol: TCP + - containerPort: 6881 + name: udp + protocol: UDP + - containerPort: 6881 + name: tcp + protocol: TCP + - containerPort: 58846 + name: thinclient + protocol: TCP + volumeMounts: + - name: config + mountPath: /config + - mountPath: /data/downloads + name: data + subPath: downloads + volumes: + - name: config + persistentVolumeClaim: + claimName: deluge-config + - name: data + persistentVolumeClaim: + claimName: media-data + + diff --git a/media/deluge/dns-endpoint.yaml b/media/deluge/dns-endpoint.yaml new file mode 100644 index 0000000..59322fb --- /dev/null +++ b/media/deluge/dns-endpoint.yaml @@ -0,0 +1,12 @@ +apiVersion: externaldns.k8s.io/v1alpha1 +kind: DNSEndpoint +metadata: + name: deluge.michaelthomson.dev + namespace: media +spec: + endpoints: + - dnsName: deluge.michaelthomson.dev + recordTTL: 180 + recordType: CNAME + targets: + - server.michaelthomson.dev diff --git a/media/deluge/ingress.yaml b/media/deluge/ingress.yaml new file mode 100644 index 0000000..e785bd9 --- /dev/null +++ b/media/deluge/ingress.yaml @@ -0,0 +1,25 @@ +apiVersion: networking.k8s.io/v1 +kind: Ingress +metadata: + name: deluge + namespace: media + annotations: + traefik.ingress.kubernetes.io/router.entrypoints: websecure + traefik.ingress.kubernetes.io/router.middlewares: traefik-authentik@kubernetescrd + traefik.ingress.kubernetes.io/router.tls: "true" +spec: + rules: + - host: deluge.michaelthomson.dev + http: + paths: + - pathType: ImplementationSpecific + path: / + backend: + service: + name: deluge + port: + name: http + tls: + - hosts: + - deluge.michaelthomson.dev + secretName: letsencrypt-wildcard-cert-michaelthomson.dev diff --git a/media/deluge/pvc-config.yaml b/media/deluge/pvc-config.yaml new file mode 100644 index 0000000..74e6be0 --- /dev/null +++ b/media/deluge/pvc-config.yaml @@ -0,0 +1,12 @@ +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: deluge-config + namespace: media +spec: + resources: + requests: + storage: 1Gi + storageClassName: longhorn + accessModes: + - ReadWriteOnce diff --git a/media/deluge/service.yaml b/media/deluge/service.yaml new file mode 100644 index 0000000..e253a91 --- /dev/null +++ b/media/deluge/service.yaml @@ -0,0 +1,12 @@ +apiVersion: v1 +kind: Service +metadata: + name: deluge + namespace: media +spec: + selector: + app: deluge + ports: + - port: 80 + targetPort: http + name: http