diff --git a/apps/charts/syncthing/Chart.yaml b/apps/charts/syncthing/Chart.yaml new file mode 100644 index 0000000..601fbe5 --- /dev/null +++ b/apps/charts/syncthing/Chart.yaml @@ -0,0 +1,3 @@ +apiVersion: v2 +version: 1.0.0 +name: syncthing diff --git a/apps/charts/syncthing/templates/deployment.yaml b/apps/charts/syncthing/templates/deployment.yaml new file mode 100644 index 0000000..009519a --- /dev/null +++ b/apps/charts/syncthing/templates/deployment.yaml @@ -0,0 +1,58 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: "{{ .Release.Name }}" +spec: + strategy: + type: Recreate + replicas: 1 + revisionHistoryLimit: 0 + selector: + matchLabels: + app: "{{ .Release.Name }}" + template: + metadata: + labels: + app: "{{ .Release.Name }}" + spec: + containers: + - name: "{{ .Release.Name }}" + image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}" + imagePullPolicy: "{{ .Values.image.pullPolicy }}" + ports: + - name: http + containerPort: 8384 + protocol: TCP + livenessProbe: + tcpSocket: + port: http + readinessProbe: + tcpSocket: + port: http + volumeMounts: + - mountPath: /var/syncthing + name: data + - mountPath: /media/music + name: music + readOnly: true + - mountPath: /media/kids-music + name: kidsmusic + readOnly: true + env: + - name: PUID + value: "1000" + - name: GUID + value: "1000" + - name: TZ + value: "{{ .Values.globals.timezone }}" + + volumes: + - name: data + persistentVolumeClaim: + claimName: "{{ .Release.Name }}-data" + - name: music + persistentVolumeClaim: + claimName: music + - name: kidsmusic + persistentVolumeClaim: + claimName: kidsmusic diff --git a/apps/charts/syncthing/templates/external-http-service.yaml b/apps/charts/syncthing/templates/external-http-service.yaml new file mode 100644 index 0000000..e28916d --- /dev/null +++ b/apps/charts/syncthing/templates/external-http-service.yaml @@ -0,0 +1,11 @@ +apiVersion: homelab.mortenolsen.pro/v1 +kind: ExternalHttpService +metadata: + name: '{{ .Release.Name }}' +spec: + environment: '{{ .Values.globals.environment }}' + subdomain: '{{ .Values.subdomain }}' + destination: + host: '{{ .Release.Name }}.{{ .Release.Namespace }}.svc.cluster.local' + port: + number: 80 diff --git a/apps/charts/syncthing/templates/pvc.yaml b/apps/charts/syncthing/templates/pvc.yaml new file mode 100644 index 0000000..bc1d0a6 --- /dev/null +++ b/apps/charts/syncthing/templates/pvc.yaml @@ -0,0 +1,11 @@ +kind: PersistentVolumeClaim +apiVersion: v1 +metadata: + name: '{{ .Release.Name }}-data' +spec: + accessModes: + - 'ReadWriteOnce' + resources: + requests: + storage: '1Gi' + storageClassName: '{{ .Values.globals.environment }}' diff --git a/apps/charts/syncthing/templates/service.yaml b/apps/charts/syncthing/templates/service.yaml new file mode 100644 index 0000000..8fb567b --- /dev/null +++ b/apps/charts/syncthing/templates/service.yaml @@ -0,0 +1,15 @@ +apiVersion: v1 +kind: Service +metadata: + name: "{{ .Release.Name }}" + labels: + app: "{{ .Release.Name }}" +spec: + type: ClusterIP + ports: + - port: 80 + targetPort: 8384 + protocol: TCP + name: http + selector: + app: "{{ .Release.Name }}" diff --git a/apps/charts/syncthing/templates/virtual-service.yaml b/apps/charts/syncthing/templates/virtual-service.yaml new file mode 100644 index 0000000..0af9b24 --- /dev/null +++ b/apps/charts/syncthing/templates/virtual-service.yaml @@ -0,0 +1,18 @@ +apiVersion: networking.istio.io/v1 +kind: VirtualService +metadata: + name: "{{ .Release.Name }}" + namespace: "{{ .Release.Namespace }}" +spec: + gateways: + - "{{ .Values.globals.istio.gateway }}" + - mesh + hosts: + - "{{ .Values.subdomain }}.{{ .Values.globals.domain }}" + - mesh + http: + - route: + - destination: + host: "{{ .Release.Name }}" + port: + number: 80 diff --git a/apps/charts/syncthing/values.yaml b/apps/charts/syncthing/values.yaml new file mode 100644 index 0000000..298c42d --- /dev/null +++ b/apps/charts/syncthing/values.yaml @@ -0,0 +1,5 @@ +image: + repository: syncthing/syncthing + tag: latest + pullPolicy: IfNotPresent +subdomain: syncthing