2021-01-13 14:47:39 +00:00
#! Copyright 2020-2021 the Pinniped contributors. All Rights Reserved.
2020-08-25 01:07:34 +00:00
#! SPDX-License-Identifier: Apache-2.0
2023-09-28 20:43:05 +00:00
#@data/values-schema
2020-07-07 20:17:34 +00:00
---
2023-09-28 20:43:05 +00:00
#@schema/desc "Name of pinniped-concierge."
2020-10-09 21:25:34 +00:00
app_name : pinniped-concierge
2020-10-14 22:05:42 +00:00
2023-09-28 20:43:05 +00:00
#@schema/desc "Creates a new namespace statically in yaml with the given name and installs the app into that namespace."
2020-10-09 21:25:34 +00:00
namespace : pinniped-concierge
2023-09-28 20:43:05 +00:00
#@ into_namespace_desc = "If specified, assumes that a namespace of the given name already exists and installs the app into that namespace. \
#@ If both `namespace` and `into_namespace` are specified, then only `into_namespace` is used."
#@schema/desc into_namespace_desc
#@schema/nullable
into_namespace : my-preexisting-namespace
#@ custom_labels_desc = "All resources created statically by yaml at install-time and all resources created dynamically \
#@ by controllers at runtime will be labelled with `app: $app_name` and also with the labels \
#@ specified here. The value of `custom_labels` must be a map of string keys to string values. \
#@ The app can be uninstalled either by: \
#@ 1. Deleting the static install-time yaml resources including the static namespace, which will cascade and also delete \
#@ resources that were dynamically created by controllers at runtime \
#@ 2. Or, deleting all resources by label, which does not assume that there was a static install-time yaml namespace."
#@schema/desc custom_labels_desc
#@schema/type any=True
custom_labels : {} #! {myCustomLabelName: myCustomLabelValue, otherCustomLabelName: otherCustomLabelValue}
#@schema/desc "Specify how many replicas of the Pinniped server to run."
2020-09-04 03:52:01 +00:00
replicas : 2
2023-09-28 20:43:05 +00:00
#@schema/desc "Specify either an image_digest or an image_tag. If both are given, only image_digest will be used."
2020-12-17 23:41:13 +00:00
image_repo : projects.registry.vmware.com/pinniped/pinniped-server
2023-09-28 20:43:05 +00:00
#@schema/desc "Specify either an image_digest or an image_tag. If both are given, only image_digest will be used."
#@schema/nullable
image_digest : sha256:f3c4fdfd3ef865d4b97a1fd295d94acc3f0c654c46b6f27ffad5cf80216903c8
#@schema/desc "Specify either an image_digest or an image_tag. If both are given, only image_digest will be used."
2020-09-16 22:46:51 +00:00
image_tag : latest
2020-07-09 17:16:46 +00:00
2023-09-28 20:43:05 +00:00
#@ kube_cert_agent_image = "Optionally specify a different image for the 'kube-cert-agent' pod which is scheduled \
#@ on the control plane. This image needs only to include `sleep` and `cat` binaries. \
#@ By default, the same image specified for image_repo/image_digest/image_tag will be re-used."
#@schema/desc kube_cert_agent_image
#@schema/nullable
kube_cert_agent_image : projects.registry.vmware.com/pinniped/pinniped-server
#@ image_pull_dockerconfigjson_desc = "Specifies a secret to be used when pulling the above `image_repo` container image. \
#@ Can be used when the above image_repo is a private registry. \
2023-10-12 15:21:06 +00:00
#@ Typically the value would be the output of: kubectl create secret docker-registry x --docker-server=https://example.io --docker-username=\"USERNAME\" --docker-password=\"PASSWORD\" --dry-run=client -o json | jq -r '.data[\".dockerconfigjson\"]' \
2023-09-28 20:43:05 +00:00
#@ Optional."
2023-10-11 20:05:53 +00:00
#! base64 encoded: {"auths":{"https://registry.example.com":{"username":"USERNAME","password":"PASSWORD","auth":"BASE64_ENCODED_USERNAME_COLON_PASSWORD"}}}
#! result: eyJhdXRocyI6eyJodHRwczovL2V4YW1wbGUuaW8iOnsidXNlcm5hbWUiOiJVU0VSTkFNRSIsInBhc3N3b3JkIjoiUEFTU1dPUkQiLCJhdXRoIjoiVlZORlVrNUJUVVU2VUVGVFUxZFBVa1E9In19fQ==
2023-09-28 20:43:05 +00:00
#@schema/desc image_pull_dockerconfigjson_desc
#@schema/nullable
2023-10-11 20:05:53 +00:00
image_pull_dockerconfigjson : "eyJhdXRocyI6eyJodHRwczovL2V4YW1wbGUuaW8iOnsidXNlcm5hbWUiOiJVU0VSTkFNRSIsInBhc3N3b3JkIjoiUEFTU1dPUkQiLCJhdXRoIjoiVlZORlVrNUJUVVU2VUVGVFUxZFBVa1E9In19fQ=="
2023-09-28 20:43:05 +00:00
#@schema/desc "Pinniped will try to guess the right K8s API URL for sharing that information with potential clients. This setting allows the guess to be overridden."
#@schema/nullable
discovery_url : https://example.com
#@ api_serving_certificate_desc = "Specify the duration and renewal interval for the API serving certificate. \
#@ The defaults are set to expire the cert about every 30 days, and to rotate it \
#@ about every 25 days."
#@schema/desc api_serving_certificate_desc
2020-08-20 21:13:02 +00:00
api_serving_certificate_duration_seconds : 2592000
2023-09-28 20:43:05 +00:00
#@schema/desc api_serving_certificate_desc
2020-08-20 21:13:02 +00:00
api_serving_certificate_renew_before_seconds : 2160000
2020-11-11 12:49:46 +00:00
2023-09-28 20:43:05 +00:00
#! Specify the verbosity of logging: info ("nice to know" information), debug (developer information), trace (timing information),
#! or all (kitchen sink). Do not use trace or all on production systems, as credentials may get logged.
#@schema/desc "default, when this value is left unset, only warnings and errors are printed. There is no way to suppress warning and error logs."
#@schema/nullable
log_level : info
#@ deprecated_log_format_desc = "Specify the format of logging: json (for machine parsable logs) and text (for legacy klog formatted logs). \
#@ By default, when this value is left unset, logs are formatted in json. \
#@ This configuration is deprecated and will be removed in a future release at which point logs will always be formatted as json."
#@schema/desc deprecated_log_format_desc
#@schema/nullable
deprecated_log_format : json
#@schema/desc "run_as_user specifies the user ID that will own the process, see the Dockerfile for the reasoning behind this choice"
run_as_user : 65532
#@schema/desc "run_as_group specifies the group ID that will own the process, see the Dockerfile for the reasoning behind this choice"
run_as_group : 65532
#@ api_group_suffix_desc = "Specify the API group suffix for all Pinniped API groups. By default, this is set to \
#@ pinniped.dev, so Pinniped API groups will look like foo.pinniped.dev, \
#@ authentication.concierge.pinniped.dev, etc. As an example, if this is set to tuna.io, then \
#@ Pinniped API groups will look like foo.tuna.io. authentication.concierge.tuna.io, etc."
#@schema/desc api_group_suffix_desc
2021-01-19 22:23:06 +00:00
api_group_suffix : pinniped.dev
2021-05-27 20:36:18 +00:00
2023-09-28 20:43:05 +00:00
#@schema/desc "Customize CredentialIssuer.spec.impersonationProxy to change how the concierge handles impersonation."
2021-05-27 20:36:18 +00:00
impersonation_proxy_spec :
#! options are "auto", "disabled" or "enabled".
#! If auto, the impersonation proxy will run only if the cluster signing key is not available
#! and the other strategy does not work.
#! If disabled, the impersonation proxy will never run, which could mean that the concierge
#! doesn't work at all.
#! If enabled, the impersonation proxy will always run regardless of other strategies available.
2023-09-28 20:43:05 +00:00
#@schema/desc "If enabled, the impersonation proxy will always run regardless of other strategies available."
2021-05-27 20:36:18 +00:00
mode : auto
2023-09-28 20:43:05 +00:00
#@ external_endpoint_desc = "The endpoint which the client should use to connect to the impersonation proxy. \
#@ If left unset, the client will default to connecting based on the ClusterIP or LoadBalancer endpoint."
#@schema/desc external_endpoint_desc
#@schema/nullable
external_endpoint : 1.2 .3 .4 : 5678
#@schema/desc "The impersonation proxy service configuration"
2021-05-27 20:36:18 +00:00
service :
#! Options are "LoadBalancer", "ClusterIP" and "None".
#! LoadBalancer automatically provisions a Service of type LoadBalancer pointing at
#! the impersonation proxy. Some cloud providers will allocate
#! a public IP address by default even on private clusters.
#! ClusterIP automatically provisions a Service of type ClusterIP pointing at the
#! impersonation proxy.
#! None does not provision either and assumes that you have set the external_endpoint
#! and set up your own ingress to connect to the impersonation proxy.
2023-09-28 20:43:05 +00:00
#@schema/desc "Options are 'LoadBalancer', 'ClusterIP' and 'None'."
#@schema/nullable
2021-06-02 19:48:18 +00:00
type : LoadBalancer
2023-09-28 20:43:05 +00:00
#@schema/desc "The annotations that should be set on the ClusterIP or LoadBalancer Service."
#@schema/nullable
2021-05-27 20:36:18 +00:00
annotations :
{service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout : "4000" }
2023-09-28 20:43:05 +00:00
#@schema/desc "When mode LoadBalancer is set, this will set the LoadBalancer Service's Spec.LoadBalancerIP."
#@schema/nullable
load_balancer_ip : 1.2 .3 .4 : 5678
#@ https_proxy_desc = "Set the standard golang HTTPS_PROXY and NO_PROXY environment variables on the Supervisor containers. \
#@ These will be used when the Supervisor makes backend-to-backend calls to upstream identity providers using HTTPS, \
#@ e.g. when the Supervisor fetches discovery documents, JWKS keys, and tokens from an upstream OIDC Provider. \
#@ The Supervisor never makes insecure HTTP calls, so there is no reason to set HTTP_PROXY. \
#@ Optional."
#@schema/desc https_proxy_desc
#@schema/nullable
https_proxy : http://proxy.example.com
#@schema/desc "do not proxy Kubernetes endpoints"
2021-08-17 13:44:40 +00:00
no_proxy : "$(KUBERNETES_SERVICE_HOST),169.254.169.254,127.0.0.1,localhost,.svc,.cluster.local" #! do not proxy Kubernetes endpoints