4 topologySpreadConstraints: []
6 # topologyKey: topology.kubernetes.io/zone
7 # whenUnsatisfiable: ScheduleAnyway
11 # topologyKey: kubernetes.io/hostname
12 # whenUnsatisfiable: DoNotSchedule
16 # -- Global hostAliases to be applied to all deployments
18 # -- Global pod labels to be applied to all deployments
20 # -- Global pod annotations to be applied to all deployments
22 # -- Global imagePullSecrets to be applied to all deployments
24 # -- Global image repository to be applied to all deployments
28 # -- Manages the securityContext properties to make them compatible with OpenShift.
30 # auto - Apply configurations if it is detected that OpenShift is the target platform.
31 # force - Always apply configurations.
32 # disabled - No modification applied.
33 adaptSecurityContext: auto
38# -- Specifies the amount of historic ReplicaSets k8s should keep (see https://kubernetes.io/docs/concepts/workloads/controllers/deployment/#clean-up-policy)
39revisionHistoryLimit: 10
41 repository: cgr.dev/chainguard-private/external-secrets
42 pullPolicy: IfNotPresent
43 # -- The image tag to use. The default is the chart appVersion.
44 tag: latest@sha256:1872bc5bfb723e6eecd769130272533a9cc70dfd35a288d5ce3d82f766b4a407
45 # -- The flavour of tag you want to use
46 # There are different image flavours available, like distroless and ubi.
47 # Please see GitHub release notes for image tags for these flavors.
48 # By default, the distroless image is used.
50# -- If set, install and upgrade CRDs through helm chart.
53 # -- If true, create CRDs for Cluster External Secret. If set to false you must also set processClusterExternalSecret: false.
54 createClusterExternalSecret: true
55 # -- If true, create CRDs for Cluster Secret Store. If set to false you must also set processClusterStore: false.
56 createClusterSecretStore: true
57 # -- If true, create CRDs for Secret Store. If set to false you must also set processSecretStore: false.
58 createSecretStore: true
59 # -- If true, create CRDs for Cluster Generator. If set to false you must also set processClusterGenerator: false.
60 createClusterGenerator: true
61 # -- If true, create CRDs for Cluster Push Secret. If set to false you must also set processClusterPushSecret: false.
62 createClusterPushSecret: true
63 # -- If true, create CRDs for Push Secret. If set to false you must also set processPushSecret: false.
64 createPushSecret: true
67 # -- Conversion is disabled by default as we stopped supporting v1alpha1.
69 # -- If true, enable v1beta1 API version serving for ExternalSecret, ClusterExternalSecret, SecretStore, and ClusterSecretStore CRDs.
70 # v1beta1 is deprecated. Only enable this for backward compatibility if you have existing v1beta1 resources.
71 # Warning: This flag will be removed on 2026.05.01.
72 unsafeServeV1Beta1: false
77# -- Additional labels added to all helm chart resources.
79# -- If true, external-secrets will perform leader election between instances to ensure no more
80# than one instance of external-secrets operates at a time.
82# -- ID of the lease object used for leader election.
83# Leave empty to use the default ('external-secrets-controller').
84# Set to a unique value when running multiple independent ESO deployments in the same namespace.
85# @default -- "external-secrets-controller"
87# -- If set external secrets will filter matching
88# Secret Stores with the appropriate controller values.
90# -- If true external secrets will use recommended kubernetes
91# annotations as prometheus metric labels.
92extendedMetricLabels: false
93# -- If set external secrets are only reconciled in the
96# -- If true, create scoped RBAC roles and implicitly disable cluster-scoped
97# controllers. Scoped to scopedNamespace if set, otherwise to .Release.Namespace.
99# -- If true the OpenShift finalizer permissions will be added to RBAC
100openshiftFinalizers: true
101# -- If true the system:auth-delegator ClusterRole will be added to RBAC
102systemAuthDelegator: false
103# -- if true, the operator will process cluster external secret. Else, it will ignore them.
104# When enabled, this adds update/patch permissions on namespaces to handle finalizers for proper
105# cleanup during namespace deletion, preventing race conditions with ExternalSecrets.
106processClusterExternalSecret: true
107# -- if true, the operator will process cluster push secret. Else, it will ignore them.
108processClusterPushSecret: true
109# -- if true, the operator will process cluster store. Else, it will ignore them.
110processClusterStore: true
111# -- if true, the operator will process secret store. Else, it will ignore them.
112processSecretStore: true
113# -- if true, the operator will process cluster generator. Else, it will ignore them.
114processClusterGenerator: true
115# -- if true, the operator will process push secret. Else, it will ignore them.
116processPushSecret: true
117# -- Enable support for generic targets (ConfigMaps, Custom Resources).
118# Warning: Using generic target. Make sure access policies and encryption are properly configured.
119# When enabled, this grants the controller permissions to create/update/delete
120# ConfigMaps and optionally other resource types specified in generic.resources.
122 # -- Enable generic target support
124 # -- List of additional resource types to grant permissions for.
125 # Each entry should specify apiGroup, resources, and verbs.
128 # - apiGroup: "argoproj.io"
129 # resources: ["applications"]
130 # verbs: ["get", "list", "watch", "create", "update", "patch", "delete"]
132# -- Specifies whether an external secret operator deployment be created.
134# -- if true, HTTP2 will be enabled for the services created by all controllers, curently metrics and webhook.
136# -- Vault token cache configuration
138 # -- Enable Vault token cache. External secrets will reuse the Vault token without creating a new one on each request.
139 enableTokenCache: false
140 # -- Maximum size of Vault token cache. Only used if enableTokenCache is true.
141 tokenCacheSize: 262144
142# -- Specifies the number of concurrent ExternalSecret Reconciles external-secret executes at
145# -- Specifies Log Params to the External Secrets Operator
150 # -- Set the ip family policy to configure dual-stack see [Configure dual-stack](https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services)
152 # -- Sets the families that should be supported and the order in which they should be applied to ClusterIP as well. Can be IPv4 and/or IPv6.
155 # -- Specifies whether a service account should be created.
157 # -- Automounts the service account token in all containers of the pod
159 # -- Annotations to add to the service account.
161 # -- Extra Labels to add to the service account.
163 # -- The name of the service account to use.
164 # If not set and create is true, a name is generated using the fullname template.
167 # -- Specifies whether role and rolebinding resources should be created.
169 # -- Specifies whether the serviceaccounts/token create permission is included in the controller RBAC.
170 # When set to false, users must create per-ServiceAccount Role/RoleBinding with resourceNames constraint
171 # to grant ESO token creation for specific ServiceAccounts referenced in SecretStore specs.
172 serviceAccountTokenCreate: true
174 # -- Specifies whether a clusterrole to give servicebindings read access should be created.
176 # -- Specifies whether permissions are aggregated to the view ClusterRole
177 aggregateToView: true
178 # -- Specifies whether permissions are aggregated to the edit ClusterRole
179 aggregateToEdit: true
180## -- Extra environment variables to add to container.
182## -- Map of extra arguments to pass to container.
184## -- Extra volumes to pass to pod.
186## -- Extra Kubernetes objects to deploy with the helm chart
188## -- Extra volumes to mount to the container.
190## -- Extra init containers to add to the pod.
191extraInitContainers: []
192## -- Extra containers to add to the pod.
194# -- Annotations to add to Deployment
195deploymentAnnotations: {}
196# -- Set deployment strategy
198# -- Annotations to add to Pod
205 allowPrivilegeEscalation: false
210 readOnlyRootFilesystem: true
221 # -- Specifies whether to create a ServiceMonitor resource for collecting Prometheus metrics
223 # -- How should we react to missing CRD "`monitoring.coreos.com/v1/ServiceMonitor`"
226 # - `skipIfMissing`: Only render ServiceMonitor resources if CRD is present, skip if missing.
227 # - `failIfMissing`: Fail Helm install if CRD is not present.
228 # - `alwaysRender` : Always render ServiceMonitor resources, do not check for CRD.
236 renderMode: skipIfMissing # @schema enum: [skipIfMissing, failIfMissing, alwaysRender]
237 # -- namespace where you want to install ServiceMonitors
239 # -- Additional labels
241 # -- Interval to scrape metrics
243 # -- Timeout if metrics can't be retrieved in given time interval
245 # -- Let prometheus add an exported_ prefix to conflicting labels
247 # -- Metric relabel configs to apply to samples before ingestion. [Metric Relabeling](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#metric_relabel_configs)
248 metricRelabelings: []
253 # - exported_namespace
254 # targetLabel: namespace
256 # -- Relabel configs to apply to samples before ingestion. [Relabeling](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#relabel_config)
258 # - sourceLabels: [__meta_kubernetes_pod_node_name]
261 # targetLabel: nodename
268 # -- Enable Kubernetes RBAC-based authentication for metrics endpoint. Requires metrics.listen.secure to be true. Default value is false.
272 # -- if those are not set or invalid, self-signed certs will be generated
273 # -- TLS cert directory path
275 # -- TLS cert file path
276 certFile: /etc/tls/tls.crt
277 # -- TLS key file path
278 keyFile: /etc/tls/tls.key
280 # -- Enable if you use another monitoring tool than Prometheus to scrape the metrics
282 # -- Metrics service port to scrape
284 # -- Additional service annotations
287 # -- If true creates a Grafana dashboard.
289 # -- Label that ConfigMaps should have to be loaded as dashboards.
290 sidecarLabel: "grafana_dashboard"
291 # -- Label value that ConfigMaps should have to be loaded as dashboards.
292 sidecarLabelValue: "1"
293 # -- Annotations that ConfigMaps can have to get configured in Grafana,
294 # See: sidecar.dashboards.folderAnnotation for specifying the dashboard folder.
295 # https://github.com/grafana/helm-charts/tree/main/charts/grafana
297 # -- Extra labels to add to the Grafana dashboard ConfigMap.
300 # -- Enabled determines if the liveness probe should be used or not. By default it's disabled.
302 # -- The body of the liveness probe settings.
304 # -- Bind address for the health server used by both liveness and readiness probes (--live-addr flag).
306 # -- Port for the health server used by both liveness and readiness probes (--live-addr flag).
308 # -- Specify the maximum amount of time to wait for a probe to respond before considering it fails.
310 # -- Number of consecutive probe failures that should occur before considering the probe as failed.
312 # -- Period in seconds for K8s to start performing probes.
314 # -- Number of successful probes to mark probe successful.
316 # -- Delay in seconds for the container to start before performing the initial probe.
317 initialDelaySeconds: 10
318 # -- Handler for liveness probe.
320 # -- Set this value to 'live' (for named port) or an an integer for liveness probes.
321 # @schema type: [string, integer]
323 # -- Path for liveness probe.
326 # -- Determines whether the readiness probe is enabled. Disabled by default. Enabling this will auto-start the health server (--live-addr) even if livenessProbe is disabled. Health server address/port are configured via livenessProbe.spec.address and livenessProbe.spec.port.
328 # -- The body of the readiness probe settings (standard Kubernetes probe spec).
330 # -- Specify the maximum amount of time to wait for a probe to respond before considering it fails.
332 # -- Number of consecutive probe failures that should occur before considering the probe as failed.
334 # -- Period in seconds for K8s to start performing probes.
336 # -- Number of successful probes to mark probe successful.
338 # -- Delay in seconds for the container to start before performing the initial probe.
339 initialDelaySeconds: 10
340 # -- Handler for readiness probe.
342 # -- Set this value to 'live' (for named port) or an integer for readiness probes.
343 # @schema type: [string, integer]
345 # -- Path for readiness probe.
349topologySpreadConstraints: []
351# -- Pod priority class name.
353# -- Pod disruption budget - for more details see https://kubernetes.io/docs/concepts/workloads/pods/disruptions/
356 minAvailable: 1 # @schema type:[integer, string]
358 # maxUnavailable: "50%"
359# -- Run the controller on the host network
361# -- (bool) Specifies if controller pod should use hostUsers or not. If hostNetwork is true, hostUsers should be too. Only available in Kubernetes ≥ 1.33.
362# @schema type: [boolean, null]
365 # -- Annotations to place on validating webhook configuration.
367 # -- Specifies whether a webhook deployment be created. If set to false, crds.conversion.enabled should also be set to false otherwise the kubeapi will be hammered because the conversion is looking for a webhook endpoint.
369 # -- Specifies the time to check if the cert is valid
370 certCheckInterval: "5m"
371 # -- Specifies the lookaheadInterval for certificate validity
372 lookaheadInterval: ""
374 # -- Specifies Log Params to the Webhook
378 # -- Specifies the amount of historic ReplicaSets k8s should keep (see https://kubernetes.io/docs/concepts/workloads/controllers/deployment/#clean-up-policy)
379 revisionHistoryLimit: 10
381 # -- Specifies whether validating webhooks should be created with failurePolicy: Fail or Ignore
383 # -- Specifies if webhook pod should use hostNetwork or not.
385 # -- (bool) Specifies if webhook pod should use hostUsers or not. If hostNetwork is true, hostUsers should be too. Only available in Kubernetes ≥ 1.33.
386 # @schema type: [boolean, null]
389 repository: cgr.dev/chainguard-private/external-secrets
390 pullPolicy: IfNotPresent
391 # -- The image tag to use. The default is the chart appVersion.
392 tag: latest@sha256:1872bc5bfb723e6eecd769130272533a9cc70dfd35a288d5ce3d82f766b4a407
393 # -- The flavour of tag you want to use
396 # -- The port the webhook will listen to
399 # -- Specifies whether a service account should be created.
401 # -- Automounts the service account token in all containers of the pod
403 # -- Annotations to add to the service account.
405 # -- Extra Labels to add to the service account.
407 # -- The name of the service account to use.
408 # If not set and create is true, a name is generated using the fullname template.
411 # -- Specifies `hostAliases` to webhook deployment
414 # -- Enabling cert-manager support will disable the built in secret and
415 # switch to using cert-manager (installed separately) to automatically issue
416 # and renew the webhook certificate. This chart does not install
417 # cert-manager for you, See https://cert-manager.io/docs/
419 # -- Automatically add the cert-manager.io/inject-ca-from annotation to the
420 # webhooks and CRDs. As long as you have the cert-manager CA Injector
421 # enabled, this will automatically setup your webhook's CA to the one used
422 # by cert-manager. See https://cert-manager.io/docs/concepts/ca-injector
423 addInjectorAnnotations: true
425 # -- Create a certificate resource within this chart. See
426 # https://cert-manager.io/docs/usage/certificate/
428 # -- For the Certificate created by this chart, setup the issuer. See
429 # https://cert-manager.io/docs/reference/api-docs/#cert-manager.io/v1.IssuerSpec
431 group: cert-manager.io
434 # -- Set the requested duration (i.e. lifetime) of the Certificate. See
435 # https://cert-manager.io/docs/reference/api-docs/#cert-manager.io/v1.CertificateSpec
436 # One year by default.
437 duration: "8760h0m0s"
438 # -- Set the revisionHistoryLimit on the Certificate. See
439 # https://cert-manager.io/docs/reference/api-docs/#cert-manager.io/v1.CertificateSpec
440 # Defaults to 0 (ignored).
441 revisionHistoryLimit: 0
442 # -- How long before the currently issued certificate’s expiry
443 # cert-manager should renew the certificate. See
444 # https://cert-manager.io/docs/reference/api-docs/#cert-manager.io/v1.CertificateSpec
445 # Note that renewBefore should be greater than .webhook.lookaheadInterval
446 # since the webhook will check this far in advance that the certificate is
449 # -- Specific settings on the privateKey and its generation
451 # rotationPolicy: Always
454 # -- Specific settings on the signatureAlgorithm used on the cert.
455 # signatureAlgorithm is only valid for cert-manager v1.18.0+
456 signatureAlgorithm: ""
457 # -- Add extra annotations to the Certificate resource.
460 topologySpreadConstraints: []
462 # -- Set deployment strategy
464 # -- Pod priority class name.
465 priorityClassName: ""
466 # -- Pod disruption budget - for more details see https://kubernetes.io/docs/concepts/workloads/pods/disruptions/
469 minAvailable: 1 # @schema type:[integer, string]
471 # maxUnavailable: "50%"
476 # -- Enable Kubernetes RBAC-based authentication for webhook's metrics endpoint. Requires webhook.metrics.listen.secure to be true. Default value is false.
480 # -- if those are not set or invalid, self-signed certs will be generated
481 # -- TLS cert directory path
483 # -- TLS cert file path
484 certFile: /etc/tls/tls.crt
485 # -- TLS key file path
486 keyFile: /etc/tls/tls.key
488 # -- Enable if you use another monitoring tool than Prometheus to scrape the metrics
490 # -- Metrics service port to scrape
492 # -- Additional service annotations
496 # -- Set this value to 'live' (for named port) or an integer for liveness probes.
497 # @schema type: [string, integer]
503 initialDelaySeconds: 10
507 # -- Set this value to 'ready' (for named port) or an integer for readiness probes.
508 # @schema type: [string, integer]
514 initialDelaySeconds: 20
515 ## -- Extra environment variables to add to container.
517 ## -- Map of extra arguments to pass to container.
519 ## -- Extra init containers to add to the pod.
520 extraInitContainers: []
521 ## -- Extra volumes to pass to pod.
523 ## -- Extra volumes to mount to the container.
524 extraVolumeMounts: []
525 # -- Annotations to add to Secret
526 secretAnnotations: {}
527 # -- Annotations to add to Deployment
528 deploymentAnnotations: {}
529 # -- Annotations to add to Pod
536 allowPrivilegeEscalation: false
541 readOnlyRootFilesystem: true
551 # -- Manage the service through which the webhook is reached.
553 # -- Whether the service object should be enabled or not (it is expected to exist).
555 # -- Custom annotations for the webhook service.
557 # -- Custom labels for the webhook service.
559 # -- The service type of the webhook service.
561 # -- If the webhook service type is LoadBalancer, you can assign a specific load balancer IP here.
562 # Check the documentation of your load balancer provider to see if/how this should be used.
565 # -- Specifies whether a certificate controller deployment be created.
567 requeueInterval: "5m"
569 # -- Specifies Log Params to the Certificate Controller
573 # -- Specifies the amount of historic ReplicaSets k8s should keep (see https://kubernetes.io/docs/concepts/workloads/controllers/deployment/#clean-up-policy)
574 revisionHistoryLimit: 10
576 repository: cgr.dev/chainguard-private/external-secrets
577 pullPolicy: IfNotPresent
578 tag: latest@sha256:1872bc5bfb723e6eecd769130272533a9cc70dfd35a288d5ce3d82f766b4a407
582 # -- Specifies whether role and rolebinding resources should be created.
585 # -- Specifies whether a service account should be created.
587 # -- Automounts the service account token in all containers of the pod
589 # -- Annotations to add to the service account.
591 # -- Extra Labels to add to the service account.
593 # -- The name of the service account to use.
594 # If not set and create is true, a name is generated using the fullname template.
597 # -- Specifies `hostAliases` to cert-controller deployment
600 topologySpreadConstraints: []
602 # -- Set deployment strategy
604 # -- Run the certController on the host network
606 # -- (bool) Specifies if certController pod should use hostUsers or not. If hostNetwork is true, hostUsers should be too. Only available in Kubernetes ≥ 1.33.
607 # @schema type: [boolean, null]
609 # -- Pod priority class name.
610 priorityClassName: ""
611 # -- Pod disruption budget - for more details see https://kubernetes.io/docs/concepts/workloads/pods/disruptions/
614 minAvailable: 1 # @schema type:[integer, string]
616 # maxUnavailable: "50%"
621 # -- Enable Kubernetes RBAC-based authentication for certController's metrics endpoint. Requires certController.metrics.listen.secure to be true. Default value is false.
625 # -- if those are not set or invalid, self-signed certs will be generated
626 # -- TLS cert directory path
628 # -- TLS cert file path
629 certFile: /etc/tls/tls.crt
630 # -- TLS key file path
631 keyFile: /etc/tls/tls.key
633 # -- Enable if you use another monitoring tool than Prometheus to scrape the metrics
635 # -- Metrics service port to scrape
637 # -- Additional service annotations
641 # -- Set this value to 'live' (for named port) or an integer for liveness probes.
642 # @schema type: [string, integer]
648 initialDelaySeconds: 10
652 # -- Set this value to 'ready' (for named port) or an integer for readiness probes.
653 # @schema type: [string, integer]
659 initialDelaySeconds: 20
661 # -- Enabled determines if the startup probe should be used or not. By default it's enabled
663 # -- whether to use the readiness probe port for startup probe.
664 useReadinessProbePort: true
665 # -- Port for startup probe.
667 ## -- Extra environment variables to add to container.
669 ## -- Map of extra arguments to pass to container.
671 ## -- Extra init containers to add to the pod.
672 extraInitContainers: []
673 ## -- Extra volumes to pass to pod.
675 ## -- Extra volumes to mount to the container.
676 extraVolumeMounts: []
677 # -- Annotations to add to Deployment
678 deploymentAnnotations: {}
679 # -- Annotations to add to Pod
686 allowPrivilegeEscalation: false
691 readOnlyRootFilesystem: true
700# -- Specifies `dnsPolicy` to deployment
701dnsPolicy: ClusterFirst
702# -- Specifies `dnsOptions` to deployment
704# -- Specifies `hostAliases` to deployment
706# -- Any extra pod spec on the deployment