mirror of
https://github.com/auricom/home-cluster.git
synced 2025-09-17 18:24:14 +02:00
♻️ homelab
This commit is contained in:
60
kubernetes/apps/default/homelab/ks.yaml
Normal file
60
kubernetes/apps/default/homelab/ks.yaml
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://raw.githubusercontent.com/fluxcd-community/flux2-schemas/main/kustomization-kustomize-v1.json
|
||||||
|
apiVersion: kustomize.toolkit.fluxcd.io/v1
|
||||||
|
kind: Kustomization
|
||||||
|
metadata:
|
||||||
|
name: cluster-apps-homnelab-minio
|
||||||
|
namespace: flux-system
|
||||||
|
labels:
|
||||||
|
substitution.flux.home.arpa/enabled: "true"
|
||||||
|
spec:
|
||||||
|
path: ./kubernetes/apps/default/homelab/minio
|
||||||
|
prune: true
|
||||||
|
sourceRef:
|
||||||
|
kind: GitRepository
|
||||||
|
name: home-ops-kubernetes
|
||||||
|
dependsOn:
|
||||||
|
- name: cluster-apps-external-secrets-stores
|
||||||
|
interval: 30m
|
||||||
|
retryInterval: 1m
|
||||||
|
timeout: 3m
|
||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://raw.githubusercontent.com/fluxcd-community/flux2-schemas/main/kustomization-kustomize-v1.json
|
||||||
|
apiVersion: kustomize.toolkit.fluxcd.io/v1
|
||||||
|
kind: Kustomization
|
||||||
|
metadata:
|
||||||
|
name: cluster-apps-homnelab-opnsense
|
||||||
|
namespace: flux-system
|
||||||
|
labels:
|
||||||
|
substitution.flux.home.arpa/enabled: "true"
|
||||||
|
spec:
|
||||||
|
path: ./kubernetes/apps/default/homelab/opnsense
|
||||||
|
prune: true
|
||||||
|
sourceRef:
|
||||||
|
kind: GitRepository
|
||||||
|
name: home-ops-kubernetes
|
||||||
|
dependsOn:
|
||||||
|
- name: cluster-apps-external-secrets-stores
|
||||||
|
interval: 30m
|
||||||
|
retryInterval: 1m
|
||||||
|
timeout: 3m
|
||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://raw.githubusercontent.com/fluxcd-community/flux2-schemas/main/kustomization-kustomize-v1.json
|
||||||
|
apiVersion: kustomize.toolkit.fluxcd.io/v1
|
||||||
|
kind: Kustomization
|
||||||
|
metadata:
|
||||||
|
name: cluster-apps-homnelab-truenas
|
||||||
|
namespace: flux-system
|
||||||
|
labels:
|
||||||
|
substitution.flux.home.arpa/enabled: "true"
|
||||||
|
spec:
|
||||||
|
path: ./kubernetes/apps/default/homelab/truenas
|
||||||
|
prune: true
|
||||||
|
sourceRef:
|
||||||
|
kind: GitRepository
|
||||||
|
name: home-ops-kubernetes
|
||||||
|
dependsOn:
|
||||||
|
- name: cluster-apps-external-secrets-stores
|
||||||
|
interval: 30m
|
||||||
|
retryInterval: 1m
|
||||||
|
timeout: 3m
|
@@ -3,7 +3,7 @@
|
|||||||
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
||||||
kind: HelmRelease
|
kind: HelmRelease
|
||||||
metadata:
|
metadata:
|
||||||
name: truenas-minio-rclone
|
name: homelab-minio-backup
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
interval: 30m
|
interval: 30m
|
||||||
@@ -39,6 +39,9 @@ spec:
|
|||||||
repository: ghcr.io/auricom/rclone
|
repository: ghcr.io/auricom/rclone
|
||||||
tag: 1.62.2@sha256:8d3ae01ed5295974be1b229f7398ce93a03c77a3fdaf301ea35bf929bb19389a
|
tag: 1.62.2@sha256:8d3ae01ed5295974be1b229f7398ce93a03c77a3fdaf301ea35bf929bb19389a
|
||||||
command: ["/bin/bash", "/app/minio-rclone.sh"]
|
command: ["/bin/bash", "/app/minio-rclone.sh"]
|
||||||
|
envFrom:
|
||||||
|
- secretRef:
|
||||||
|
name: homelab-minio-secret
|
||||||
service:
|
service:
|
||||||
main:
|
main:
|
||||||
enabled: false
|
enabled: false
|
||||||
@@ -49,17 +52,12 @@ spec:
|
|||||||
config:
|
config:
|
||||||
enabled: true
|
enabled: true
|
||||||
type: configMap
|
type: configMap
|
||||||
name: truenas-minio-rclone-configmap
|
name: homelab-minio-configmap
|
||||||
defaultMode: 0775
|
defaultMode: 0775
|
||||||
globalMounts:
|
globalMounts:
|
||||||
- path: /app/minio-rclone.sh
|
- path: /app/minio-rclone.sh
|
||||||
subPath: minio-rclone.sh
|
subPath: minio-rclone.sh
|
||||||
readOnly: true
|
readOnly: true
|
||||||
age:
|
- path: /config/rclone.conf
|
||||||
enabled: true
|
subPath: rclone.conf
|
||||||
type: secret
|
|
||||||
name: truenas-secret
|
|
||||||
globalMounts:
|
|
||||||
- path: /app/age_key
|
|
||||||
subPath: SOPS_AGE_KEY
|
|
||||||
readOnly: true
|
readOnly: true
|
@@ -0,0 +1,15 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://raw.githubusercontent.com/SchemaStore/schemastore/master/src/schemas/json/kustomization.json
|
||||||
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
|
kind: Kustomization
|
||||||
|
namespace: default
|
||||||
|
resources:
|
||||||
|
- ./helmrelease.yaml
|
||||||
|
configMapGenerator:
|
||||||
|
- name: homelab-minio-configmap
|
||||||
|
files:
|
||||||
|
- ./minio-rclone.sh
|
||||||
|
- ./rclone.conf
|
||||||
|
generatorOptions:
|
||||||
|
disableNameSuffixHash: true
|
||||||
|
|
17
kubernetes/apps/default/homelab/minio/backup/minio-rclone.sh
Executable file
17
kubernetes/apps/default/homelab/minio/backup/minio-rclone.sh
Executable file
@@ -0,0 +1,17 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -o nounset
|
||||||
|
set -o errexit
|
||||||
|
|
||||||
|
# Replace the placeholders in the file with the environment variables values
|
||||||
|
cp /config/rclone.conf /tmp/rclone.conf
|
||||||
|
sed -i "s@__RCLONE_ACCESS_ID__@$RCLONE_ACCESS_ID@g" "/tmp/rclone.conf"
|
||||||
|
sed -i "s@__RCLONE_SECRET_KEY__@$RCLONE_SECRET_KEY@g" "/tmp/rclone.conf"
|
||||||
|
sed -i "s@__PASSWORD__@$GDRIVE_PASSWORD@g" "/tmp/rclone.conf"
|
||||||
|
sed -i "s@__PASSWORD2__@$GDRIVE_PASSWORD2@g" "/tmp/rclone.conf"
|
||||||
|
sed -i "s@__GDRIVE_CLIENT_ID__@$GDRIVE_CLIENT_ID@g" "/tmp/rclone.conf"
|
||||||
|
sed -i "s@__GDRIVE_CLIENT_SECRET__@$GDRIVE_CLIENT_SECRET@g" "/tmp/rclone.conf"
|
||||||
|
sed -i "s@__GDRIVE_TOKEN__@$GDRIVE_TOKEN@g" "/tmp/rclone.conf"
|
||||||
|
|
||||||
|
echo "Sync minio buckets with encrypted remote gdrive-homelab-backups ..."
|
||||||
|
rclone --config /tmp/rclone.conf sync minio: gdrive-homelab-backups:
|
22
kubernetes/apps/default/homelab/minio/backup/rclone.conf
Normal file
22
kubernetes/apps/default/homelab/minio/backup/rclone.conf
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
[minio]
|
||||||
|
type = s3
|
||||||
|
provider = Minio
|
||||||
|
access_key_id = __RCLONE_ACCESS_ID__
|
||||||
|
secret_access_key = __RCLONE_SECRET_KEY__
|
||||||
|
endpoint = https://minio.${SECRET_DOMAIN}:51515
|
||||||
|
acl = private
|
||||||
|
|
||||||
|
[gdrive-homelab-backups]
|
||||||
|
type = crypt
|
||||||
|
remote = gdrive:homelab-backups
|
||||||
|
directory_name_encryption = false
|
||||||
|
password = __PASSWORD__
|
||||||
|
password2 = __PASSWORD2__
|
||||||
|
|
||||||
|
[gdrive]
|
||||||
|
type = drive
|
||||||
|
client_id = __GDRIVE_CLIENT_ID__
|
||||||
|
client_secret = __GDRIVE_CLIENT_SECRET__
|
||||||
|
scope = drive.file
|
||||||
|
token = __GDRIVE_TOKEN__
|
||||||
|
team_drive =
|
28
kubernetes/apps/default/homelab/minio/externalsecret.yaml
Normal file
28
kubernetes/apps/default/homelab/minio/externalsecret.yaml
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://kubernetes-schemas.devbu.io/external-secrets.io/externalsecret_v1beta1.json
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ExternalSecret
|
||||||
|
metadata:
|
||||||
|
name: homelab-minio
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
secretStoreRef:
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
name: onepassword-connect
|
||||||
|
target:
|
||||||
|
name: homelab-minio-secret
|
||||||
|
creationPolicy: Owner
|
||||||
|
template:
|
||||||
|
data:
|
||||||
|
# App
|
||||||
|
GDRIVE_CLIENT_ID: "{{ .GDRIVE_CLIENT_ID }}"
|
||||||
|
GDRIVE_CLIENT_SECRET: "{{ .GDRIVE_CLIENT_SECRET }}"
|
||||||
|
GDRIVE_TOKEN: "{{ .GDRIVE_TOKEN }}"
|
||||||
|
GDRIVE_PASSWORD: "{{ .GDRIVE_PASSWORD }}"
|
||||||
|
GDRIVE_PASSWORD2: "{{ .GDRIVE_PASSWORD2 }}"
|
||||||
|
RCLONE_ACCESS_ID: "{{ .RCLONE_ACCESS_ID }}"
|
||||||
|
RCLONE_SECRET_KEY: "{{ .RCLONE_SECRET_KEY }}"
|
||||||
|
|
||||||
|
dataFrom:
|
||||||
|
- extract:
|
||||||
|
key: homelab-minio
|
8
kubernetes/apps/default/homelab/minio/kustomization.yaml
Normal file
8
kubernetes/apps/default/homelab/minio/kustomization.yaml
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://raw.githubusercontent.com/SchemaStore/schemastore/master/src/schemas/json/kustomization.json
|
||||||
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
|
kind: Kustomization
|
||||||
|
namespace: default
|
||||||
|
resources:
|
||||||
|
- ./backup
|
||||||
|
- ./externalsecret.yaml
|
@@ -3,7 +3,7 @@
|
|||||||
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
||||||
kind: HelmRelease
|
kind: HelmRelease
|
||||||
metadata:
|
metadata:
|
||||||
name: opnsense-backup
|
name: homelab-opnsense-backup
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
interval: 30m
|
interval: 30m
|
||||||
@@ -38,12 +38,13 @@ spec:
|
|||||||
image:
|
image:
|
||||||
repository: ghcr.io/auricom/kubectl
|
repository: ghcr.io/auricom/kubectl
|
||||||
tag: 1.28.3@sha256:536e3a2a8222d56637208c207a5b77a7d656175a29b899383d5a1bb1d1e48438
|
tag: 1.28.3@sha256:536e3a2a8222d56637208c207a5b77a7d656175a29b899383d5a1bb1d1e48438
|
||||||
|
command: ["/bin/bash", "/app/opnsense-backup.sh"]
|
||||||
env:
|
env:
|
||||||
OPNSENSE_URL: "https://opnsense.${SECRET_DOMAIN}"
|
OPNSENSE_URL: "https://opnsense.${SECRET_DOMAIN}"
|
||||||
S3_URL: "https://truenas.${SECRET_DOMAIN}:51515"
|
S3_URL: "https://truenas.${SECRET_DOMAIN}:51515"
|
||||||
envFrom:
|
envFrom:
|
||||||
- secretRef:
|
- secretRef:
|
||||||
name: opnsense-backup-secret
|
name: homelab-opnsense-secret
|
||||||
service:
|
service:
|
||||||
main:
|
main:
|
||||||
enabled: false
|
enabled: false
|
||||||
@@ -51,7 +52,7 @@ spec:
|
|||||||
config:
|
config:
|
||||||
enabled: true
|
enabled: true
|
||||||
type: configMap
|
type: configMap
|
||||||
name: opnsense-backup-configmap
|
name: homelab-opnsense-backup-configmap
|
||||||
defaultMode: 0775
|
defaultMode: 0775
|
||||||
globalMounts:
|
globalMounts:
|
||||||
- path: /app/opnsense-backup.sh
|
- path: /app/opnsense-backup.sh
|
@@ -6,9 +6,9 @@ namespace: default
|
|||||||
resources:
|
resources:
|
||||||
- ./helmrelease.yaml
|
- ./helmrelease.yaml
|
||||||
configMapGenerator:
|
configMapGenerator:
|
||||||
- name: truenas-minio-rclone-configmap
|
- name: homelab-opnsense-backup-configmap
|
||||||
files:
|
files:
|
||||||
- ./minio-rclone.sh
|
- ./opnsense-backup.sh
|
||||||
generatorOptions:
|
generatorOptions:
|
||||||
disableNameSuffixHash: true
|
disableNameSuffixHash: true
|
||||||
annotations:
|
annotations:
|
@@ -3,16 +3,16 @@
|
|||||||
apiVersion: external-secrets.io/v1beta1
|
apiVersion: external-secrets.io/v1beta1
|
||||||
kind: ExternalSecret
|
kind: ExternalSecret
|
||||||
metadata:
|
metadata:
|
||||||
name: opnsense-backup
|
name: homelab-opnsense
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
secretStoreRef:
|
secretStoreRef:
|
||||||
kind: ClusterSecretStore
|
kind: ClusterSecretStore
|
||||||
name: onepassword-connect
|
name: onepassword-connect
|
||||||
target:
|
target:
|
||||||
name: opnsense-backup-secret
|
name: homelab-opnsense-secret
|
||||||
creationPolicy: Owner
|
creationPolicy: Owner
|
||||||
dataFrom:
|
dataFrom:
|
||||||
- extract:
|
- extract:
|
||||||
# OPNSENSE_KEY, OPNSENSE_SECRET, AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY
|
# OPNSENSE_KEY, OPNSENSE_SECRET, AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY
|
||||||
key: opnsense-backup
|
key: homelab-opnsense
|
@@ -4,12 +4,9 @@ apiVersion: kustomize.config.k8s.io/v1beta1
|
|||||||
kind: Kustomization
|
kind: Kustomization
|
||||||
namespace: default
|
namespace: default
|
||||||
resources:
|
resources:
|
||||||
|
- ./backup
|
||||||
- ./externalsecret.yaml
|
- ./externalsecret.yaml
|
||||||
- ./helmrelease.yaml
|
|
||||||
configMapGenerator:
|
configMapGenerator:
|
||||||
- name: opnsense-backup-configmap
|
|
||||||
files:
|
|
||||||
- ./opnsense-backup.sh
|
|
||||||
- name: opnsense-dashboard
|
- name: opnsense-dashboard
|
||||||
files:
|
files:
|
||||||
- opnsense-dashboard.json=./dashboard.json
|
- opnsense-dashboard.json=./dashboard.json
|
@@ -3,7 +3,7 @@
|
|||||||
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
||||||
kind: HelmRelease
|
kind: HelmRelease
|
||||||
metadata:
|
metadata:
|
||||||
name: truenas-backup
|
name: homelab-truenas-backup
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
interval: 30m
|
interval: 30m
|
||||||
@@ -43,7 +43,7 @@ spec:
|
|||||||
HOSTNAME: truenas
|
HOSTNAME: truenas
|
||||||
envFrom: &envFrom
|
envFrom: &envFrom
|
||||||
- secretRef:
|
- secretRef:
|
||||||
name: truenas-secret
|
name: &secret homelab-truenas-secret
|
||||||
truenas-remote-backup:
|
truenas-remote-backup:
|
||||||
name: truenas-remote-backup
|
name: truenas-remote-backup
|
||||||
image:
|
image:
|
||||||
@@ -60,7 +60,7 @@ spec:
|
|||||||
config:
|
config:
|
||||||
enabled: true
|
enabled: true
|
||||||
type: configMap
|
type: configMap
|
||||||
name: truenas-backup-configmap
|
name: homelab-truenas-backup-configmap
|
||||||
defaultMode: 0775
|
defaultMode: 0775
|
||||||
globalMounts:
|
globalMounts:
|
||||||
- path: /app/truenas-backup.sh
|
- path: /app/truenas-backup.sh
|
||||||
@@ -68,7 +68,7 @@ spec:
|
|||||||
readOnly: true
|
readOnly: true
|
||||||
ssh:
|
ssh:
|
||||||
type: secret
|
type: secret
|
||||||
name: truenas-secret
|
name: *secret
|
||||||
defaultMode: 0775
|
defaultMode: 0775
|
||||||
globalMounts:
|
globalMounts:
|
||||||
- path: /opt/id_rsa
|
- path: /opt/id_rsa
|
@@ -6,7 +6,7 @@ namespace: default
|
|||||||
resources:
|
resources:
|
||||||
- ./helmrelease.yaml
|
- ./helmrelease.yaml
|
||||||
configMapGenerator:
|
configMapGenerator:
|
||||||
- name: truenas-backup-configmap
|
- name: homelab-truenas-backup-configmap
|
||||||
files:
|
files:
|
||||||
- ./truenas-backup.sh
|
- ./truenas-backup.sh
|
||||||
generatorOptions:
|
generatorOptions:
|
@@ -3,7 +3,7 @@
|
|||||||
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
||||||
kind: HelmRelease
|
kind: HelmRelease
|
||||||
metadata:
|
metadata:
|
||||||
name: truenas-certs-deploy
|
name: homelab-truenas-certs-deploy
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
interval: 30m
|
interval: 30m
|
||||||
@@ -45,7 +45,7 @@ spec:
|
|||||||
CERTS_DEPLOY_S3_ENABLED: "True"
|
CERTS_DEPLOY_S3_ENABLED: "True"
|
||||||
envFrom: &envFrom
|
envFrom: &envFrom
|
||||||
- secretRef:
|
- secretRef:
|
||||||
name: truenas-secret
|
name: &secret homelab-truenas-secret
|
||||||
truenas-remote-certs-deploy:
|
truenas-remote-certs-deploy:
|
||||||
image:
|
image:
|
||||||
repository: ghcr.io/auricom/kubectl
|
repository: ghcr.io/auricom/kubectl
|
||||||
@@ -63,7 +63,7 @@ spec:
|
|||||||
config:
|
config:
|
||||||
enabled: true
|
enabled: true
|
||||||
type: configMap
|
type: configMap
|
||||||
name: truenas-certs-deploy-configmap
|
name: homelab-truenas-certs-deploy-configmap
|
||||||
defaultMode: 0775
|
defaultMode: 0775
|
||||||
globalMounts:
|
globalMounts:
|
||||||
- path: /app/truenas-certs-deploy.sh
|
- path: /app/truenas-certs-deploy.sh
|
||||||
@@ -71,7 +71,7 @@ spec:
|
|||||||
readOnly: true
|
readOnly: true
|
||||||
config-python:
|
config-python:
|
||||||
type: configMap
|
type: configMap
|
||||||
name: truenas-certs-deploy-configmap
|
name: homelab-truenas-certs-deploy-configmap
|
||||||
defaultMode: 0775
|
defaultMode: 0775
|
||||||
globalMounts:
|
globalMounts:
|
||||||
- path: /app/truenas-certs-deploy.py
|
- path: /app/truenas-certs-deploy.py
|
||||||
@@ -79,7 +79,7 @@ spec:
|
|||||||
readOnly: true
|
readOnly: true
|
||||||
ssh:
|
ssh:
|
||||||
type: secret
|
type: secret
|
||||||
name: truenas-secret
|
name: *secret
|
||||||
defaultMode: 0775
|
defaultMode: 0775
|
||||||
globalMounts:
|
globalMounts:
|
||||||
- path: /opt/id_rsa
|
- path: /opt/id_rsa
|
@@ -6,7 +6,7 @@ namespace: default
|
|||||||
resources:
|
resources:
|
||||||
- ./helmrelease.yaml
|
- ./helmrelease.yaml
|
||||||
configMapGenerator:
|
configMapGenerator:
|
||||||
- name: truenas-certs-deploy-configmap
|
- name: homelab-truenas-certs-deploy-configmap
|
||||||
files:
|
files:
|
||||||
- ./truenas-certs-deploy.sh
|
- ./truenas-certs-deploy.sh
|
||||||
- ./truenas-certs-deploy.py
|
- ./truenas-certs-deploy.py
|
@@ -3,14 +3,14 @@
|
|||||||
apiVersion: external-secrets.io/v1beta1
|
apiVersion: external-secrets.io/v1beta1
|
||||||
kind: ExternalSecret
|
kind: ExternalSecret
|
||||||
metadata:
|
metadata:
|
||||||
name: truenas
|
name: homelab-truenas
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
secretStoreRef:
|
secretStoreRef:
|
||||||
kind: ClusterSecretStore
|
kind: ClusterSecretStore
|
||||||
name: onepassword-connect
|
name: onepassword-connect
|
||||||
target:
|
target:
|
||||||
name: truenas-secret
|
name: homelab-truenas-secret
|
||||||
creationPolicy: Owner
|
creationPolicy: Owner
|
||||||
template:
|
template:
|
||||||
data:
|
data:
|
||||||
@@ -24,13 +24,12 @@ spec:
|
|||||||
TRUENAS_REMOTE_API_KEY: "{{ .TRUENAS_REMOTE_API_KEY }}"
|
TRUENAS_REMOTE_API_KEY: "{{ .TRUENAS_REMOTE_API_KEY }}"
|
||||||
SECRET_DOMAIN: "{{ .SECRET_DOMAIN }}"
|
SECRET_DOMAIN: "{{ .SECRET_DOMAIN }}"
|
||||||
SECRET_PUBLIC_DOMAIN: "{{ .SECRET_PUBLIC_DOMAIN }}"
|
SECRET_PUBLIC_DOMAIN: "{{ .SECRET_PUBLIC_DOMAIN }}"
|
||||||
SOPS_AGE_KEY: "{{ .SOPS_AGE_KEY }}"
|
|
||||||
dataFrom:
|
dataFrom:
|
||||||
- extract:
|
- extract:
|
||||||
key: generic
|
key: generic
|
||||||
|
- extract:
|
||||||
|
key: homelab-truenas
|
||||||
- extract:
|
- extract:
|
||||||
key: pushover
|
key: pushover
|
||||||
- extract:
|
- extract:
|
||||||
key: sops
|
key: sops
|
||||||
- extract:
|
|
||||||
key: truenas
|
|
@@ -7,4 +7,3 @@ resources:
|
|||||||
- ./backup
|
- ./backup
|
||||||
- ./certs-deploy
|
- ./certs-deploy
|
||||||
- ./externalsecret.yaml
|
- ./externalsecret.yaml
|
||||||
- ./minio-rclone
|
|
@@ -20,6 +20,7 @@ resources:
|
|||||||
- ./hajimari/ks.yaml
|
- ./hajimari/ks.yaml
|
||||||
- ./home-assistant/ks.yaml
|
- ./home-assistant/ks.yaml
|
||||||
- ./homebox/ks.yaml
|
- ./homebox/ks.yaml
|
||||||
|
- ./homelab/ks.yaml
|
||||||
- ./immich/ks.yaml
|
- ./immich/ks.yaml
|
||||||
- ./invidious/ks.yaml
|
- ./invidious/ks.yaml
|
||||||
- ./jellyfin/ks.yaml
|
- ./jellyfin/ks.yaml
|
||||||
@@ -38,7 +39,6 @@ resources:
|
|||||||
- ./media-browser/ks.yaml
|
- ./media-browser/ks.yaml
|
||||||
- ./music-transcode/ks.yaml
|
- ./music-transcode/ks.yaml
|
||||||
- ./navidrome/ks.yaml
|
- ./navidrome/ks.yaml
|
||||||
- ./opnsense/ks.yaml
|
|
||||||
- ./outline/ks.yaml
|
- ./outline/ks.yaml
|
||||||
- ./paperless/ks.yaml
|
- ./paperless/ks.yaml
|
||||||
- ./pgadmin/ks.yaml
|
- ./pgadmin/ks.yaml
|
||||||
@@ -54,7 +54,6 @@ resources:
|
|||||||
- ./sonarr/ks.yaml
|
- ./sonarr/ks.yaml
|
||||||
- ./smtp-relay/ks.yaml
|
- ./smtp-relay/ks.yaml
|
||||||
- ./tandoor/ks.yaml
|
- ./tandoor/ks.yaml
|
||||||
- ./truenas/ks.yaml
|
|
||||||
- ./unifi/ks.yaml
|
- ./unifi/ks.yaml
|
||||||
- ./vaultwarden/ks.yaml
|
- ./vaultwarden/ks.yaml
|
||||||
- ./vikunja/ks.yaml
|
- ./vikunja/ks.yaml
|
||||||
|
@@ -1,20 +0,0 @@
|
|||||||
---
|
|
||||||
# yaml-language-server: $schema=https://raw.githubusercontent.com/fluxcd-community/flux2-schemas/main/kustomization-kustomize-v1.json
|
|
||||||
apiVersion: kustomize.toolkit.fluxcd.io/v1
|
|
||||||
kind: Kustomization
|
|
||||||
metadata:
|
|
||||||
name: cluster-apps-opnsense
|
|
||||||
namespace: flux-system
|
|
||||||
labels:
|
|
||||||
substitution.flux.home.arpa/enabled: "true"
|
|
||||||
spec:
|
|
||||||
path: ./kubernetes/apps/default/opnsense/app
|
|
||||||
prune: true
|
|
||||||
sourceRef:
|
|
||||||
kind: GitRepository
|
|
||||||
name: home-ops-kubernetes
|
|
||||||
dependsOn:
|
|
||||||
- name: cluster-apps-external-secrets-stores
|
|
||||||
interval: 30m
|
|
||||||
retryInterval: 1m
|
|
||||||
timeout: 3m
|
|
@@ -1,20 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
set -o nounset
|
|
||||||
set -o errexit
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
echo "Download rclone config file ..."
|
|
||||||
curl -fsSL \
|
|
||||||
--output "/tmp/rclone.conf.age" \
|
|
||||||
"https://raw.githubusercontent.com/auricom/dotfiles/main/private_dot_config/rclone/encrypted_private_rclone.conf.age"
|
|
||||||
|
|
||||||
echo "Decrypt rclone config file ..."
|
|
||||||
age --decrypt \
|
|
||||||
-i /app/age_key \
|
|
||||||
/tmp/rclone.conf.age > /tmp/rclone.conf
|
|
||||||
|
|
||||||
|
|
||||||
echo "Sync minio buckets with encrypted remote gdrive-homelab-backups ..."
|
|
||||||
rclone --config /tmp/rclone.conf sync minio: gdrive-homelab-backups:
|
|
@@ -1,18 +0,0 @@
|
|||||||
---
|
|
||||||
# yaml-language-server: $schema=https://raw.githubusercontent.com/fluxcd-community/flux2-schemas/main/kustomization-kustomize-v1.json
|
|
||||||
apiVersion: kustomize.toolkit.fluxcd.io/v1
|
|
||||||
kind: Kustomization
|
|
||||||
metadata:
|
|
||||||
name: cluster-apps-truenas
|
|
||||||
namespace: flux-system
|
|
||||||
labels:
|
|
||||||
substitution.flux.home.arpa/enabled: "true"
|
|
||||||
spec:
|
|
||||||
path: ./kubernetes/apps/default/truenas
|
|
||||||
prune: true
|
|
||||||
sourceRef:
|
|
||||||
kind: GitRepository
|
|
||||||
name: home-ops-kubernetes
|
|
||||||
interval: 30m
|
|
||||||
retryInterval: 1m
|
|
||||||
timeout: 3m
|
|
Reference in New Issue
Block a user