Compare commits
3 Commits
rclone-buc
...
rclone-buc
| Author | SHA1 | Date | |
|---|---|---|---|
| 67d0dbcf71 | |||
| f901d1574b | |||
| 73779ad42b |
@@ -1,6 +1,6 @@
|
|||||||
apiVersion: v2
|
apiVersion: v2
|
||||||
name: rclone-bucket
|
name: rclone-bucket
|
||||||
version: 0.3.0
|
version: 0.4.2
|
||||||
description: Rclone CronJob to replicate buckets
|
description: Rclone CronJob to replicate buckets
|
||||||
keywords:
|
keywords:
|
||||||
- rclone-bucket
|
- rclone-bucket
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# rclone-bucket
|
# rclone-bucket
|
||||||
|
|
||||||
 
|
 
|
||||||
|
|
||||||
Rclone CronJob to replicate buckets
|
Rclone CronJob to replicate buckets
|
||||||
|
|
||||||
@@ -29,7 +29,7 @@ Rclone CronJob to replicate buckets
|
|||||||
| 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.73.5@sha256:1619a625f845e169c34b952cf40c483c0392965b821c5155cde8cbfd35254a96"}` | 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 |
|
||||||
|
|||||||
@@ -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 }}
|
||||||
|
|||||||
@@ -26,6 +26,14 @@ controllers:
|
|||||||
- --min-age
|
- --min-age
|
||||||
- {{ .Values.prune.ageToPrune }}
|
- {{ .Values.prune.ageToPrune }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
{{- if .Values.prune.include }}
|
||||||
|
- --include
|
||||||
|
- {{ .Values.prune.include }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.prune.exclude }}
|
||||||
|
- --exclude
|
||||||
|
- {{ .Values.prune.exclude }}
|
||||||
|
{{- end }}
|
||||||
- --verbose
|
- --verbose
|
||||||
env:
|
env:
|
||||||
- name: RCLONE_S3_PROVIDER
|
- name: RCLONE_S3_PROVIDER
|
||||||
@@ -40,22 +48,22 @@ controllers:
|
|||||||
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_S3_FORCE_PATH_STYLE
|
||||||
value: {{ .Values.rclone.source.forcePathStyle }}
|
value: {{ .Values.rclone.source.forcePathStyle }}
|
||||||
- name: RCLONE_CONFIG_DEST_TYPE
|
- name: RCLONE_CONFIG_DEST_TYPE
|
||||||
@@ -68,22 +76,22 @@ controllers:
|
|||||||
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_SRC_DEST_FORCE_PATH_STYLE
|
||||||
value: {{ .Values.rclone.destination.forcePathStyle }}
|
value: {{ .Values.rclone.destination.forcePathStyle }}
|
||||||
{{- if .Values.prune.enabled }}
|
{{- if .Values.prune.enabled }}
|
||||||
@@ -109,22 +117,22 @@ controllers:
|
|||||||
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_SRC_S3_FORCE_PATH_STYLE
|
||||||
value: {{ .Values.rclone.destination.forcePathStyle }}
|
value: {{ .Values.rclone.destination.forcePathStyle }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|||||||
@@ -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 }}
|
||||||
|
|||||||
@@ -38,6 +38,8 @@ rclone:
|
|||||||
prune:
|
prune:
|
||||||
enabled: false
|
enabled: false
|
||||||
ageToPrune: 90d
|
ageToPrune: 90d
|
||||||
|
include: ""
|
||||||
|
exclude: ""
|
||||||
|
|
||||||
# -- Secret configuration
|
# -- Secret configuration
|
||||||
secret:
|
secret:
|
||||||
|
|||||||
Reference in New Issue
Block a user