Compare commits
21 Commits
rclone-buc
...
generic-de
| Author | SHA1 | Date | |
|---|---|---|---|
| 9be8e7dd76 | |||
|
142a3556b1
|
|||
| 9347aa397e | |||
| 9e7ab77502 | |||
| 8c9a3bf080 | |||
| 86c9cd930a | |||
| 0f14e46c20 | |||
| 8cae3bb53c | |||
|
49e3392ed5
|
|||
| 8e9b9460b6 | |||
|
82ded9e1cd
|
|||
| 89319e12c5 | |||
|
007016b59f
|
|||
| 52363a1dbc | |||
| 1a535ae4c2 | |||
| 5a73a500a2 | |||
| 67d0dbcf71 | |||
| f901d1574b | |||
| 73779ad42b | |||
| 96cc6a8038 | |||
| addd63616c |
@@ -1,6 +1,6 @@
|
|||||||
apiVersion: v2
|
apiVersion: v2
|
||||||
name: generic-device-plugin
|
name: generic-device-plugin
|
||||||
version: 0.20.31
|
version: 0.20.33
|
||||||
description: Generic Device Plugin
|
description: Generic Device Plugin
|
||||||
keywords:
|
keywords:
|
||||||
- generic-device-plugin
|
- generic-device-plugin
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# generic-device-plugin
|
# generic-device-plugin
|
||||||
|
|
||||||
 
|
 
