From 65c8e1e2ebbdfe7460bae2d8f0e3da569c31c7c4 Mon Sep 17 00:00:00 2001 From: Michael Thomson Date: Fri, 15 Dec 2023 16:11:40 -0500 Subject: [PATCH] lazylibrarian --- media/lazylibrarian/config.yaml | 9 +++++++ media/lazylibrarian/deployment.yaml | 39 +++++++++++++++++++++++++++ media/lazylibrarian/dns-endpoint.yaml | 12 +++++++++ media/lazylibrarian/ingress.yaml | 25 +++++++++++++++++ media/lazylibrarian/pvc-config.yaml | 12 +++++++++ media/lazylibrarian/service.yaml | 12 +++++++++ 6 files changed, 109 insertions(+) create mode 100644 media/lazylibrarian/config.yaml create mode 100644 media/lazylibrarian/deployment.yaml create mode 100644 media/lazylibrarian/dns-endpoint.yaml create mode 100644 media/lazylibrarian/ingress.yaml create mode 100644 media/lazylibrarian/pvc-config.yaml create mode 100644 media/lazylibrarian/service.yaml diff --git a/media/lazylibrarian/config.yaml b/media/lazylibrarian/config.yaml new file mode 100644 index 0000000..d4fb70a --- /dev/null +++ b/media/lazylibrarian/config.yaml @@ -0,0 +1,9 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: lazylibrarian-config + namespace: media +data: + PUID: "1000" + PGID: "1000" + DOCKER_MODS: linuxserver/mods:lazylibrarian-ffmpeg diff --git a/media/lazylibrarian/deployment.yaml b/media/lazylibrarian/deployment.yaml new file mode 100644 index 0000000..f4a0af0 --- /dev/null +++ b/media/lazylibrarian/deployment.yaml @@ -0,0 +1,39 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: lazylibrarian + namespace: media +spec: + selector: + matchLabels: + app: lazylibrarian + template: + metadata: + labels: + app: lazylibrarian + spec: + containers: + - name: lazylibrarian + image: lscr.io/linuxserver/lazylibrarian:latest + envFrom: + - configMapRef: + name: lazylibrarian-config + optional: false + ports: + - containerPort: 5299 + name: http + protocol: TCP + volumeMounts: + - name: config + mountPath: /config + - mountPath: /data + name: data + volumes: + - name: config + persistentVolumeClaim: + claimName: lazylibrarian-config + - name: data + persistentVolumeClaim: + claimName: media-data + + diff --git a/media/lazylibrarian/dns-endpoint.yaml b/media/lazylibrarian/dns-endpoint.yaml new file mode 100644 index 0000000..6315681 --- /dev/null +++ b/media/lazylibrarian/dns-endpoint.yaml @@ -0,0 +1,12 @@ +apiVersion: externaldns.k8s.io/v1alpha1 +kind: DNSEndpoint +metadata: + name: lazylibrarian.michaelthomson.dev + namespace: media +spec: + endpoints: + - dnsName: lazylibrarian.michaelthomson.dev + recordTTL: 180 + recordType: CNAME + targets: + - server.michaelthomson.dev diff --git a/media/lazylibrarian/ingress.yaml b/media/lazylibrarian/ingress.yaml new file mode 100644 index 0000000..32558a5 --- /dev/null +++ b/media/lazylibrarian/ingress.yaml @@ -0,0 +1,25 @@ +apiVersion: networking.k8s.io/v1 +kind: Ingress +metadata: + name: lazylibrarian + 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: lazylibrarian.michaelthomson.dev + http: + paths: + - pathType: ImplementationSpecific + path: / + backend: + service: + name: lazylibrarian + port: + name: http + tls: + - hosts: + - lazylibrarian.michaelthomson.dev + secretName: letsencrypt-wildcard-cert-michaelthomson.dev diff --git a/media/lazylibrarian/pvc-config.yaml b/media/lazylibrarian/pvc-config.yaml new file mode 100644 index 0000000..9ebb2b1 --- /dev/null +++ b/media/lazylibrarian/pvc-config.yaml @@ -0,0 +1,12 @@ +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: lazylibrarian-config + namespace: media +spec: + resources: + requests: + storage: 1Gi + storageClassName: longhorn + accessModes: + - ReadWriteOnce diff --git a/media/lazylibrarian/service.yaml b/media/lazylibrarian/service.yaml new file mode 100644 index 0000000..1e6549d --- /dev/null +++ b/media/lazylibrarian/service.yaml @@ -0,0 +1,12 @@ +apiVersion: v1 +kind: Service +metadata: + name: lazylibrarian + namespace: media +spec: + selector: + app: lazylibrarian + ports: + - port: 80 + targetPort: http + name: http