1# Default values for external-dns.
2# This is a YAML-formatted file.
3# Declare variables to be passed into your templates.
6 # -- Global image pull secrets.
7 imagePullSecrets: [] # @schema item: object
8image: # @schema additionalProperties: false
9 # -- Image repository for the `external-dns` container.
10 repository: cgr.dev/chainguard-private/external-dns-fips
11 # -- Image tag for the `external-dns` container, this will default to `.Chart.AppVersion` if not set.
12 tag: latest@sha256:cb861cf01d5be75026d3b0cb9514743cc1793554993775a7335845d9b0ef657b # @schema type:[string, null]
13 # -- Image pull policy for the `external-dns` container.
14 pullPolicy: IfNotPresent # @schema enum:[IfNotPresent, Always]
15# -- Image pull secrets.
16imagePullSecrets: [] # @schema item: object
17# -- (string) Override the name of the chart.
18nameOverride: # @schema type:[string, null]; default: null
19# -- (string) Override the full name of the chart.
20fullnameOverride: # @schema type:[string, null]; default: null
21# -- (string) Override the namespace that chart resources are rendered into.
22# Defaults to the release namespace. Useful when installing the chart as a
23# subchart that should live in its own namespace, separate from the umbrella
25namespaceOverride: # @schema type:[string, null]; default: null
26# -- Labels to add to all chart resources.
29 # -- If `true`, create a new `ServiceAccount`.
31 # -- Labels to add to the service account.
33 # -- Annotations to add to the service account. Templates are allowed in both the key and the value. Example: `example.com/annotation/{{ .Values.nameOverride }}: {{ .Values.nameOverride }}`
35 # -- (string) If this is set and `serviceAccount.create` is `true` this will be used for the created `ServiceAccount` name, if set and `serviceAccount.create` is `false` then this will define an existing `ServiceAccount` to use.
36 name: # @schema type:[string, null]; default: null
37 # -- Set this to `false` to [opt out of API credential automounting](https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/#opt-out-of-api-credential-automounting) for the `ServiceAccount`.
38 automountServiceAccountToken: true
40 # -- Service annotations.
42 # -- Service HTTP port.
43 port: 7979 # @schema minimum:0; default:7979
44 # -- Service IP families (e.g. IPv4 and/or IPv6).
45 ipFamilies: [] # @schema type: [array, null]; item: string; itemEnum: ["IPv4", "IPv6"]; minItems:0; maxItems:2; uniqueItems: true
48 # -- Service IP family policy.
49 ipFamilyPolicy: # @schema type: [string, null]; enum:[SingleStack, PreferDualStack, RequireDualStack, null]
50rbac: # @schema additionalProperties: true
51 # -- If `true`, create a `ClusterRole` & `ClusterRoleBinding` with access to the Kubernetes API.
53 # -- Additional rules to add to the `ClusterRole`.
54 additionalPermissions: []
55# -- Annotations to add to the `Deployment`.
56deploymentAnnotations: {}
57# -- Extra containers to add to the `Deployment`.
59# -- [Deployment Strategy](https://kubernetes.io/docs/concepts/workloads/controllers/deployment/#strategy).
60deploymentStrategy: # @schema additionalProperties: true
61 type: Recreate # @schema enum:[Recreate, RollingUpdate]; type:string; default: Recreate
62# -- (int) Specify the number of old `ReplicaSets` to retain to allow rollback of the `Deployment``.
63revisionHistoryLimit: # @schema type:[integer, null];minimum:0
64# -- Labels to add to the `Pod`.
66# -- Annotations to add to the `Pod`.
68# -- (bool) Set this to `false` to [opt out of API credential automounting](https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/#opt-out-of-api-credential-automounting) for the `Pod`.
69automountServiceAccountToken: true
70# -- If `true`, the `Pod` will have [process namespace sharing](https://kubernetes.io/docs/tasks/configure-pod-container/share-process-namespace/) enabled.
71shareProcessNamespace: false
72# -- [Pod security context](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.22/#podsecuritycontext-v1-core), this supports full customisation.
73# @default -- See _values.yaml_
79# -- (string) Priority class name for the `Pod`.
80priorityClassName: # @schema type:[string, null]; default: null
81# -- (int) Termination grace period for the `Pod` in seconds.
82terminationGracePeriodSeconds: # @schema type:[integer, null]
83# -- (string) [DNS policy](https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy) for the pod, if not set the default will be used.
84dnsPolicy: # @schema type:[string, null]; default: null
85# -- (object) [DNS config](https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-dns-config) for the pod, if not set the default will be used.
86dnsConfig: # @schema type:[object, null]; default: null
87# -- [Init containers](https://kubernetes.io/docs/concepts/workloads/pods/init-containers/) to add to the `Pod` definition.
89# -- [Security context](https://kubernetes.io/docs/tasks/configure-pod-container/security-context/#set-the-security-context-for-a-container) for the `external-dns` container.
90# @default -- See _values.yaml_
93 allowPrivilegeEscalation: false
94 readOnlyRootFilesystem: true
100# -- [Environment variables](https://kubernetes.io/docs/tasks/inject-data-application/define-environment-variable-container/) for the `external-dns` container.
102# -- [Liveness probe](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/) configuration for the `external-dns` container.
103# @default -- See _values.yaml_
108 initialDelaySeconds: 10
113# -- [Readiness probe](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/) configuration for the `external-dns` container.
114# @default -- See _values.yaml_
119 initialDelaySeconds: 5
124# -- Extra [volumes](https://kubernetes.io/docs/concepts/storage/volumes/) for the `Pod`.
126# -- Extra [volume mounts](https://kubernetes.io/docs/concepts/storage/volumes/) for the `external-dns` container.
128# -- [Resources](https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/) for the `external-dns` container.
130# -- Node labels to match for `Pod` [scheduling](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/).
132# -- Affinity settings for `Pod` [scheduling](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/). If an explicit label selector is not provided for pod affinity or pod anti-affinity one will be created from the pod selector labels.
134# -- Topology spread constraints for `Pod` [scheduling](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/). If an explicit label selector is not provided one will be created from the pod selector labels.
135topologySpreadConstraints: []
136# -- Node taints which will be tolerated for `Pod` [scheduling](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/).
139 # -- If `true`, create a `ServiceMonitor` resource to support the _Prometheus Operator_.
141 # -- Additional labels for the `ServiceMonitor`.
143 # -- Annotations to add to the `ServiceMonitor`.
145 # -- (string) If set create the `ServiceMonitor` in an alternate namespace.
146 namespace: # @schema type:[string, null]; default: null
147 # -- (string) If set override the _Prometheus_ default interval.
148 interval: # @schema type:[string, null]; default: null
149 # -- (string) If set override the _Prometheus_ default scrape timeout.
150 scrapeTimeout: # @schema type:[string, null]; default: null
151 # -- (string) If set overrides the _Prometheus_ default scheme.
152 scheme: # @schema type:[string, null]; default: null
153 # -- Configure the `ServiceMonitor` [TLS config](https://github.com/coreos/prometheus-operator/blob/master/Documentation/api.md#tlsconfig).
155 # -- (string) Provide a bearer token file for the `ServiceMonitor`.
156 bearerTokenFile: # @schema type:[string, null]; default: null
157 # -- [Relabel configs](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#relabel_config) to apply to samples before ingestion.
159 # -- [Metric relabel configs](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#metric_relabel_configs) to apply to samples before ingestion.
160 metricRelabelings: []
161 # -- Provide target labels for the `ServiceMonitor`.
164logLevel: info # @schema enum:[panic, debug, info, warning, error, fatal]; type:string; default: "info"
166logFormat: text # @schema enum:["text", "json"]; type:string; default: "text"
167# -- Interval for DNS updates.
169# -- If `true`, triggers run loop on create/update/delete events in addition of regular interval.
170triggerLoopOnEvent: false
171# -- if `true`, _ExternalDNS_ will run in a namespaced scope (`Role`` and `Rolebinding`` will be namespaced too).
173# -- if `true`, the Gateway API ListenerSet flag will be enabled.
174enableGatewayListenerSets: false
175# -- _Gateway API_ gateway namespace to watch.
176# When `namespaced=true`, setting this value avoids creating any cluster-scoped RBAC
177# (no ClusterRole/ClusterRoleBinding) for Gateway sources.
178gatewayNamespace: # @schema type:[string, null]; default: null
179# -- Source namespace to watch for Kubernetes resources other than Gateway API gateways.
180# Used only when `namespaced=true`. Defaults to Release.Namespace
181sourceNamespace: # @schema type:[string, null]; default: null
182# -- _Kubernetes_ resources to monitor for DNS entries.
186# -- How DNS records are synchronized between sources and providers; available values are `create-only`, `sync`, & `upsert-only`.
187policy: upsert-only # @schema enum:[create-only, sync, upsert-only]; type:string; default: "upsert-only"
188# -- Specify the registry for storing ownership and labels.
189# Valid values are `txt`, `aws-sd`, `dynamodb` & `noop`.
190registry: txt # @schema enum:[txt, aws-sd, dynamodb, noop]; default: "txt"
191# -- (string) Specify an identifier for this instance of _ExternalDNS_ when using a registry other than `noop`.
192txtOwnerId: # @schema type:[string, null]; default: null
193# -- (string) Specify a prefix for the domain names of TXT records created for the `txt` registry.
194# Mutually exclusive with `txtSuffix`.
195txtPrefix: # @schema type:[string, null]; default: null
196# -- (string) Specify a suffix for the domain names of TXT records created for the `txt` registry.
197# Mutually exclusive with `txtPrefix`.
198txtSuffix: # @schema type:[string, null]; default: null
199# -- Limit possible target zones by domain suffixes.
201# -- Intentionally exclude domains from being managed.
203# -- Filter resources queried for endpoints by label selector.
204labelFilter: # @schema type: [string,null]; default: null
205# -- Filter resources queried for endpoints by annotation selector.
206annotationFilter: # @schema type: [string,null]; default: null
207# -- Annotation prefix for external-dns annotations (useful for split horizon DNS with multiple instances).
208annotationPrefix: # @schema type: [string,null]; default: null
209# -- Record types to manage (default: A, AAAA, CNAME)
210managedRecordTypes: [] # @schema type: [array, null]; item: string; uniqueItems: true
211provider: # @schema type: [object, string]
212 # -- _ExternalDNS_ provider name; for the available providers and how to configure them see [README](https://github.com/kubernetes-sigs/external-dns/blob/master/charts/external-dns/README.md#providers).
216 # -- (string) Image repository for the `webhook` container.
217 repository: cgr.dev/chainguard-private/external-dns-fips # @schema type:[string, null]; default: null
218 # -- (string) Image tag for the `webhook` container.
219 tag: latest@sha256:cb861cf01d5be75026d3b0cb9514743cc1793554993775a7335845d9b0ef657b # @schema type:[string, null]; default: null
220 # -- Image pull policy for the `webhook` container.
221 pullPolicy: IfNotPresent
222 # -- [Environment variables](https://kubernetes.io/docs/tasks/inject-data-application/define-environment-variable-container/) for the `webhook` container.
224 # -- Extra arguments to provide for the `webhook` container.
226 # -- Extra [volume mounts](https://kubernetes.io/docs/concepts/storage/volumes/) for the `webhook` container.
227 extraVolumeMounts: []
228 # -- [Resources](https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/) for the `webhook` container.
230 # -- [Pod security context](https://kubernetes.io/docs/tasks/configure-pod-container/security-context/#set-the-security-context-for-a-container) for the `webhook` container.
231 # @default -- See _values.yaml_
233 # -- [Liveness probe](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/) configuration for the `external-dns` container.
234 # @default -- See _values.yaml_
237 path: /healthz # @schema type:[string, null]; default: null
238 port: http-webhook # @schema type:[integer,string]; default: string
239 initialDelaySeconds: 10 # @schema type:[integer, null]; default: null
240 periodSeconds: 10 # @schema type:[integer, null]; default: null
241 timeoutSeconds: 5 # @schema type:[integer, null]; default: null
242 failureThreshold: 2 # @schema type:[integer, null]; default: null
243 successThreshold: 1 # @schema type:[integer, null]; default: null
244 # -- [Readiness probe](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/) configuration for the `webhook` container.
245 # @default -- See _values.yaml_
248 path: /healthz # @schema type:[string, null]; default: null
249 port: http-webhook # @schema type:[integer,string]; default: string
250 initialDelaySeconds: 5 # @schema type:[integer, null]; default: null
251 periodSeconds: 10 # @schema type:[integer, null]; default: null
252 timeoutSeconds: 5 # @schema type:[integer, null]; default: null
253 failureThreshold: 6 # @schema type:[integer, null]; default: null
254 successThreshold: 1 # @schema type:[integer, null]; default: null
256 # -- Webhook exposed HTTP port for the service.
258 # -- Optional [Service Monitor](https://prometheus-operator.dev/docs/operator/design/#servicemonitor) configuration for the `webhook` container.
259 # @default -- See _values.yaml_
261 interval: # @schema type:[string, null]; default: null
262 scheme: # @schema type:[string, null]; default: null
264 bearerTokenFile: # @schema type:[string, null]; default: null
265 scrapeTimeout: # @schema type:[string, null]; default: null
266 metricRelabelings: []
268# -- Extra arguments to provide to _ExternalDNS_.
269# An array or map can be used, with maps allowing for value overrides; maps also support slice values to use the same arg multiple times.
270extraArgs: {} # @schema type: [array, null, object]; item: string; uniqueItems: true
272 # -- If `true`, create a `Secret` to store sensitive provider configuration (**DEPRECATED**).
274 # -- Mount path for the `Secret`, this can be templated.
275 mountPath: # @schema type:[string, null]; default: null
276 # -- Sub-path for mounting the `Secret`, this can be templated.
277 subPath: # @schema type:[string, null]; default: null
280# -- (bool) No effect - reserved for use in sub-charting.
281enabled: # @schema type: [boolean, null]; description: No effect - reserved for use in sub-charting