|
||||||
|
|
||||||
Generic Device Plugin
|
Generic Device Plugin
|
||||||
|
|
||||||
@@ -28,7 +28,7 @@ Generic Device Plugin
|
|||||||
| config | object | `{"data":"devices:\n - name: serial\n groups:\n - paths:\n - path: /dev/ttyUSB*\n - paths:\n - path: /dev/ttyACM*\n - paths:\n - path: /dev/tty.usb*\n - paths:\n - path: /dev/cu.*\n - paths:\n - path: /dev/cuaU*\n - paths:\n - path: /dev/rfcomm*\n - name: video\n groups:\n - paths:\n - path: /dev/video0\n - name: fuse\n groups:\n - count: 10\n paths:\n - path: /dev/fuse\n - name: audio\n groups:\n - count: 10\n paths:\n - path: /dev/snd\n - name: capture\n groups:\n - paths:\n - path: /dev/snd/controlC0\n - path: /dev/snd/pcmC0D0c\n - paths:\n - path: /dev/snd/controlC1\n mountPath: /dev/snd/controlC0\n - path: /dev/snd/pcmC1D0c\n mountPath: /dev/snd/pcmC0D0c\n - paths:\n - path: /dev/snd/controlC2\n mountPath: /dev/snd/controlC0\n - path: /dev/snd/pcmC2D0c\n mountPath: /dev/snd/pcmC0D0c\n - paths:\n - path: /dev/snd/controlC3\n mountPath: /dev/snd/controlC0\n - path: /dev/snd/pcmC3D0c\n mountPath: /dev/snd/pcmC0D0c\n","enabled":true}` | Config map |
|
| config | object | `{"data":"devices:\n - name: serial\n groups:\n - paths:\n - path: /dev/ttyUSB*\n - paths:\n - path: /dev/ttyACM*\n - paths:\n - path: /dev/tty.usb*\n - paths:\n - path: /dev/cu.*\n - paths:\n - path: /dev/cuaU*\n - paths:\n - path: /dev/rfcomm*\n - name: video\n groups:\n - paths:\n - path: /dev/video0\n - name: fuse\n groups:\n - count: 10\n paths:\n - path: /dev/fuse\n - name: audio\n groups:\n - count: 10\n paths:\n - path: /dev/snd\n - name: capture\n groups:\n - paths:\n - path: /dev/snd/controlC0\n - path: /dev/snd/pcmC0D0c\n - paths:\n - path: /dev/snd/controlC1\n mountPath: /dev/snd/controlC0\n - path: /dev/snd/pcmC1D0c\n mountPath: /dev/snd/pcmC0D0c\n - paths:\n - path: /dev/snd/controlC2\n mountPath: /dev/snd/controlC0\n - path: /dev/snd/pcmC2D0c\n mountPath: /dev/snd/pcmC0D0c\n - paths:\n - path: /dev/snd/controlC3\n mountPath: /dev/snd/controlC0\n - path: /dev/snd/pcmC3D0c\n mountPath: /dev/snd/pcmC0D0c\n","enabled":true}` | Config map |
|
||||||
| config.data | string | See [values.yaml](./values.yaml) | generic-device-plugin config file [[ref]](https://github.com/squat/generic-device-plugin#usage) |
|
| config.data | string | See [values.yaml](./values.yaml) | generic-device-plugin config file [[ref]](https://github.com/squat/generic-device-plugin#usage) |
|
||||||
| deviceDomain | string | `"devic.es"` | Domain used by devices for identifcation |
|
| deviceDomain | string | `"devic.es"` | Domain used by devices for identifcation |
|
||||||
| image | object | `{"pullPolicy":"Always","repository":"ghcr.io/squat/generic-device-plugin","tag":"latest@sha256:d9e098e33a20c32a561adb1ef8cace7d5912cd5ffb38f07dd9f83af4bdf38505"}` | Default image |
|
| image | object | `{"pullPolicy":"Always","repository":"ghcr.io/squat/generic-device-plugin","tag":"latest@sha256:826da38d5a66409d6042ac92dc6357f2e45675cdcedb2d259c893a4392734630"}` | Default image |
|
||||||
| name | string | `"generic-device-plugin"` | Name override of release |
|
| name | string | `"generic-device-plugin"` | Name override of release |
|
||||||
| resources | object | `{"requests":{"cpu":"50m","memory":"10Mi"}}` | Default resources |
|
| resources | object | `{"requests":{"cpu":"50m","memory":"10Mi"}}` | Default resources |
|
||||||
| service | object | `{"listenPort":8080}` | Service port |
|
| service | object | `{"listenPort":8080}` | Service port |
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ name: generic-device-plugin
|
|||||||
# -- Default image
|
# -- Default image
|
||||||
image:
|
image:
|
||||||
repository: ghcr.io/squat/generic-device-plugin
|
repository: ghcr.io/squat/generic-device-plugin
|
||||||
tag: latest@sha256:d9e098e33a20c32a561adb1ef8cace7d5912cd5ffb38f07dd9f83af4bdf38505
|
tag: latest@sha256:face0477a34f4eb49502226a28d126403b844c2eaee7ce691e7b9529ca8ab123
|
||||||
pullPolicy: Always
|
pullPolicy: Always
|
||||||
|
|
||||||
# -- Domain used by devices for identifcation
|
# -- Domain used by devices for identifcation
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
apiVersion: v2
|
apiVersion: v2
|
||||||
name: rclone-bucket
|
name: rclone-bucket
|
||||||
version: 0.1.0
|
version: 0.7.0
|
||||||
description: Rclone CronJob to replicate buckets
|
description: Rclone CronJob to replicate buckets
|
||||||
keywords:
|
keywords:
|
||||||
- rclone-bucket
|
- rclone-bucket
|
||||||
@@ -17,4 +17,4 @@ dependencies:
|
|||||||
version: 4.6.2
|
version: 4.6.2
|
||||||
icon: https://cdn.jsdelivr.net/gh/selfhst/icons@main/png/rclone.png
|
icon: https://cdn.jsdelivr.net/gh/selfhst/icons@main/png/rclone.png
|
||||||
# renovate: datasource=github-releases depName=rclone/rclone
|
# renovate: datasource=github-releases depName=rclone/rclone
|
||||||
appVersion: v1.73.5
|
appVersion: v1.74.0
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# rclone-bucket
|
# rclone-bucket
|
||||||
|
|
||||||
 
|
 
|
||||||
|
|
||||||
Rclone CronJob to replicate buckets
|
Rclone CronJob to replicate buckets
|
||||||
|
|
||||||
@@ -27,9 +27,9 @@ Rclone CronJob to replicate buckets
|
|||||||
|-----|------|---------|-------------|
|
|-----|------|---------|-------------|
|
||||||
| additionalLabels | object | `{}` | Add additional labels |
|
| additionalLabels | object | `{}` | Add additional labels |
|
||||||
| cronJob | object | `{"backoffLimit":3,"parallelism":1,"schedule":"0 0 * * *","suspend":false,"timeZone":"America/Chicago"}` | CronJob configuration |
|
| cronJob | object | `{"backoffLimit":3,"parallelism":1,"schedule":"0 0 * * *","suspend":false,"timeZone":"America/Chicago"}` | CronJob configuration |
|
||||||
| image | object | `{"pullPolicy":"IfNotPresent","repository":"rclone/rclone","tag":"1.73.5@sha256:1619a625f845e169c34b952cf40c483c0392965b821c5155cde8cbfd35254a96"}` | Default image |
|
| image | object | `{"pullPolicy":"IfNotPresent","repository":"rclone/rclone","tag":"1.74.0@sha256:d2e0e88359d0b2e67cfcd2c43d5405185eb8adfc207079df27c42da82c5207bc"}` | Default image |
|
||||||
| nameOverride | string | `""` | Default pattern follows <pvcTarget>-backup |
|
| nameOverride | string | `""` | Default pattern follows <pvcTarget>-backup |
|
||||||
| prune | object | `{"ageToPrune":"90d","enabled":false}` | Enable prune job |
|
| prune | object | `{"ageToPrune":"90d","enabled":false,"exclude":"","include":""}` | Enable prune job |
|
||||||
| rclone | object | `{"destination":{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"},"providerType":"Other","source":{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"}}` | rclone configuration |
|
| rclone | object | `{"destination":{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"},"providerType":"Other","source":{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"}}` | rclone configuration |
|
||||||
| rclone.destination | object | `{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"}` | Destination configuration |
|
| rclone.destination | object | `{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"}` | Destination configuration |
|
||||||
| rclone.source | object | `{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"}` | Source configuration |
|
| rclone.source | object | `{"bucketName":"bucket","forcePathStyle":true,"providerType":"Other"}` | Source configuration |
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ Generate the secret name
|
|||||||
{{- if .Values.secret.externalSecret.source.nameOverride }}
|
{{- if .Values.secret.externalSecret.source.nameOverride }}
|
||||||
{{- .Values.secret.externalSecret.source.nameOverride | trunc 63 | trimSuffix "-" }}
|
{{- .Values.secret.externalSecret.source.nameOverride | trunc 63 | trimSuffix "-" }}
|
||||||
{{- else }}
|
{{- else }}
|
||||||
{{- printf "%s-rclone-config" .Values.rclone.source.bucketName -}}
|
{{- printf "%s-rclone-source-config" .Values.rclone.source.bucketName -}}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- else if .Values.secret.existingSecretSource.name }}
|
{{- else if .Values.secret.existingSecretSource.name }}
|
||||||
{{- printf "%s" .Values.secret.existingSecretSource.name -}}
|
{{- printf "%s" .Values.secret.existingSecretSource.name -}}
|
||||||
@@ -31,7 +31,7 @@ Generate the secret name
|
|||||||
{{- if .Values.secret.externalSecret.destination.nameOverride }}
|
{{- if .Values.secret.externalSecret.destination.nameOverride }}
|
||||||
{{- .Values.secret.externalSecret.destination.nameOverride | trunc 63 | trimSuffix "-" }}
|
{{- .Values.secret.externalSecret.destination.nameOverride | trunc 63 | trimSuffix "-" }}
|
||||||
{{- else }}
|
{{- else }}
|
||||||
{{- printf "%s-rclone-config" .Values.rclone.destination.bucketName -}}
|
{{- printf "%s-rclone-destination-config" .Values.rclone.destination.bucketName -}}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- else if .Values.secret.existingSecretDestination.name }}
|
{{- else if .Values.secret.existingSecretDestination.name }}
|
||||||
{{- printf "%s" .Values.secret.existingSecretDestination.name -}}
|
{{- printf "%s" .Values.secret.existingSecretDestination.name -}}
|
||||||
@@ -43,35 +43,35 @@ Generate the secret name
|
|||||||
{{/*
|
{{/*
|
||||||
Common env names
|
Common env names
|
||||||
*/}}
|
*/}}
|
||||||
{{- define "secret.envAccessKey" -}}
|
{{- define "secretRclone.envAccessKey" -}}
|
||||||
ACCESS_KEY_ID
|
ACCESS_KEY_ID
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- define "secret.envSecretKey" -}}
|
{{- define "secretRclone.envSecretKey" -}}
|
||||||
ACCESS_SECRET_KEY
|
ACCESS_SECRET_KEY
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- define "secret.envRegion" -}}
|
{{- define "secretRclone.envRegion" -}}
|
||||||
ACCESS_REGION
|
ACCESS_REGION
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- define "secret.envSrcEndpoint" -}}
|
{{- define "secretRclone.envSrcEndpoint" -}}
|
||||||
SRC_ENDPOINT
|
SRC_ENDPOINT
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- define "secret.envDestEndpoint" -}}
|
{{- define "secretRclone.envDestEndpoint" -}}
|
||||||
DEST_ENDPOINT
|
DEST_ENDPOINT
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|
||||||
{{/*
|
{{/*
|
||||||
Create chart name and version as used by the chart label.
|
Create chart name and version as used by the chart label.
|
||||||
*/}}
|
*/}}
|
||||||
{{- define "secret.chart" -}}
|
{{- define "secretRclone.chart" -}}
|
||||||
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
|
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|
||||||
{{/*
|
{{/*
|
||||||
Common labels
|
Common labels
|
||||||
*/}}
|
*/}}
|
||||||
{{- define "secret.labels" -}}
|
{{- define "secretRclone.labels" -}}
|
||||||
helm.sh/chart: {{ include "secret.chart" $ }}
|
helm.sh/chart: {{ include "secretRclone.chart" $ }}
|
||||||
{{ include "secret.selectorLabels" $ }}
|
{{ include "secretRclone.selectorLabels" $ }}
|
||||||
{{- if .Chart.AppVersion }}
|
{{- if .Chart.AppVersion }}
|
||||||
app.kubernetes.io/version: {{ .Chart.Version | quote }}
|
app.kubernetes.io/version: {{ .Chart.Version | quote }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
@@ -84,7 +84,7 @@ app.kubernetes.io/managed-by: {{ .Release.Service }}
|
|||||||
{{/*
|
{{/*
|
||||||
Selector labels
|
Selector labels
|
||||||
*/}}
|
*/}}
|
||||||
{{- define "secret.selectorLabels" -}}
|
{{- define "secretRclone.selectorLabels" -}}
|
||||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
app.kubernetes.io/part-of: {{ .Release.Name }}
|
app.kubernetes.io/part-of: {{ .Release.Name }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|||||||
@@ -22,6 +22,18 @@ controllers:
|
|||||||
- src:{{ .Values.rclone.source.bucketName }}
|
- src:{{ .Values.rclone.source.bucketName }}
|
||||||
- dest:{{ .Values.rclone.destination.bucketName }}
|
- dest:{{ .Values.rclone.destination.bucketName }}
|
||||||
- --s3-no-check-bucket
|
- --s3-no-check-bucket
|
||||||
|
{{- if .Values.prune.enabled }}
|
||||||
|
- --max-age
|
||||||
|
- {{ .Values.prune.ageToPrune | quote }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.prune.include }}
|
||||||
|
- --include
|
||||||
|
- {{ .Values.prune.include | quote }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.prune.exclude }}
|
||||||
|
- --exclude
|
||||||
|
- {{ .Values.prune.exclude | quote }}
|
||||||
|
{{- end }}
|
||||||
- --verbose
|
- --verbose
|
||||||
env:
|
env:
|
||||||
- name: RCLONE_S3_PROVIDER
|
- name: RCLONE_S3_PROVIDER
|
||||||
@@ -31,57 +43,57 @@ controllers:
|
|||||||
- name: RCLONE_CONFIG_SRC_PROVIDER
|
- name: RCLONE_CONFIG_SRC_PROVIDER
|
||||||
value: {{ .Values.rclone.source.providerType }}
|
value: {{ .Values.rclone.source.providerType }}
|
||||||
- name: RCLONE_CONFIG_SRC_ENV_AUTH
|
- name: RCLONE_CONFIG_SRC_ENV_AUTH
|
||||||
value: false
|
value: "false"
|
||||||
- name: RCLONE_CONFIG_SRC_ACCESS_KEY_ID
|
- name: RCLONE_CONFIG_SRC_ACCESS_KEY_ID
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.sourceSecretName" . }}
|
name: {{ include "rclone.sourceSecretName" . }}
|
||||||
key: {{ include "secret.envAccessKey" . }}
|
key: {{ include "secretRclone.envAccessKey" . }}
|
||||||
- name: RCLONE_CONFIG_SRC_SECRET_ACCESS_KEY
|
- name: RCLONE_CONFIG_SRC_SECRET_ACCESS_KEY
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.sourceSecretName" . }}
|
name: {{ include "rclone.sourceSecretName" . }}
|
||||||
key: {{ include "secret.envSecretKey" . }}
|
key: {{ include "secretRclone.envSecretKey" . }}
|
||||||
- name: RCLONE_CONFIG_SRC_REGION
|
- name: RCLONE_CONFIG_SRC_REGION
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.sourceSecretName" . }}
|
name: {{ include "rclone.sourceSecretName" . }}
|
||||||
key: {{ include "secret.envRegion" . }}
|
key: {{ include "secretRclone.envRegion" . }}
|
||||||
- name: RCLONE_CONFIG_SRC_ENDPOINT
|
- name: RCLONE_CONFIG_SRC_ENDPOINT
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.sourceSecretName" . }}
|
name: {{ include "rclone.sourceSecretName" . }}
|
||||||
key: {{ include "secret.envSrcEndpoint" . }}
|
key: {{ include "secretRclone.envSrcEndpoint" . }}
|
||||||
- name: RCLONE_CONFIG_SRC_S3_FORCE_PATH_STYLE
|
- name: RCLONE_CONFIG_SRC_FORCE_PATH_STYLE
|
||||||
value: {{ .Values.rclone.source.forcePathStyle }}
|
value: {{ .Values.rclone.source.forcePathStyle | quote }}
|
||||||
- name: RCLONE_CONFIG_DEST_TYPE
|
- name: RCLONE_CONFIG_DEST_TYPE
|
||||||
value: s3
|
value: s3
|
||||||
- name: RCLONE_CONFIG_DEST_PROVIDER
|
- name: RCLONE_CONFIG_DEST_PROVIDER
|
||||||
value: {{ .Values.rclone.destination.providerType }}
|
value: {{ .Values.rclone.destination.providerType }}
|
||||||
- name: RCLONE_CONFIG_DEST_ENV_AUTH
|
- name: RCLONE_CONFIG_DEST_ENV_AUTH
|
||||||
value: false
|
value: "false"
|
||||||
- name: RCLONE_CONFIG_DEST_ACCESS_KEY_ID
|
- name: RCLONE_CONFIG_DEST_ACCESS_KEY_ID
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envAccessKey" . }}
|
key: {{ include "secretRclone.envAccessKey" . }}
|
||||||
- name: RCLONE_CONFIG_DEST_SECRET_ACCESS_KEY
|
- name: RCLONE_CONFIG_DEST_SECRET_ACCESS_KEY
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envSecretKey" . }}
|
key: {{ include "secretRclone.envSecretKey" . }}
|
||||||
- name: RCLONE_CONFIG_DEST_REGION
|
- name: RCLONE_CONFIG_DEST_REGION
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envRegion" . }}
|
key: {{ include "secretRclone.envRegion" . }}
|
||||||
- name: RCLONE_CONFIG_DEST_ENDPOINT
|
- name: RCLONE_CONFIG_DEST_ENDPOINT
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envDestEndpoint" . }}
|
key: {{ include "secretRclone.envDestEndpoint" . }}
|
||||||
- name: RCLONE_CONFIG_SRC_DEST_FORCE_PATH_STYLE
|
- name: RCLONE_CONFIG_DEST_FORCE_PATH_STYLE
|
||||||
value: {{ .Values.rclone.destination.forcePathStyle }}
|
value: {{ .Values.rclone.destination.forcePathStyle | quote }}
|
||||||
{{- if .Values.prune.enabled }}
|
{{- if .Values.prune.enabled }}
|
||||||
prune:
|
prune:
|
||||||
image:
|
image:
|
||||||
@@ -92,7 +104,7 @@ controllers:
|
|||||||
- delete
|
- delete
|
||||||
- dest:{{ .Values.rclone.destination.bucketName }}
|
- dest:{{ .Values.rclone.destination.bucketName }}
|
||||||
- --min-age
|
- --min-age
|
||||||
- {{ .Values.prune.ageToPrune }}
|
- {{ .Values.prune.ageToPrune | quote }}
|
||||||
- --verbose
|
- --verbose
|
||||||
env:
|
env:
|
||||||
- name: RCLONE_CONFIG_DEST_TYPE
|
- name: RCLONE_CONFIG_DEST_TYPE
|
||||||
@@ -100,29 +112,29 @@ controllers:
|
|||||||
- name: RCLONE_CONFIG_DEST_PROVIDER
|
- name: RCLONE_CONFIG_DEST_PROVIDER
|
||||||
value: {{ .Values.rclone.destination.providerType }}
|
value: {{ .Values.rclone.destination.providerType }}
|
||||||
- name: RCLONE_CONFIG_DEST_ENV_AUTH
|
- name: RCLONE_CONFIG_DEST_ENV_AUTH
|
||||||
value: false
|
value: "false"
|
||||||
- name: RCLONE_CONFIG_DEST_ACCESS_KEY_ID
|
- name: RCLONE_CONFIG_DEST_ACCESS_KEY_ID
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envAccessKey" . }}
|
key: {{ include "secretRclone.envAccessKey" . }}
|
||||||
- name: RCLONE_CONFIG_DEST_SECRET_ACCESS_KEY
|
- name: RCLONE_CONFIG_DEST_SECRET_ACCESS_KEY
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envSecretKey" . }}
|
key: {{ include "secretRclone.envSecretKey" . }}
|
||||||
- name: RCLONE_CONFIG_DEST_REGION
|
- name: RCLONE_CONFIG_DEST_REGION
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envRegion" . }}
|
key: {{ include "secretRclone.envRegion" . }}
|
||||||
- name: RCLONE_CONFIG_DEST_ENDPOINT
|
- name: RCLONE_CONFIG_DEST_ENDPOINT
|
||||||
valueFrom:
|
valueFrom:
|
||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
key: {{ include "secret.envDestEndpoint" . }}
|
key: {{ include "secretRclone.envDestEndpoint" . }}
|
||||||
- name: RCLONE_CONFIG_SRC_S3_FORCE_PATH_STYLE
|
- name: RCLONE_CONFIG_DEST_FORCE_PATH_STYLE
|
||||||
value: {{ .Values.rclone.destination.forcePathStyle }}
|
value: {{ .Values.rclone.destination.forcePathStyle | quote }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
{{- $_ := mergeOverwrite .Values (include "rclone.hardcodedValues" . | fromYaml) -}}
|
{{- $_ := mergeOverwrite .Values (include "rclone.hardcodedValues" . | fromYaml) -}}
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ metadata:
|
|||||||
name: {{ include "rclone.sourceSecretName" . }}
|
name: {{ include "rclone.sourceSecretName" . }}
|
||||||
namespace: {{ .Release.Namespace }}
|
namespace: {{ .Release.Namespace }}
|
||||||
labels:
|
labels:
|
||||||
{{- include "secret.labels" . | nindent 4 }}
|
{{- include "secretRclone.labels" . | nindent 4 }}
|
||||||
app.kubernetes.io/name: {{ include "rclone.sourceSecretName" . }}
|
app.kubernetes.io/name: {{ include "rclone.sourceSecretName" . }}
|
||||||
{{- with .Values.additionalLabels }}
|
{{- with .Values.additionalLabels }}
|
||||||
{{- toYaml . | nindent 4 }}
|
{{- toYaml . | nindent 4 }}
|
||||||
@@ -16,19 +16,19 @@ spec:
|
|||||||
kind: ClusterSecretStore
|
kind: ClusterSecretStore
|
||||||
name: {{ .Values.secret.externalSecret.storeName | required "External Secret store name is required" }}
|
name: {{ .Values.secret.externalSecret.storeName | required "External Secret store name is required" }}
|
||||||
data:
|
data:
|
||||||
- secretKey: {{ include "secret.envAccessKey" . }}
|
- secretKey: {{ include "secretRclone.envAccessKey" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.source.credentials.path }}
|
key: {{ .Values.secret.externalSecret.source.credentials.path }}
|
||||||
property: {{ .Values.secret.externalSecret.source.credentials.keyIdProperty }}
|
property: {{ .Values.secret.externalSecret.source.credentials.keyIdProperty }}
|
||||||
- secretKey: {{ include "secret.envSecretKey" . }}
|
- secretKey: {{ include "secretRclone.envSecretKey" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.source.credentials.path }}
|
key: {{ .Values.secret.externalSecret.source.credentials.path }}
|
||||||
property: {{ .Values.secret.externalSecret.source.credentials.secretKeyProperty }}
|
property: {{ .Values.secret.externalSecret.source.credentials.secretKeyProperty }}
|
||||||
- secretKey: {{ include "secret.envRegion" . }}
|
- secretKey: {{ include "secretRclone.envRegion" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.source.credentials.path }}
|
key: {{ .Values.secret.externalSecret.source.credentials.path }}
|
||||||
property: {{ .Values.secret.externalSecret.source.credentials.regionProperty }}
|
property: {{ .Values.secret.externalSecret.source.credentials.regionProperty }}
|
||||||
- secretKey: {{ include "secret.envSrcEndpoint" . }}
|
- secretKey: {{ include "secretRclone.envSrcEndpoint" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.source.config.path }}
|
key: {{ .Values.secret.externalSecret.source.config.path }}
|
||||||
property: {{ .Values.secret.externalSecret.source.config.endpointProperty }}
|
property: {{ .Values.secret.externalSecret.source.config.endpointProperty }}
|
||||||
@@ -40,7 +40,7 @@ metadata:
|
|||||||
name: {{ include "rclone.destinationSecretName" . }}
|
name: {{ include "rclone.destinationSecretName" . }}
|
||||||
namespace: {{ .Release.Namespace }}
|
namespace: {{ .Release.Namespace }}
|
||||||
labels:
|
labels:
|
||||||
{{- include "secret.labels" . | nindent 4 }}
|
{{- include "secretRclone.labels" . | nindent 4 }}
|
||||||
app.kubernetes.io/name: {{ include "rclone.destinationSecretName" . }}
|
app.kubernetes.io/name: {{ include "rclone.destinationSecretName" . }}
|
||||||
{{- with .Values.additionalLabels }}
|
{{- with .Values.additionalLabels }}
|
||||||
{{- toYaml . | nindent 4 }}
|
{{- toYaml . | nindent 4 }}
|
||||||
@@ -50,19 +50,19 @@ spec:
|
|||||||
kind: ClusterSecretStore
|
kind: ClusterSecretStore
|
||||||
name: {{ .Values.secret.externalSecret.storeName | required "External Secret store name is required" }}
|
name: {{ .Values.secret.externalSecret.storeName | required "External Secret store name is required" }}
|
||||||
data:
|
data:
|
||||||
- secretKey: {{ include "secret.envAccessKey" . }}
|
- secretKey: {{ include "secretRclone.envAccessKey" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.destination.credentials.path }}
|
key: {{ .Values.secret.externalSecret.destination.credentials.path }}
|
||||||
property: {{ .Values.secret.externalSecret.destination.credentials.keyIdProperty }}
|
property: {{ .Values.secret.externalSecret.destination.credentials.keyIdProperty }}
|
||||||
- secretKey: {{ include "secret.envSecretKey" . }}
|
- secretKey: {{ include "secretRclone.envSecretKey" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.destination.credentials.path }}
|
key: {{ .Values.secret.externalSecret.destination.credentials.path }}
|
||||||
property: {{ .Values.secret.externalSecret.destination.credentials.keyIdProperty }}
|
property: {{ .Values.secret.externalSecret.destination.credentials.secretKeyProperty }}
|
||||||
- secretKey: {{ include "secret.envRegion" . }}
|
- secretKey: {{ include "secretRclone.envRegion" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.destination.credentials.path }}
|
key: {{ .Values.secret.externalSecret.destination.credentials.path }}
|
||||||
property: {{ .Values.secret.externalSecret.destination.credentials.keyIdProperty }}
|
property: {{ .Values.secret.externalSecret.destination.credentials.regionProperty }}
|
||||||
- secretKey: {{ include "secret.envDestEndpoint" . }}
|
- secretKey: {{ include "secretRclone.envDestEndpoint" . }}
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: {{ .Values.secret.externalSecret.destination.config.path }}
|
key: {{ .Values.secret.externalSecret.destination.config.path }}
|
||||||
property: {{ .Values.secret.externalSecret.destination.config.endpointProperty }}
|
property: {{ .Values.secret.externalSecret.destination.config.endpointProperty }}
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ additionalLabels: {}
|
|||||||
# -- Default image
|
# -- Default image
|
||||||
image:
|
image:
|
||||||
repository: rclone/rclone
|
repository: rclone/rclone
|
||||||
tag: 1.73.5@sha256:1619a625f845e169c34b952cf40c483c0392965b821c5155cde8cbfd35254a96
|
tag: 1.74.0@sha256:d2e0e88359d0b2e67cfcd2c43d5405185eb8adfc207079df27c42da82c5207bc
|
||||||
pullPolicy: IfNotPresent
|
pullPolicy: IfNotPresent
|
||||||
|
|
||||||
# -- CronJob configuration
|
# -- CronJob configuration
|
||||||
@@ -38,6 +38,8 @@ rclone:
|
|||||||
prune:
|
prune:
|
||||||
enabled: false
|
enabled: false
|
||||||
ageToPrune: 90d
|
ageToPrune: 90d
|
||||||
|
include: ""
|
||||||
|
exclude: ""
|
||||||
|
|
||||||
# -- Secret configuration
|
# -- Secret configuration
|
||||||
secret:
|
secret:
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
apiVersion: v2
|
apiVersion: v2
|
||||||
name: valkey
|
name: valkey
|
||||||
version: 0.6.1
|
version: 0.7.0
|
||||||
description: Valkey chart with preconfigured settings
|
description: Valkey chart with preconfigured settings
|
||||||
keywords:
|
keywords:
|
||||||
- valkey
|
- valkey
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# valkey
|
# valkey
|
||||||
|
|
||||||
 
|
 
|
||||||
|
|
||||||
Valkey chart with preconfigured settings
|
Valkey chart with preconfigured settings
|
||||||
|
|
||||||
@@ -39,7 +39,7 @@ Valkey chart with preconfigured settings
|
|||||||
| valkey.metrics.enabled | bool | `true` | |
|
| valkey.metrics.enabled | bool | `true` | |
|
||||||
| valkey.metrics.exporter.image.registry | string | `"ghcr.io"` | |
|
| valkey.metrics.exporter.image.registry | string | `"ghcr.io"` | |
|
||||||
| valkey.metrics.exporter.image.repository | string | `"oliver006/redis_exporter"` | |
|
| valkey.metrics.exporter.image.repository | string | `"oliver006/redis_exporter"` | |
|
||||||
| valkey.metrics.exporter.image.tag | string | `"v1.82.0@sha256:6a97d4dd743b533e1f950c677b87d880e44df363c61af3f406fc9e53ed65ee03"` | |
|
| valkey.metrics.exporter.image.tag | string | `"v1.83.0@sha256:e8c209894d4c0cc55b1259ddd47e0b769ad1ff864b356736ee885462a3b0e48c"` | |
|
||||||
| valkey.metrics.exporter.resources.requests.cpu | string | `"1m"` | |
|
| valkey.metrics.exporter.resources.requests.cpu | string | `"1m"` | |
|
||||||
| valkey.metrics.exporter.resources.requests.memory | string | `"10M"` | |
|
| valkey.metrics.exporter.resources.requests.memory | string | `"10M"` | |
|
||||||
| valkey.metrics.podMonitor.enabled | bool | `true` | |
|
| valkey.metrics.podMonitor.enabled | bool | `true` | |
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ valkey:
|
|||||||
image:
|
image:
|
||||||
registry: ghcr.io
|
registry: ghcr.io
|
||||||
repository: oliver006/redis_exporter
|
repository: oliver006/redis_exporter
|
||||||
tag: v1.82.0@sha256:6a97d4dd743b533e1f950c677b87d880e44df363c61af3f406fc9e53ed65ee03
|
tag: v1.83.0@sha256:e8c209894d4c0cc55b1259ddd47e0b769ad1ff864b356736ee885462a3b0e48c
|
||||||
resources:
|
resources:
|
||||||
requests:
|
requests:
|
||||||
cpu: 1m
|
cpu: 1m
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
apiVersion: v2
|
apiVersion: v2
|
||||||
name: volsync-target
|
name: volsync-target
|
||||||
version: 1.0.0
|
version: 1.1.1
|
||||||
description: Volsync Replication set to target specific PVC with preconfigured settings
|
description: Volsync Replication set to target specific PVC with preconfigured settings
|
||||||
keywords:
|
keywords:
|
||||||
- volsync-target
|
- volsync-target
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# volsync-target
|
# volsync-target
|
||||||
|
|
||||||
 
|
 
|
||||||
|
|
||||||
Volsync Replication set to target specific PVC with preconfigured settings
|
Volsync Replication set to target specific PVC with preconfigured settings
|
||||||
|
|
||||||
@@ -33,6 +33,7 @@ Volsync Replication set to target specific PVC with preconfigured settings
|
|||||||
| moverSecurityContext | object | `{}` | Glocal security context for restic mover |
|
| moverSecurityContext | object | `{}` | Glocal security context for restic mover |
|
||||||
| nameOverride | string | `""` | Default pattern follows <pvcTarget>-backup |
|
| nameOverride | string | `""` | Default pattern follows <pvcTarget>-backup |
|
||||||
| namespaceOverride | string | `""` | Override the namespace of the chart |
|
| namespaceOverride | string | `""` | Override the namespace of the chart |
|
||||||
|
| prometheusRule | object | `{"enabled":true}` | Prometheus Rule |
|
||||||
| pvcTarget | string | `"data"` | Name of the PVC target |
|
| pvcTarget | string | `"data"` | Name of the PVC target |
|
||||||
| remote | object | `{"enabled":false,"externalSecret":{"bucketPath":"/garage/config","credentialPath":"/garage/home-infra/volsync-backups"},"restic":{"cacheCapacity":"1Gi","copyMethod":"Snapshot","pruneIntervalDays":7,"repository":"","retain":{"daily":7,"hourly":0,"monthly":3,"weekly":4,"yearly":1},"storageClassName":"ceph-block","volumeSnapshotClassName":"ceph-blockpool-snapshot"},"schedule":"0 10 * * *"}` | Remote backup configuration |
|
| remote | object | `{"enabled":false,"externalSecret":{"bucketPath":"/garage/config","credentialPath":"/garage/home-infra/volsync-backups"},"restic":{"cacheCapacity":"1Gi","copyMethod":"Snapshot","pruneIntervalDays":7,"repository":"","retain":{"daily":7,"hourly":0,"monthly":3,"weekly":4,"yearly":1},"storageClassName":"ceph-block","volumeSnapshotClassName":"ceph-blockpool-snapshot"},"schedule":"0 10 * * *"}` | Remote backup configuration |
|
||||||
| remote.externalSecret | object | `{"bucketPath":"/garage/config","credentialPath":"/garage/home-infra/volsync-backups"}` | External Secret configuration |
|
| remote.externalSecret | object | `{"bucketPath":"/garage/config","credentialPath":"/garage/home-infra/volsync-backups"}` | External Secret configuration |
|
||||||
|
|||||||
32
charts/volsync-target/templates/prometheus-rule.yaml
Normal file
32
charts/volsync-target/templates/prometheus-rule.yaml
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
{{- if .Values.prometheusRule.enabled }}
|
||||||
|
---
|
||||||
|
apiVersion: monitoring.coreos.com/v1
|
||||||
|
kind: PrometheusRule
|
||||||
|
metadata:
|
||||||
|
name: {{ include "volsync.name" . }}-source-local
|
||||||
|
namespace: {{ include "volsync.namespace" . }}
|
||||||
|
labels:
|
||||||
|
{{- include "volsync.labels" . | nindent 4 }}
|
||||||
|
app.kubernetes.io/name: {{ include "volsync.name" . }}-source-local
|
||||||
|
{{- with .Values.additionalLabels }}
|
||||||
|
{{- toYaml . | nindent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
spec:
|
||||||
|
groups:
|
||||||
|
- name: volsync.alerts
|
||||||
|
rules:
|
||||||
|
- alert: VolSyncBackupPodFailed
|
||||||
|
expr: |
|
||||||
|
(kube_pod_container_status_last_terminated_exitcode > 0)
|
||||||
|
* on(pod, namespace) group_left(owner_name)
|
||||||
|
kube_pod_owner{owner_kind="Job", owner_name=~"volsync-.*"}
|
||||||
|
for: 1m
|
||||||
|
labels:
|
||||||
|
severity: critical
|
||||||
|
annotations:
|
||||||
|
summary: "VolSync Backup Pod failed in {{ `{{ $labels.namespace }}` }}"
|
||||||
|
description: |
|
||||||
|
A pod for the VolSync backup of PVC '{{ .Values.pvcTarget }}' failed with exit code {{ `{{ $value }}` }}.
|
||||||
|
Job: {{ `{{ $labels.owner_name }}` }}
|
||||||
|
Namespace: {{ `{{ $labels.namespace }}` }}
|
||||||
|
{{- end }}
|
||||||
@@ -7,7 +7,7 @@ metadata:
|
|||||||
namespace: {{ include "volsync.namespace" . }}
|
namespace: {{ include "volsync.namespace" . }}
|
||||||
labels:
|
labels:
|
||||||
{{- include "volsync.labels" . | nindent 4 }}
|
{{- include "volsync.labels" . | nindent 4 }}
|
||||||
app.kubernetes.io/name: {{ include "volsync.name" . }}
|
app.kubernetes.io/name: {{ include "volsync.name" . }}-source-local
|
||||||
{{- with .Values.additionalLabels }}
|
{{- with .Values.additionalLabels }}
|
||||||
{{- toYaml . | nindent 4 }}
|
{{- toYaml . | nindent 4 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|||||||
@@ -16,6 +16,10 @@ pvcTarget: "data"
|
|||||||
# -- Glocal security context for restic mover
|
# -- Glocal security context for restic mover
|
||||||
moverSecurityContext: {}
|
moverSecurityContext: {}
|
||||||
|
|
||||||
|
# -- Prometheus Rule
|
||||||
|
prometheusRule:
|
||||||
|
enabled: true
|
||||||
|
|
||||||
# -- Use external secrets
|
# -- Use external secrets
|
||||||
externalSecrets:
|
externalSecrets:
|
||||||
enabled: true
|
enabled: true
|
||||||
|
|||||||
Reference in New Issue
Block a user