github.com/replicatedhq/ship@v0.55.0/integration/failing/init/concourse/expected/.ship/state.json (about) 1 { 2 "v1": { 3 "config": {}, 4 "releaseName": "concourse", 5 "helmValuesDefaults": "## Default values for Concourse Helm Chart.\n## This is a YAML-formatted file.\n## Declare variables to be passed into your templates.\n\n## Override the name of the Chart.\n##\n# nameOverride:\n\n## Concourse image.\n##\nimage: concourse/concourse\n\n## Concourse image version.\n## ref: https://hub.docker.com/r/concourse/concourse/tags/\n##\nimageTag: \"4.2.2\"\n\n## Specific image digest to use in place of a tag.\n## ref: https://kubernetes.io/docs/concepts/configuration/overview/#container-images\n##\n# imageDigest: sha256:54ea351808b55ecc14af6590732932e2a6a0ed8f6d10f45e8be3b51165d5526a\n\n## Specify a imagePullPolicy: 'Always' if imageTag is 'latest', else set to 'IfNotPresent'.\n## ref: https://kubernetes.io/docs/user-guide/images/#pre-pulling-images\n##\nimagePullPolicy: IfNotPresent\n\n## Optionally specify an array of imagePullSecrets.\n## Secrets must be manually created in the namespace.\n## ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/\n##\n# imagePullSecrets:\n# - myRegistrKeySecretName\n\n## Configuration values for Concourse.\n## ref: https://concourse-ci.org/setting-up.html\n##\nconcourse:\n web:\n ## Minimum level of logs to see.\n # logLevel: info\n ## IP address on which to listen for web traffic.\n # bindIp: 0.0.0.0\n ## Port on which to listen for HTTP traffic.\n bindPort: 8080\n ## TLS configurations for the web component to be able to serve HTTPS traffic.\n ## Once enabled, consumes the certificates set via secrets.\n #\n tls:\n enabled: false\n ## Port on which to listen for HTTPS traffic.\n # bindPort:\n ## URL used to reach any ATC from the outside world.\n # externalUrl: http://127.0.0.1:8080\n ## URL used to reach this ATC from other ATCs in the cluster.\n # peerUrl: http://127.0.0.1:8080\n ## Enable encryption of pipeline configuration. Encryption keys can be set via secrets.\n ## See https://concourse-ci.org/encryption.html\n ##\n encryption:\n enabled: false\n localAuth:\n enabled: true\n ## IP address on which to listen for the pprof debugger endpoints.\n # debugBindIp: 127.0.0.1\n ## Port on which to listen for the pprof debugger endpoints.\n # debugBindPort: 8079\n ## Length of time for a intercepted session to be idle before terminating.\n # interceptIdleTimeout: 0m\n ## Time limit on checking for new versions of resources.\n # globalResourceCheckTimeout: 1h\n ## Interval on which to check for new versions of resources.\n # resourceCheckingInterval: 1m\n ## Interval on which to check for new versions of resource types.\n # resourceTypeCheckingInterval: 1m\n ## Method by which a worker is selected during container placement.\n # containerPlacementStrategy: volume-locality\n ## How long to wait for Baggageclaim to send the response header.\n # baggageclaimResponseHeaderTimeout: 1m\n ## Directory containing downloadable CLI binaries.\n # cliArtifactsDir:\n ## Log database queries.\n # logDbQueries:\n ## Interval on which to run build tracking.\n # buildTrackerInterval: 10s\n ## Default build logs to retain, 0 means all\n # defaultBuildLogsToRetain:\n ## Maximum build logs to retain, 0 means not specified. Will override values configured in jobs\n # maxBuildLogsToRetain:\n ## Default max number of cpu shares per task, 0 means unlimited\n # defaultTaskCpuLimit:\n ## Default maximum memory per task, 0 means unlimited\n # defaultTaskMemoryLimit:\n postgres:\n ## The host to connect to.\n host: 127.0.0.1\n ## The port to connect to.\n port: 5432\n ## Path to a UNIX domain socket to connect to.\n # socket:\n ## Whether or not to use SSL.\n sslmode: disable\n ## Dialing timeout. (0 means wait indefinitely)\n connectTimeout: 5m\n ## The name of the database to use.\n database: atc\n\n kubernetes:\n\n ## Enable the use of in-cluster Kubernetes Secrets.\n ##\n enabled: true\n\n ## Prefix to use for Kubernetes namespaces under which secrets will be looked up. Defaults to\n ## the Release name hyphen, e.g. \"my-release-\" produces namespace \"my-release-main\" for the\n ## \"main\" Concourse team.\n ##\n ## namespacePrefix:\n\n ## Teams to create namespaces for to hold secrets.\n teams:\n - main\n\n ## Create the Kubernetes namespace for each team listed above.\n createTeamNamespaces: true\n\n ## When true, namespaces are not deleted when the release is deleted.\n ## Irrelevant if the namespaces are not created by this chart.\n keepNamespaces: true\n\n ## Path to Kubernetes config when running ATC outside Kubernetes.\n # configPath:\n\n awsSecretsManager:\n ## Enable the use of AWS Secrets Manager.\n ##\n enabled: false\n\n ## AWS region to use when reading from Secrets Manager\n ##\n # region:\n\n ## pipeline-specific template for Secrets Manager parameters, defaults to: /concourse/{team}/{pipeline}/{secret}\n ##\n # pipelineSecretTemplate:\n\n ## team-specific template for Secrets Manager parameters, defaults to: /concourse/{team}/{secret}\n ##\n # teamSecretTemplate: ''\n\n awsSsm:\n ## Enable the use of AWS SSM.\n ##\n enabled: false\n\n ## AWS region to use when reading from SSM\n ##\n # region:\n\n ## pipeline-specific template for SSM parameters, defaults to: /concourse/{team}/{pipeline}/{secret}\n ##\n # pipelineSecretTemplate:\n\n ## team-specific template for SSM parameters, defaults to: /concourse/{team}/{secret}\n ##\n # teamSecretTemplate: ''\n\n\n vault:\n enabled: false\n\n ## URL pointing to vault addr (i.e. http://vault:8200).\n ##\n # url:\n\n ## vault path under which to namespace credential lookup, defaults to /concourse.\n ##\n pathPrefix: /concourse\n\n ## if the Vault server is using a self-signed certificate, set this to true,\n ## and provide a value for the cert in secrets.\n ##\n # useCaCert:\n\n ## vault authentication backend, leave this blank if using an initial periodic token\n ## currently supported backends: token, approle, cert.\n ##\n # authBackend:\n\n ## Cache returned secrets for their lease duration in memory\n # cache:\n ## If the cache is enabled, and this is set, override secrets lease duration with a maximum value\n # maxLease:\n ## Path to a directory of PEMEncoded CA cert files to verify the vault server SSL cert.\n # caPath:\n ## If set, is used to set the SNI host when connecting via TLS.\n # serverName:\n ## Enable insecure SSL verification.\n # insecureSkipVerify:\n ## Client token for accessing secrets within the Vault server.\n # clientToken:\n ## Auth backend to use for logging in to Vault.\n # authBackend:\n ## Time after which to force a reLogin. If not set, the token will just be continuously renewed.\n # authBackendMaxTtl:\n ## The maximum time between retries when logging in or reAuthing a secret.\n retryMax: 5m\n ## The initial time between retries when logging in or reAuthing a secret.\n retryInitial: 1s\n ## Don't actually do any automatic scheduling or checking.\n # noop:\n staticWorker:\n enabled: false\n ## A Garden API endpoint to register as a worker.\n gardenUrl:\n ## A Baggageclaim API endpoint to register with the worker.\n baggageclaimUrl:\n ## A resource type to advertise for the worker. Can be specified multiple times.\n resource:\n metrics:\n ## Host string to attach to emitted metrics.\n hostName:\n ## A keyValue attribute to attach to emitted metrics. Can be specified multiple times.\n attribute:\n datadog:\n enabled: false\n ## Use IP of node the pod is scheduled on, overrides `agentHost`\n agentHostUseHostIP: false\n ## Datadog agent host to expose dogstatsd metrics\n agentHost: 127.0.0.1\n ## Datadog agent port to expose dogstatsd metrics\n agentPort: 8125\n ## Prefix for all metrics to easily find them in Datadog\n # prefix: concoursedev\n influxdb:\n enabled: false\n ## InfluxDB server address to emit points to.\n url: http://127.0.0.1:8086\n ## InfluxDB database to write points to.\n database: concourse\n ## InfluxDB server username.\n # username:\n ## Skip SSL verification when emitting to InfluxDB.\n insecureSkipVerify: false\n ## Emit metrics to logs.\n # emitToLogs:\n newrelic:\n enabled: false\n ## New Relic Account ID\n # accountId:\n ## New Relic Insights API Key\n # apiKey:\n ## An optional prefix for emitted New Relic events\n # servicePrefix:\n prometheus:\n enabled: false\n ## IP to listen on to expose Prometheus metrics.\n bindIp: \"0.0.0.0\"\n ## Port to listen on to expose Prometheus metrics.\n bindPort: 9391\n riemann:\n enabled: false\n ## Riemann server address to emit metrics to.\n # host:\n ## Port of the Riemann server to emit metrics to.\n port: 5555\n ## An optional prefix for emitted Riemann services\n # servicePrefix:\n ## Tag to attach to emitted metrics. Can be specified multiple times.\n # tag:\n ## The value to set for XFrame-Options. If omitted, the header is not set.\n # xFrameOptions:\n gc:\n overrideDefaults: false\n ## Interval on which to perform garbage collection.\n interval: 30s\n ## Grace period before reaping oneOff task containers\n oneOffGracePeriod: 5m\n syslog:\n enabled: false\n ## Client hostname with which the build logs will be sent to the syslog server.\n hostName: atc-syslog-drainer\n ## Remote syslog server address with port (Example: 0.0.0.0:514).\n # address:\n ## Transport protocol for syslog messages (Currently supporting tcp, udp \u0026 tls).\n # transport:\n ## Interval over which checking is done for new build logs to send to syslog server (duration measurement units are s/m/h; eg. 30s/30m/1h)\n drainInterval: 30s\n ## if the syslog server is using a self-signed certificate, set this to true,\n ## and provide a value for the cert in secrets.\n useCaCert: false\n auth:\n ## Force sending secure flag on http cookies\n # cookieSecure:\n ## Length of time for which tokens are valid. Afterwards, users will have to log back in.\n # duration: 24h\n mainTeam:\n ## List of whitelisted local concourse users. These are the users you've added at atc startup with the addLocalUser setting.\n localUser: \"test\"\n ## Setting this flag will whitelist all logged in users in the system. ALL OF THEM. If, for example, you've configured GitHub, any user with a GitHub account will have access to your team.\n # allowAllUsers:\n ## Authentication (Main Team) (CloudFoundry)\n cf:\n ## List of whitelisted CloudFoundry users.\n user:\n ## List of whitelisted CloudFoundry orgs\n org:\n ## List of whitelisted CloudFoundry spaces\n space:\n ## (Deprecated) List of whitelisted CloudFoundry space guids\n spaceGuid:\n ## Authentication (Main Team) (GitHub)\n github:\n ## List of whitelisted GitHub users\n user:\n ## List of whitelisted GitHub orgs\n org:\n ## List of whitelisted GitHub teams\n team:\n ## Authentication (Main Team) (GitLab)\n gitlab:\n ## List of whitelisted GitLab users\n user:\n ## List of whitelisted GitLab groups\n group:\n ## Authentication (Main Team) (LDAP)\n ldap:\n ## List of whitelisted LDAP users\n user:\n ## List of whitelisted LDAP groups\n group:\n ## Authentication (Main Team) (OAuth2)\n oauth:\n ## List of whitelisted OAuth2 users\n user:\n ## List of whitelisted OAuth2 groups\n group:\n ## Authentication (Main Team) (OIDC)\n oidc:\n ## List of whitelisted OIDC users\n user:\n ## List of whitelisted OIDC groups\n group:\n ## Authentication (CloudFoundry)\n cf:\n enabled: false\n ## (Required) The base API URL of your CF deployment. It will use this information to discover information about the authentication provider.\n # apiUrl: https://api.run.pivotal.io\n ## CA Certificate\n # useCaCert:\n ## Skip SSL validation\n # skipSslValidation:\n ## Authentication (GitHub)\n github:\n enabled: false\n ## Hostname of GitHub Enterprise deployment (No scheme, No trailing slash)\n # host:\n ## CA certificate of GitHub Enterprise deployment\n # useCaCert:\n ## Authentication (GitLab)\n gitlab:\n enabled: false\n ## Hostname of Gitlab Enterprise deployment (Include scheme, No trailing slash)\n # host:\n ## Authentication (LDAP)\n ldap:\n enabled: false\n ## The auth provider name displayed to users on the login page\n # displayName:\n ## (Required) The host and optional port of the LDAP server. If port isn't supplied, it will be guessed based on the TLS configuration. 389 or 636.\n # host:\n ## (Required) Bind DN for searching LDAP users and groups. Typically this is a readOnly user.\n # bindDn:\n ## (Required) Bind Password for the user specified by 'bindDn'\n # bindPw:\n ## Required if LDAP host does not use TLS.\n # insecureNoSsl:\n ## Skip certificate verification\n # insecureSkipVerify:\n ## Start on insecure port, then negotiate TLS\n # startTls:\n ## CA certificate\n # useCaCert:\n ## BaseDN to start the search from. For example 'cn=users,dc=example,dc=com'\n # userSearchBaseDn:\n ## Optional filter to apply when searching the directory. For example '(objectClass=person)'\n # userSearchFilter:\n ## Attribute to match against the inputted username. This will be translated and combined with the other filter as '(\u003cattr\u003e=\u003cusername\u003e)'.\n # userSearchUsername:\n ## Can either be: 'sub' search the whole sub tree or 'one' - only search one level. Defaults to 'sub'.\n # userSearchScope:\n ## A mapping of attributes on the user entry to claims. Defaults to 'uid'.\n # userSearchIdAttr:\n ## A mapping of attributes on the user entry to claims. Defaults to 'mail'.\n # userSearchEmailAttr:\n ## A mapping of attributes on the user entry to claims.\n # userSearchNameAttr:\n ## BaseDN to start the search from. For example 'cn=groups,dc=example,dc=com'\n # groupSearchBaseDn:\n ## Optional filter to apply when searching the directory. For example '(objectClass=posixGroup)'\n # groupSearchFilter:\n ## Can either be: 'sub' search the whole sub tree or 'one' - only search one level. Defaults to 'sub'.\n # groupSearchScope:\n ## Adds an additional requirement to the filter that an attribute in the group match the user's attribute value. The exact filter being added is: (\u003cgroupAttr\u003e=\u003cuserAttr value\u003e)\n # groupSearchUserAttr:\n ## Adds an additional requirement to the filter that an attribute in the group match the user's attribute value. The exact filter being added is: (\u003cgroupAttr\u003e=\u003cuserAttr value\u003e)\n # groupSearchGroupAttr:\n ## The attribute of the group that represents its name.\n # groupSearchNameAttr:\n ## Authentication (OAuth2)\n oauth:\n enabled: false\n ## The auth provider name displayed to users on the login page\n # displayName:\n ## (Required) Authorization URL\n # authUrl:\n ## (Required) Token URL\n # tokenUrl:\n ## UserInfo URL\n # userinfoUrl:\n ## Any additional scopes that need to be requested during authorization\n # scope:\n ## The groups key indicates which claim to use to map external groups to Concourse teams.\n # groupsKey:\n ## CA Certificate\n # useCaCert:\n ## Skip SSL validation\n # skipSslValidation:\n ## Authentication (OIDC)\n oidc:\n enabled: false\n ## The auth provider name displayed to users on the login page\n # displayName:\n ## (Required) An OIDC issuer URL that will be used to discover provider configuration using the .wellKnown/openid-configuration\n # issuer:\n ## Any additional scopes that need to be requested during authorization\n # scope:\n ## The groups key indicates which claim to use to map external groups to Concourse teams.\n # groupsKey:\n ## CA Certificate\n # useCaCert:\n ## Skip SSL validation\n # skipSslValidation:\n tsa:\n ## Minimum level of logs to see.\n # logLevel: info\n ## IP address on which to listen for SSH.\n # bindIp: 0.0.0.0\n ## Port on which to listen for SSH.\n bindPort: 2222\n ## Port on which to listen for TSA pprof server.\n # bindDebugPort: 8089\n ## IP address of this TSA, reachable by the ATCs. Used for forwarded worker addresses.\n # peerIp:\n ## Path to private key to use for the SSH server.\n # hostKey:\n ## Path to file containing keys to authorize, in SSH authorized_keys format (one public key per line).\n # authorizedKeys:\n ## Path to file containing keys to authorize, in SSH authorized_keys format (one public key per line).\n # teamAuthorizedKeys:\n ## ATC API endpoints to which workers will be registered.\n # atcUrl:\n ## Path to private key to use when signing tokens in reqests to the ATC during registration.\n # sessionSigningKey:\n ## interval on which to heartbeat workers to the ATC\n # heartbeatInterval: 30s\n worker:\n ## The name to set for the worker during registration. If not specified, the hostname will be used.\n # name:\n ## A tag to set during registration. Can be specified multiple times.\n # tag:\n ## The name of the team that this worker will be assigned to.\n # team:\n ## HTTP proxy endpoint to use for containers.\n # http_proxy:\n ## HTTPS proxy endpoint to use for containers.\n # https_proxy:\n ## Blacklist of addresses to skip the proxy when reaching.\n # no_proxy:\n ## If set, the worker will be immediately removed upon stalling.\n # ephemeral:\n ## Port on which to listen for beacon pprof server.\n # bindDebugPort: 9099\n ## Version of the worker. This is normally baked in to the binary, so this flag is hidden.\n # version:\n ## Directory in which to place container data.\n workDir: /concourse-work-dir\n ## IP address on which to listen for the Garden server.\n # bindIp: 127.0.0.1\n ## Port on which to listen for the Garden server.\n # bindPort: 7777\n ## IP used to reach this worker from the ATC nodes.\n # peerIp:\n ## Minimum level of logs to see.\n # logLevel: info\n tsa:\n ## TSA host to forward the worker through. Can be specified multiple times.\n host: 127.0.0.1:2222\n ## File containing a public key to expect from the TSA.\n # publicKey:\n ## File containing the private key to use when authenticating to the TSA.\n # workerPrivateKey:\n garden:\n ## Minimum level of logs to see.\n # logLevel: info\n ## format of log timestamps\n # timeFormat: unix-epoch\n ## Bind with TCP on the given IP.\n # bindIp:\n ## Bind with TCP on the given port.\n bindPort: 7777\n ## Bind with Unix on the given socket path.\n # bindSocket: /tmp/garden.sock\n ## Bind the debug server on the given IP.\n # debugBindIp:\n ## Bind the debug server to the given port.\n # debugBindPort: 17013\n ## Skip the preparation part of the host that requires root privileges\n # skipSetup:\n ## Directory in which to store container data.\n # depot: /var/run/gdn/depot\n ## Path in which to store properties.\n # propertiesPath:\n ## Path in which to store temporary sockets\n # consoleSocketsPath:\n ## Clean up proccess dirs on first invocation of wait\n # cleanupProcessDirsOnWait:\n ## Disable creation of privileged containers\n # disablePrivilegedContainers:\n ## The lowest numerical subordinate user ID the user is allowed to map\n # uidMapStart: 1\n ## The number of numerical subordinate user IDs the user is allowed to map\n # uidMapLength:\n ## The lowest numerical subordinate group ID the user is allowed to map\n # gidMapStart: 1\n ## The number of numerical subordinate group IDs the user is allowed to map\n # gidMapLength:\n ## Default rootfs to use when not specified on container creation.\n # defaultRootfs:\n ## Default time after which idle containers should expire.\n # defaultGraceTime:\n ## Clean up all the existing containers on startup.\n # destroyContainersOnStartup:\n ## Apparmor profile to use for unprivileged container processes\n # apparmor:\n ## Directory in which to extract packaged assets\n # assetsDir: /var/gdn/assets\n ## Path to the 'dadoo' binary.\n # dadooBin:\n ## Path to the 'nstar' binary.\n # nstarBin:\n ## Path to the 'tar' binary.\n # tarBin:\n ## path to the iptables binary\n # iptablesBin: /sbin/iptables\n ## path to the iptables-restore binary\n # iptablesRestoreBin: /sbin/iptables-restore\n ## Path execute as pid 1 inside each container.\n # initBin:\n ## Path to the runtime plugin binary.\n # runtimePlugin: runc\n ## Extra argument to pass to the runtime plugin. Can be specified multiple times.\n # runtimePluginExtraArg:\n ## Directory on which to store imported rootfs graph data.\n # graph:\n ## Disk usage of the graph dir at which cleanup should trigger, or -1 to disable graph cleanup.\n # graphCleanupThresholdInMegabytes: -1\n ## Image that should never be garbage collected. Can be specified multiple times.\n # persistentImage:\n ## Path to image plugin binary.\n # imagePlugin:\n ## Extra argument to pass to the image plugin to create unprivileged images. Can be specified multiple times.\n # imagePluginExtraArg:\n ## Path to privileged image plugin binary.\n # privilegedImagePlugin:\n ## Extra argument to pass to the image plugin to create privileged images. Can be specified multiple times.\n # privilegedImagePluginExtraArg:\n ## Docker registry API endpoint.\n # dockerRegistry: registry-1.docker.io\n ## Docker registry to allow connecting to even if not secure. Can be specified multiple times.\n # insecureDockerRegistry:\n ## Network range to use for dynamically allocated container subnets.\n # networkPool: 10.254.0.0/22\n ## Allow network access to the host machine.\n # allowHostAccess:\n ## Network ranges to which traffic from containers will be denied. Can be specified multiple times.\n # denyNetwork:\n ## DNS server IP address to use instead of automatically determined servers. Can be specified multiple times.\n # dnsServer:\n ## DNS server IP address to append to the automatically determined servers. Can be specified multiple times.\n # additionalDnsServer:\n ## Per line hosts entries. Can be specified multiple times and will be appended verbatim in order to /etc/hosts\n # additionalHostEntry:\n ## IP address to use to reach container's mapped ports. Autodetected if not specified.\n # externalIp:\n ## Start of the ephemeral port range used for mapped container ports.\n # portPoolStart: 61001\n ## Size of the port pool used for mapped container ports.\n # portPoolSize: 4534\n ## Path in which to store port pool properties.\n # portPoolPropertiesPath:\n ## MTU size for container network interfaces. Defaults to the MTU of the interface used for outbound access by the host. Max allowed value is 1500.\n # mtu:\n ## Path to network plugin binary.\n # networkPlugin:\n ## Extra argument to pass to the network plugin. Can be specified multiple times.\n # networkPluginExtraArg:\n ## Maximum number of microseconds each cpu share assigned to a container allows per quota period\n # cpuQuotaPerShare: 0\n ## Set hard limit for the tcp buf memory, value in bytes\n # tcpMemoryLimit: 0\n ## Default block IO weight assigned to a container\n # defaultContainerBlockioWeight: 0\n ## Maximum number of containers that can be created.\n # maxContainers: 0\n ## Disable swap memory limit\n # disableSwapLimit:\n ## Interval on which to emit metrics.\n # metricsEmissionInterval: 1m\n ## Origin identifier for Dropsonde-emitted metrics.\n # dropsondeOrigin: garden-linux\n ## Destination for Dropsonde-emitted metrics.\n # dropsondeDestination: 127.0.0.1:3457\n ## Path to a containerd socket.\n # containerdSocket:\n ## Use containerd to run processes in containers.\n # useContainerdForProcesses:\n ## Enable proxy DNS server.\n # dnsProxyEnable:\n baggageclaim:\n ## Minimum level of logs to see.\n # logLevel: info\n ## IP address on which to listen for API traffic.\n # bindIp: 127.0.0.1\n ## Port on which to listen for API traffic.\n # bindPort: 7788\n ## Port on which to listen for baggageclaim pprof server.\n # bindDebugPort: 8099\n ## Directory in which to place volume data.\n # volumes:\n ## Driver to use for managing volumes.\n driver: naive\n ## Path to btrfs binary\n # btrfsBin: btrfs\n ## Path to mkfs.btrfs binary\n # mkfsBin: mkfs.btrfs\n ## Path to directory in which to store overlay data\n # overlaysDir:\n ## Interval on which to reap expired volumes.\n # reapInterval: 10s\n\n## Configuration values for Concourse Web components.\n##\nweb:\n ## Override the components name (defaults to web).\n ##\n # nameOverride:\n\n ## Number of replicas.\n ##\n replicas: 1\n\n ## Configures the liveness probe used to determine\n ## if the Web component is up.\n ## Note.: if you're upgrading Concourse from one version\n ## to another, the probe will probably fail for some time\n ## before migrations are finished - in such situations,\n ## either consider bumping the values set here.\n livenessProbe:\n failureThreshold: 5\n httpGet:\n path: /api/v1/info\n port: atc\n initialDelaySeconds: 10\n periodSeconds: 15\n timeoutSeconds: 3\n\n ## Configures the readiness probes.\n readinessProbe:\n httpGet:\n path: /api/v1/info\n port: atc\n\n ## Configure resource requests and limits.\n ## ref: https://kubernetes.io/docs/user-guide/compute-resources/\n ##\n resources:\n requests:\n cpu: \"100m\"\n memory: \"128Mi\"\n\n ## Configure additional environment variables for the\n ## web containers.\n # env:\n # - name: CONCOURSE_LOG_LEVEL\n # value: \"debug\"\n # - name: CONCOURSE_TSA_LOG_LEVEL\n # value: \"debug\"\n\n ## For managing where secrets should be mounted for the web agents\n keySecretsPath: \"/concourse-keys\"\n authSecretsPath: \"/concourse-auth\"\n vaultSecretsPath: \"/concourse-vault\"\n postgresqlSecretsPath: \"/concourse-postgresql\"\n syslogSecretsPath: \"/concourse-syslog\"\n tlsSecretsPath: \"/concourse-web-tls\"\n\n ## Configure additional volumes for the\n ## web container(s)\n ##\n # additionalVolumes:\n # - name: my-team-authorized-keys\n # configMap:\n # name: my-team-authorized-keys-config\n\n ## Configure additional volumeMounts for the\n ## web container(s)\n ##\n # additionalVolumeMounts:\n # - name: my-team-authorized-keys\n # mountPath: /my-team-authorized-keys\n\n ## Additional affinities to add to the web pods.\n ##\n # additionalAffinities:\n # nodeAffinity:\n # preferredDuringSchedulingIgnoredDuringExecution:\n # - weight: 50\n # preference:\n # matchExpressions:\n # - key: spot\n # operator: NotIn\n # values:\n # - \"true\"\n\n ## Annotations for the web nodes.\n ## Ref: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/\n annotations: {}\n # annotations:\n # key1: \"value1\"\n # key2: \"value2\"\n\n ## Node selector for web nodes.\n nodeSelector: {}\n\n ## Tolerations for the web nodes.\n ## Ref: https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/\n tolerations: []\n # tolerations:\n # - key: \"toleration=key\"\n # operator: \"Equal\"\n # value: \"value\"\n # effect: \"NoSchedule\"\n\n ## Service configuration.\n ## ref: https://kubernetes.io/docs/user-guide/services/\n ##\n service:\n ## For minikube, set this to ClusterIP, elsewhere use LoadBalancer or NodePort\n ## ref: https://kubernetes.io/docs/user-guide/services/#publishing-services---service-types\n ##\n type: ClusterIP\n\n ## When using web.service.type: LoadBalancer, sets the user-specified load balancer IP\n # loadBalancerIP: 172.217.1.174\n\n # # Additional Labels to be added to the web service.\n # labels:\n\n ## Annotations to be added to the web service.\n ##\n # annotations:\n # prometheus.io/probe: \"true\"\n # prometheus.io/probe_path: \"/\"\n #\n # ## When using web.service.type: LoadBalancer, enable HTTPS with an ACM cert\n # service.beta.kubernetes.io/aws-load-balancer-ssl-cert: \"arn:aws:acm:eu-west-1:123456789:certificate/abc123-abc123-abc123-abc123\"\n # service.beta.kubernetes.io/aws-load-balancer-backend-protocol: \"http\"\n # service.beta.kubernetes.io/aws-load-balancer-backend-port: \"atc\"\n # service.beta.kubernetes.io/aws-load-balancer-ssl-ports: \"443\"\n #\n # ## When using web.service.type: LoadBalancer, whitelist the load balancer to particular IPs\n # loadBalancerSourceRanges:\n # - 192.168.1.10/32\n\n # When using web.service.type: NodePort, sets the nodePort for atc\n # atcNodePort: 30150\n #\n # When using web.service.type: NodePort, sets the nodePort for atc tls\n # atcTlsNodePort: 30151\n #\n # When using web.service.type: NodePort, sets the nodePort for tsa\n # tsaNodePort: 30152\n\n ## Ingress configuration.\n ## ref: https://kubernetes.io/docs/user-guide/ingress/\n ##\n ingress:\n ## Enable Ingress.\n ##\n enabled: false\n\n ## Annotations to be added to the web ingress.\n ##\n # annotations:\n # kubernetes.io/ingress.class: nginx\n # kubernetes.io/tls-acme: 'true'\n\n ## Hostnames.\n ## Must be provided if Ingress is enabled.\n ##\n # hosts:\n # - concourse.domain.com\n\n ## TLS configuration.\n ## Secrets must be manually created in the namespace.\n ##\n # tls:\n # - secretName: concourse-web-tls\n # hosts:\n # - concourse.domain.com\n #\n #\n\n## Configuration values for Concourse Worker components.\n##\nworker:\n ## Override the components name (defaults to worker).\n ##\n # nameOverride:\n\n ## Number of replicas.\n ##\n replicas: 2\n\n ## Minimum number of workers available after an eviction\n ## ref: https://kubernetes.io/docs/admin/disruptions/\n ##\n minAvailable: 1\n\n ## Configure resource requests and limits.\n ## ref: https://kubernetes.io/docs/user-guide/compute-resources/\n ##\n resources:\n requests:\n cpu: \"100m\"\n memory: \"512Mi\"\n\n ## Configure additional environment variables for the\n ## worker container(s)\n # env:\n # - name: http_proxy\n # value: \"http://proxy.your-domain.com:3128\"\n # - name: https_proxy\n # value: \"http://proxy.your-domain.com:3128\"\n # - name: no_proxy\n # value: \"your-domain.com\"\n # - name: CONCOURSE_GARDEN_DNS_SERVER\n # value: \"8.8.8.8\"\n # - name: CONCOURSE_GARDEN_DNS_PROXY_ENABLE\n # value: \"true\"\n # - name: CONCOURSE_GARDEN_ALLOW_HOST_ACCESS\n # value: \"true\"\n\n\n ## For managing where secrets should be mounted for worker agents\n keySecretsPath: \"/concourse-keys\"\n\n ## Configure additional volumeMounts for the\n ## worker container(s)\n # additionalVolumeMounts:\n # - name: concourse-baggageclaim\n # mountPath: /baggageclaim\n\n ## Annotations to be added to the worker pods.\n ##\n # annotations:\n # iam.amazonaws.com/role: arn:aws:iam::123456789012:role/concourse\n #\n\n ## Node selector for the worker nodes.\n ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#nodeselector\n nodeSelector: {}\n # nodeSelector: {type: concourse}\n\n ## Additional affinities to add to the worker pods.\n ## Useful if you prefer to run workers on non-spot instances, for example\n ##\n # additionalAffinities:\n # nodeAffinity:\n # preferredDuringSchedulingIgnoredDuringExecution:\n # - weight: 50\n # preference:\n # matchExpressions:\n # - key: spot\n # operator: NotIn\n # values:\n # - \"true\"\n\n ## Configure additional volumes for the\n ## worker container(s)\n # additionalVolumes:\n # - name: concourse-baggageclaim\n # hostPath:\n # path: /dev/nvme0n1\n # type: BlockDevice\n #\n # As a special exception, this allows taking over the `concourse-work-dir`\n # volume (from the default emptyDir) if `persistence.enabled` is false:\n #\n # additionalVolumes:\n # - name: concourse-work-dir\n # hostPath:\n # path: /mnt/locally-mounted-fast-disk/concourse\n # type: DirectoryOrCreate\n\n ## Whether the workers should be forced to run on separate nodes.\n ## This is accomplished by setting their AntiAffinity with requiredDuringSchedulingIgnoredDuringExecution as opposed to preferred\n ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#inter-pod-affinity-and-anti-affinity-beta-feature\n hardAntiAffinity: false\n\n ## Tolerations for the worker nodes.\n ## Ref: https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/\n tolerations: []\n # tolerations:\n # - key: \"toleration=key\"\n # operator: \"Equal\"\n # value: \"value\"\n # effect: \"NoSchedule\"\n\n ## Time to allow the pod to terminate before being forcefully terminated. This should provide time for\n ## the worker to retire, i.e. drain its tasks. See https://concourse-ci.org/worker-internals.html for worker\n ## lifecycle semantics.\n terminationGracePeriodSeconds: 60\n\n ## If any of the strings are found in logs, the worker's livenessProbe will fail and trigger a pod restart.\n ## Specify one string per line, exact matching is used.\n ##\n fatalErrors: |-\n guardian.api.garden-server.create.failed\n baggageclaim.api.volume-server.create-volume-async.failed-to-create\n\n ## Strategy for StatefulSet updates (requires Kubernetes 1.6+)\n ## Ref: https://kubernetes.io/docs/concepts/workloads/controllers/statefulset\n ##\n updateStrategy: RollingUpdate\n\n ## Pod Management strategy (requires Kubernetes 1.7+)\n ## Ref: https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/#pod-management-policies\n ##\n ## \"OrderedReady\" is default. \"Parallel\" means worker pods will launch or terminate\n ## in parallel.\n podManagementPolicy: Parallel\n\n ## When persistance is disabled this value will be used to limit the emptyDir volume size\n ## Ref: https://kubernetes.io/docs/concepts/storage/volumes/#emptydir\n # emptyDirSize: 20Gi\n\n## Persistent Volume Storage configuration.\n## ref: https://kubernetes.io/docs/user-guide/persistent-volumes\n##\npersistence:\n ## Enable persistence using Persistent Volume Claims.\n ##\n enabled: true\n\n ## Worker Persistence configuration.\n ##\n worker:\n ## concourse data Persistent Volume Storage Class\n ## If defined, storageClassName: \u003cstorageClass\u003e\n ## If set to \"-\", storageClassName: \"\", which disables dynamic provisioning\n ## If undefined (the default) or set to null, no storageClassName spec is\n ## set, choosing the default provisioner. (gp2 on AWS, standard on\n ## GKE, AWS \u0026 OpenStack)\n ##\n # storageClass: \"-\"\n\n ## Persistent Volume Access Mode.\n ##\n accessMode: ReadWriteOnce\n\n ## Persistent Volume Storage Size.\n ##\n size: 20Gi\n\n## Configuration values for the postgresql dependency.\n## ref: https://github.com/kubernetes/charts/blob/master/stable/postgresql/README.md\n##\npostgresql:\n\n ## Use the PostgreSQL chart dependency.\n ## Set to false if bringing your own PostgreSQL, and set secret value postgresql-uri.\n ##\n enabled: true\n\n ### PostgreSQL User to create.\n ##\n postgresUser: concourse\n\n ## PostgreSQL Password for the new user.\n ## If not set, a random 10 characters password will be used.\n ##\n postgresPassword: concourse\n\n ## PostgreSQL Database to create.\n ##\n postgresDatabase: concourse\n\n ## Persistent Volume Storage configuration.\n ## ref: https://kubernetes.io/docs/user-guide/persistent-volumes\n ##\n persistence:\n ## Enable PostgreSQL persistence using Persistent Volume Claims.\n ##\n enabled: true\n ## concourse data Persistent Volume Storage Class\n ## If defined, storageClassName: \u003cstorageClass\u003e\n ## If set to \"-\", storageClassName: \"\", which disables dynamic provisioning\n ## If undefined (the default) or set to null, no storageClassName spec is\n ## set, choosing the default provisioner. (gp2 on AWS, standard on\n ## GKE, AWS \u0026 OpenStack)\n ##\n # storageClass: \"-\"\n ## Persistent Volume Access Mode.\n ##\n accessMode: ReadWriteOnce\n ## Persistent Volume Storage Size.\n ##\n size: 8Gi\n\n## For RBAC support:\nrbac:\n # true here enables creation of rbac resources\n create: true\n\n # rbac version\n apiVersion: v1beta1\n\n ## The name of the service account to use for web pods if rbac.create is false\n ##\n webServiceAccountName: default\n\n ## The name of the service account to use for worker pods if rbac.create is false\n ##\n workerServiceAccountName: default\n\n## For managing secrets using Helm\n##\nsecrets:\n\n ## List of username:password or username:bcrypted_password combinations for all your local concourse users.\n localUsers: \"test:test\"\n ## Create the secret resource from the following values. Set this to\n ## false to manage these secrets outside Helm.\n ##\n create: true\n\n ## The TLS certificate and private key for the web component to be able to terminate\n ## TLS connections.\n # webTlsCert:\n # webTlsKey:\n\n ## Concourse Host Keys.\n ## ref: https://concourse-ci.org/install.html#generating-keys\n ##\n hostKey: |-\n -----BEGIN RSA PRIVATE KEY-----\n MIIEogIBAAKCAQEA2AUPXxuiDC/qrBWjIdT5fvNcMlMEYpR3X4SLQIgLC1ULDsCO\n fleKZ+Wi4RzwbkUKiKmJm5GeyNVVCDdfvdD1Sd1+5faqmp2/OQBzLS7o8NY/btMw\n 8h9lx4KVJaJJ1EM1EiyGY41Nx591KP14pBfr0/NdOIrDu2JvF6e7CHEbrzkN57kb\n BVQkaIMaS01Rw/5Oe68GFalli2ii8L8dNWVVzquBh5PwVWimvTgwv3TYG2TH8L1V\n V7n+/zRRpkjMl2+PUouGqD+Bp+4wF+hp4AW5v24CqjtLJEMv4IEJv2FRfrOauBIZ\n XjAS1SSg9VaTOS3iwxaYrv8uG1XfMFHICvkEPQIDAQABAoIBAG87W8jrX6vK2Jm3\n ooJ/OeFmymiXWsCwFi+2/kVCR/2T0tfLyxO/W+NX2WD1F9CP+HaaZeMXPp3HS7up\n V8FT4ZohVYBwXTS0WYyucKApcYThrVQRpzhldnEfClGQmVeVK7Sp/KEyV4Sc1SVA\n L2i/cI142N2Ohm7spquVkLcuFsVINzZ0fXCv25dTqbkEgjTJzNdBzyFXvc4z0Mt9\n gW14M7mz+YKYOfsCxIEm438fC9b16C96yIFBdN+/jaP8pmb2RoIE2D0F8bj5K1hR\n YyGFKMOU4e6cYq59iWfubKuu2WNJEBk/5aO7x7Xu2S0k8wIYlwxFuu4LfR2Kvizu\n +mFVf3kCgYEA9e0+40tJGpOPM8hAB3DwXjYc8lCuyYf3z30T3RqVNCUVSWnlaj/s\n 3ENi6+Ng3u+Zs8cR2CFou+jAClTyWLuSnI9yACD0eyW9n4bzYMUbgdC6vneLjpzx\n wWR9Xv5RmZVly7xWuqcgEeEf8RNcYI3oXby0laF3EObvuAx/4ETIkFcCgYEA4N42\n w1UEWGopWBIIXYHkEPHQuF0SxR2CZyh9ExTeSxFphyibkcHRjDW+t91ZLnSm5k1N\n TOdYuc0ApBV3U+TexeFvDI94L/Oze6Ht5MatRQz8kRwMFGJL3TrpbgTmWdfG05Ad\n oiScJzwY16oJXnKusxik7V+gCCNNE0/2UuMnY4sCgYAEf82pvOPef5qcGOrK+A79\n ukG3UTCRcVJgUmp9nhHivVbxW+WdlwPPV9BEfol0KrAGMPsrmBjhbzWsOregVfYt\n tRYh2HiAlEUu2Po06AZDzrzL5UYBWu+1WRBOH5sAk1IkcxKnIY2dph++elszTQVW\n SbCIGEckYQU7ucbRJJECywKBgBb4vHFx8vKxTa3wkagzx7+vZFohL/SxEgxFx5k2\n bYsPqU8kZ9gZC7YeG3CfDShAxHgMd5QeoiLA/YrFop4QaG2gnP6UfXuwkqpTnYDc\n hwDh1b9hNR6z9/oOtaAGoh2VfHtKYqyYvtcHPaZyeWiLoKstHlQdi7SpHouVhJ1t\n FS4HAoGAGy+56+zvdROjJy9A2Mn/4BvWrsu4RSQILBJ6Hb4TpF46p2fn0rwqyhOj\n Occs+xkdEsI9w5phXzIEeOq2LqvWHDPxtdLpxOrrmx4AftAWdM8S1+OqTpzHihK1\n y1ZOrWfvON+XjWFFAEej/CpQZkNUkTzjTtSC0dnfAveZlasQHdI=\n -----END RSA PRIVATE KEY-----\n\n hostKeyPub: |-\n ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDYBQ9fG6IML+qsFaMh1Pl+81wyUwRilHdfhItAiAsLVQsOwI5+V4pn5aLhHPBuRQqIqYmbkZ7I1VUIN1+90PVJ3X7l9qqanb85AHMtLujw1j9u0zDyH2XHgpUloknUQzUSLIZjjU3Hn3Uo/XikF+vT8104isO7Ym8Xp7sIcRuvOQ3nuRsFVCRogxpLTVHD/k57rwYVqWWLaKLwvx01ZVXOq4GHk/BVaKa9ODC/dNgbZMfwvVVXuf7/NFGmSMyXb49Si4aoP4Gn7jAX6GngBbm/bgKqO0skQy/ggQm/YVF+s5q4EhleMBLVJKD1VpM5LeLDFpiu/y4bVd8wUcgK+QQ9 Concourse\n\n ## Concourse Session Signing Keys.\n ## ref: https://concourse-ci.org/install.html#generating-keys\n ##\n sessionSigningKey: |-\n -----BEGIN RSA PRIVATE KEY-----\n MIIEowIBAAKCAQEAwLql/rUIaI+PX7Tl3FWcTee4sQf8/daakALXx955tPwkhqlY\n e4T2V84p/ylFvNWpM4vfcMYKfMY0JLKgAgBvJhCytSkDBhTBoWmN6yE0AB11P9En\n lIZRBWNYqaC2cSge2ZD8qOSnwfFhnQAW8+7pE+ElJAVh7dtdF3A478H50lIigq8I\n zMWp2EGJpFC7/Uu36oIL/03MNGCmrH1jvtTuJiAMQUZYyL1ReBkvvHOzw9i4HXPy\n SMVtcllm4NBs2aVPtwhr2kwSkLt8t1bPdRn6OIyEAw5WktzAKaiZnkTvj6g3xzdp\n zKcrdlBr9aznlNvoSinBUfvtwyFmvFN1HHbA9wIDAQABAoIBAE7G/DrUfI9gvtX7\n 90jMpYsigFe8UCjho2PiBZlo0o6r0bJJXiV+/8J8PqZRlHPPUc4EClzqVjcSPRYS\n /VxUGRqSELoD/Xxq14rGvn+xnrO9VsOzFl6bWFq/dOpBCtHN+G4t2VifvgKES8YE\n 11z19sdta+UBXjn/RFnkQSGfRCI3QqTaYvjxevt0uWlyPmqkFPQQw8bvHIXzoB+B\n rzeiMa++nMvbX5pAH9XA0BvhyuH3fHidTUwiVBpkMcpLWtjP0A0JTsecDdbinDDq\n un2EIo8zMWRwKQN/JnUxsi8AUEigBTCUqeDgREXtW62uvFkSpcVMXwmVityLYIVy\n qnVLUCECgYEA6IwXkP1qnSfcNeoVI/ypDuz1/kdqcjSPhLYe+jdiLLoFkMW9AlDm\n lzwNaWlTFD9ygo+NjJCo63/A8HCm55sajws5hZ6r20vdZcKFMk9h0qF5oVA7lkQ2\n gvG2WaznuU7KkqhfP+pXhiLgZKoJkst/+g7r6uHpredwDY6hxeBK4vsCgYEA1CqH\n 8ywC5qUo/36kQg/TU2adN/YEHdJAAbU23EVrGQSVmnXW08H2NLFk0tsxrwoNnbgp\n PIk2J7BimbJvbND17ibr4GAklDTsR8aJkDl+0JgNCAK9N07qVt1s7FXzhg95jUL9\n EQW55z60GAJpecqNwA4Jsa8P852N0355Obp92TUCgYBkOBvf7JcJ66fHxH4f6D+j\n oxPQ5k5Fsck4VJS9GSlCRVkor09ptBvsiYDuMOoRC9b51YwXTDDAbWplNOd5YSrt\n AtVjdKJz/BoKRO7KY9Owxs54au+DLxqfDDSeKRokjoRW+CE0lnXp5RX3zCAcF3+r\n 8MpTi9D9lYSBEzs84BDmCQKBgQCMcH6/K3HcJJVn0fd+tyUGftUw9sswxjySJNbk\n pZrH263/qWMDls+Xf5kire9MU1ZCAWZiaN0NFoed/2wcVpGEDAV0548u/30r4bKr\n YjOcdhmiJNYFJ1qdF0MDib2CDvpB1IbZXrX46RujDO2urbJ435HxKNVhR/had8xc\n tyKYxQKBgCVDhN0MhnlUQJVZfX42APmF4gQg0r3sfL/NGXjEjMIKKFe5a88eZVHr\n L8x1+dp0q7czC8a/l1DUuiwDKl8OEpxLsGCq/J/wAfrSMPifu6EUlbUwlJOPdgha\n +p/KFAelHXJ2w/8yackAcarh35VP7ixhuvxswHNdgvfsBTFcjn30\n -----END RSA PRIVATE KEY-----\n\n ## Concourse Worker Keys.\n ## ref: https://concourse-ci.org/install.html#generating-keys\n ##\n workerKey: |-\n -----BEGIN RSA PRIVATE KEY-----\n MIIEpAIBAAKCAQEAuPehUmBXAQCoA7TLAQCYhf+vzcZVyj+VGXnMhLHnWLk7dRjo\n CU8GgNamdS5h7G3ywxOvKA3YjOLr8XyOMLS4c+e8N7tIzlMWdiXhe0lcBH9Z1ai5\n +Bof3/BlDUBksiKdc1A+QcfX6tDwMkOO5re1H4vOK3H/Cype58wCB03HYNgb05ED\n fW1Bj2qvz29VtmyjwEMuDs100iMqwCfPUx9oxXmmX8sUBRmw/Y1Rx/8pdKIjKw3m\n kWIHHBOSCPimO1qC47Aa8v/UH9hERCykyuFHiBiKlnIvZWm9bYvhsRTz4gt5KzRY\n 6OI0oVeHlLOHDSK48Da8VWij15lOqO2Nx6WssQIDAQABAoIBADET22UNFOi6MNpS\n 5S5N5ypezlnOD0NLnZcV3zMyNQ0wkNsgEakuo64Zxi7/cJIYFjq2hVoeWl//cdUw\n VFYODYcLbMBo3AeKukH9CRf6PgUfeUmcrENtQxnbIiTi+hTd5GMNXod7rAmtCJ59\n mHQVOGS3ZqvWYnKm+mmMktk3RPinynX/A4y3WHPacuAS58HM09Ck43WcHMxbGpsL\n /gZpICyFYZ2DviM+AHyWGcmw7LJrpC0QHo6+BAFMs4xlUecNgVIFUpfOoAcfsdtG\n K9j4AbuZ47iFisbay+1pyg/7O5eRTdGVQRtc7PBMOjea5jGsfmlDmdn1ZS50ykun\n ANfoQ5UCgYEA9Ak73PRy9nLlRkt4OBCF/4fwThUCMedsnWaVjQBMJYim4FB2ivF5\n cKdWt3y/RZI85KKYu0EXhLEoSIEAfz057R8t3QdVK4tZx6B47UFjBjCYeVMtwHDQ\n prxQiOPHIHCplBNFuGzA5VXL9gQLRD+ek0uOy2GJJ0Wu1xyeouI+SW8CgYEAwgkO\n TOtOogqmcAALjWgeeQiZetflSKbJlpQNhmCPAMm0SFI8eF4SpRXLzd41VC2mLIwT\n L3tjc7/8ocXoElFM4L0fo9Lx/SHFH4JEn5FT0PXPmvsF2JRhsXJFLJSihxF/91Xs\n 2aBcQILPFzLcrI6OFUakNwGTU/CIxpkzRvQrG98CgYEAzNVnUuo4CNadzagRK3Xr\n E3Yl5VRK+FpY17FAfA6w25xc/dFr/un61e0Po4no/ltmEz7LVfmn5O/ScTEemq5o\n jbjrBShfe+JGpIH0nqiQlqR5hvSjZXEMIbfVHWGbRYZrQGgA0HEwZA7k2QXB8zI3\n R0lXfSzMM5OQ0uwp12xxfa8CgYBHILq1R6zTicPpWprhg0FobNaWSX4rW7iaEjvC\n /rJtP4Nu33Z7SUDcc1j6ZnJ2ISXBPrfpt/mE/OPHCZ1A2bysxadLjpBWkoKIQmCV\n fdiTyQgJb+t8sSf+vDzPUs0hZjDaogzo2ff3TfxMLMDoIHnFItgfsdwn8QyygIZj\n hC4pUQKBgQDqsxnkI6yXFE5gshnW7H8zqKNlzKd/dZEL6e+lRz4R3UY/KcEkRAfq\n Yi3cwo9fE3U3kSmpl5MQwUjWm/BZ7JyueoY/4ndwaFPgc34IKsgJ0wau9pZiQAB1\n DxpOSF+BR71Jx3sxvIdCODNTtm645j5yrZVnJAuMPofo5XFmunDoJA==\n -----END RSA PRIVATE KEY-----\n\n workerKeyPub: |-\n ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC496FSYFcBAKgDtMsBAJiF/6/NxlXKP5UZecyEsedYuTt1GOgJTwaA1qZ1LmHsbfLDE68oDdiM4uvxfI4wtLhz57w3u0jOUxZ2JeF7SVwEf1nVqLn4Gh/f8GUNQGSyIp1zUD5Bx9fq0PAyQ47mt7Ufi84rcf8LKl7nzAIHTcdg2BvTkQN9bUGPaq/Pb1W2bKPAQy4OzXTSIyrAJ89TH2jFeaZfyxQFGbD9jVHH/yl0oiMrDeaRYgccE5II+KY7WoLjsBry/9Qf2ERELKTK4UeIGIqWci9lab1ti+GxFPPiC3krNFjo4jShV4eUs4cNIrjwNrxVaKPXmU6o7Y3Hpayx Concourse\n\n ## Secrets for DB access\n # postgresUser:\n # postgresPassword:\n # postgresCaCert:\n # postgresClientCert:\n # postgresClientKey:\n\n ## Secrets for DB encryption\n ##\n # encryptionKey:\n # oldEncryptionKey:\n\n ## Secrets for SSM AWS access\n # awsSsmAccessKey:\n # awsSsmSecretKey:\n # awsSsmSessionToken:\n\n ## Secrets for Secrets Manager AWS access\n # awsSecretsmanagerAccessKey:\n # awsSecretsmanagerSecretKey:\n # awsSecretsmanagerSessionToken:\n\n ## Secrets for CF OAuth\n # cfClientId:\n # cfClientSecret:\n # cfCaCert: |-\n\n ## Secrets for GitHub OAuth.\n ##\n # githubClientId:\n # githubClientSecret:\n # githubCaCert: |-\n\n ## Secrets for GitLab OAuth.\n ##\n # gitlabClientId:\n # gitlabClientSecret:\n\n ## Secrets for LDAP Auth.\n ##\n # ldapCaCert: |-\n\n ## Secrets for generic OAuth.\n ##\n # oauthClientId:\n # oauthClientSecret:\n # oauthCaCert: |-\n\n ## Secrets for oidc OAuth.\n ##\n # oidcClientId:\n # oidcClientSecret:\n # oidcCaCert: |-\n\n ## Secrets for using Hashcorp Vault as a credential manager.\n ##\n ## if the Vault server is using a self-signed certificate, provide the CA public key.\n ## the value will be written to /concourse-vault/ca.cert\n ##\n # vaultCaCert: |-\n\n ## initial periodic token issued for concourse\n ## ref: https://www.vaultproject.io/docs/concepts/tokens.html#periodic-tokens\n ##\n # vaultClientToken:\n\n ## vault authentication parameters\n ## Paramter to pass when logging in via the backend\n ## Required for \"approle\" authenication method\n ## e.g. \"role_id=x,secret_id=x\"\n ## ref: https://concourse-ci.org/creds.html#vault-auth-param=NAME=VALUE\n ##\n # vaultAuthParam:\n\n ## provide the client certificate for authenticating with the [TLS](https://www.vaultproject.io/docs/auth/cert.html) backend\n ## the value will be written to /concourse-vault/client.cert\n ## make sure to also set credentialManager.vault.authBackend to `cert`\n ##\n # vaultClientCert: |-\n\n ## provide the client key for authenticating with the [TLS](https://www.vaultproject.io/docs/auth/cert.html) backend\n ## the value will be written to /concourse-vault/client.key\n ## make sure to also set credentialManager.vault.authBackend to `cert`\n ##\n # vaultClientKey: |-\n\n ## If influxdb metrics are enabled and authentication is required,\n ## provide a password here to authenticate with the influxdb server configured.\n ##\n # influxdbPassword:\n\n ## SSL certificate used to verify the Syslog server for draining build logs.\n # syslogCaCert: |-\n", 6 "upstream": "https://github.com/helm/charts/tree/0662ec9efe30dda63467bf19ae00217472b1385c/stable/concourse", 7 "metadata": { 8 "applicationType": "helm", 9 "sequence": 0, 10 "icon": "https://avatars1.githubusercontent.com/u/7809479", 11 "name": "concourse", 12 "releaseNotes": "[stable/concourse] Allow namespace creation independently of rbac (#10786)\n\n* Allow namespace creation independently of rbac\n\nAt the moment, when defining `concourse.web.kubernetes.teams`, the helm\nchart will take care of namespace generation. Although this is very\nuseful in most cases, we believe some people may find it problematic.\n\nOur use case, is to create the namespaces ahead of time and fill them\nwith `Pipeline` type resources defining Concourse pipelines. These are\nthen picked by our `pipeline-operator` and continuously applied to\nConcourse for specific teams.\n\nA hacky way around it, would be to set the\n`concourse.web.kubernetes.teams` value to an empty array, and create the\nrole bindings manually. It feels a little like cheating, and a cleaner\nway to accomplish that would be to have a separate flag responsible for\nnamespace creation in the Concourse helm chart.\n\nSigned-off-by: Rafal Proszowski \u003cparoxp@gmail.com\u003e\n\n* Bump patch\n\nSigned-off-by: Rafal Proszowski \u003cparoxp@gmail.com\u003e", 13 "version": "3.7.2", 14 "license": { 15 "id": "", 16 "assignee": "", 17 "createdAt": "0001-01-01T00:00:00Z", 18 "expiresAt": "0001-01-01T00:00:00Z", 19 "type": "" 20 } 21 }, 22 "upstreamContents": { 23 "upstreamFiles": [ 24 { 25 "filePath": ".helmignore", 26 "fileContents": "IyBQYXR0ZXJucyB0byBpZ25vcmUgd2hlbiBidWlsZGluZyBwYWNrYWdlcy4KIyBUaGlzIHN1cHBvcnRzIHNoZWxsIGdsb2IgbWF0Y2hpbmcsIHJlbGF0aXZlIHBhdGggbWF0Y2hpbmcsIGFuZAojIG5lZ2F0aW9uIChwcmVmaXhlZCB3aXRoICEpLiBPbmx5IG9uZSBwYXR0ZXJuIHBlciBsaW5lLgouRFNfU3RvcmUKIyBDb21tb24gVkNTIGRpcnMKLmdpdC8KLmdpdGlnbm9yZQouYnpyLwouYnpyaWdub3JlCi5oZy8KLmhnaWdub3JlCi5zdm4vCiMgQ29tbW9uIGJhY2t1cCBmaWxlcwoqLnN3cAoqLmJhawoqLnRtcAoqfgojIFZhcmlvdXMgSURFcwoucHJvamVjdAouaWRlYS8KKi50bXByb2oK" 27 }, 28 { 29 "filePath": "Chart.yaml", 30 "fileContents": "bmFtZTogY29uY291cnNlCnZlcnNpb246IDMuNy4yCmFwcFZlcnNpb246IDQuMi4yCmRlc2NyaXB0aW9uOiBDb25jb3Vyc2UgaXMgYSBzaW1wbGUgYW5kIHNjYWxhYmxlIENJIHN5c3RlbS4KaWNvbjogaHR0cHM6Ly9hdmF0YXJzMS5naXRodWJ1c2VyY29udGVudC5jb20vdS83ODA5NDc5CmtleXdvcmRzOgotIGNpCi0gY29uY291cnNlCi0gY29uY291cnNlLmNpCmhvbWU6IGh0dHBzOi8vY29uY291cnNlLWNpLm9yZy8Kc291cmNlczoKLSBodHRwczovL2dpdGh1Yi5jb20vY29uY291cnNlL2NvbmNvdXJzZQotIGh0dHBzOi8vZ2l0aHViLmNvbS9oZWxtL2NoYXJ0cwptYWludGFpbmVyczoKLSBuYW1lOiBjaXJvY29zdGEKICBlbWFpbDogY3Njb3N0YUBwaXZvdGFsLmlvCi0gbmFtZTogd2lsbGlhbS10cmFuCiAgZW1haWw6IHdpbGxAYXV0b25vbWljLmFpCmVuZ2luZTogZ290cGwK" 31 }, 32 { 33 "filePath": "OWNERS", 34 "fileContents": "YXBwcm92ZXJzOgotIGNpcm9jb3N0YQotIHdpbGxpYW0tdHJhbgpyZXZpZXdlcnM6Ci0gY2lyb2Nvc3RhCi0gd2lsbGlhbS10cmFuCg==" 35 }, 36 { 37 "filePath": "README.md", 38 "fileContents": "# Concourse Helm Chart

[Concourse](https://concourse-ci.org/) is a simple and scalable CI system.

## TL;DR;

```console
$ helm install stable/concourse
```

## Introduction

This chart bootstraps a [Concourse](https://concourse-ci.org/) deployment on a [Kubernetes](https://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager.

## Prerequisites Details

* Kubernetes 1.6 (for `pod affinity` support)
* PV support on underlying infrastructure (if persistence is required)

## Installing the Chart

To install the chart with the release name `my-release`:

```console
$ helm install --name my-release stable/concourse
```

## Uninstalling the Chart

To uninstall/delete the `my-release` deployment:

```console
$ helm delete my-release
```

The command removes nearly all the Kubernetes components associated with the chart and deletes the release.

### Cleanup orphaned Persistent Volumes

This chart uses `StatefulSets` for Concourse Workers. Deleting a `StatefulSet` does not delete associated Persistent Volumes.

Do the following after deleting the chart release to clean up orphaned Persistent Volumes.

```console
$ kubectl delete pvc -l app=${RELEASE-NAME}-worker
```

## Scaling the Chart

Scaling should typically be managed via the `helm upgrade` command, but `StatefulSets` don't yet work with `helm upgrade`. In the meantime, until `helm upgrade` works, if you want to change the number of replicas, you can use the `kubectl scale` command as shown below:

```console
$ kubectl scale statefulset my-release-worker --replicas=3
```

### Restarting workers

If a worker isn't taking on work, you can restart the worker with `kubectl delete pod`. This initiates a graceful shutdown by "retiring" the worker, to ensure Concourse doesn't try looking for old volumes on the new worker. The value`worker.terminationGracePeriodSeconds` can be used to provide an upper limit on graceful shutdown time before forcefully terminating the container. Check the output of `fly workers`, and if a worker is `stalled`, you'll also need to run `fly prune-worker` to allow the new incarnation of the worker to start.

### Worker Liveness Probe

The worker's Liveness Probe will trigger a restart of the worker if it detects unrecoverable errors, by looking at the worker's logs. The set of strings used to identify such errors could change in the future, but can be tuned with `worker.fatalErrors`. See [values.yaml](values.yaml) for the defaults.

## Configuration

The following table lists the configurable parameters of the Concourse chart and their default values.

| Parameter               | Description                           | Default                                                    |
| ----------------------- | ----------------------------------    | ---------------------------------------------------------- |
| `image` | Concourse image | `concourse/concourse` |
| `imageTag` | Concourse image version | `4.2.2` |
| `imagePullPolicy` | Concourse image pull policy | `IfNotPresent` |
| `imagePullSecrets` | Array of imagePullSecrets in the namespace for pulling images | `[]` |
| `web.additionalAffinities` | Additional affinities to apply to web pods. E.g: node affinity | `{}` |
| `web.additionalVolumeMounts` | VolumeMounts to be added to the web pods | `nil` |
| `web.additionalVolumes` | Volumes to be added to the web pods | `nil` |
| `web.annotations`| Concourse Web deployment annotations | `nil` |
| `web.authSecretsPath` | Specify the mount directory of the web auth secrets | `/concourse-auth` |
| `web.env` | Configure additional environment variables for the web containers | `[]` |
| `web.ingress.annotations` | Concourse Web Ingress annotations | `{}` |
| `web.ingress.enabled` | Enable Concourse Web Ingress | `false` |
| `web.ingress.hosts` | Concourse Web Ingress Hostnames | `[]` |
| `web.ingress.tls` | Concourse Web Ingress TLS configuration | `[]` |
| `web.keysSecretsPath` | Specify the mount directory of the web keys secrets | `/concourse-keys` |
| `web.livenessProbe` | Liveness Probe settings | `{"failureThreshold":5,"httpGet":{"path":"/api/v1/info","port":"atc"},"initialDelaySeconds":10,"periodSeconds":15,"timeoutSeconds":3}` |
| `web.nameOverride` | Override the Concourse Web components name | `nil` |
| `web.nodeSelector` | Node selector for web nodes | `{}` |
| `web.postgresqlSecrtsPath` | Specify the mount directory of the web postgresql secrets | `/concourse-postgresql` |
| `web.readinessProbe` | Readiness Probe settings | `{"httpGet":{"path":"/api/v1/info","port":"atc"}}` |
| `web.replicas` | Number of Concourse Web replicas | `1` |
| `web.resources` | Concourse Web resource requests and limits | `{requests: {cpu: "100m", memory: "128Mi"}}` |
| `web.service.annotations` | Concourse Web Service annotations | `nil` |
| `web.service.atcNodePort` | Sets the nodePort for atc when using `NodePort` | `nil` |
| `web.service.atcTlsNodePort` | Sets the nodePort for atc tls when using `NodePort` | `nil` |
| `web.service.labels` | Additional concourse web service labels | `nil` |
| `web.service.loadBalancerIP` | The IP to use when web.service.type is LoadBalancer | `nil` |
| `web.service.loadBalancerSourceRanges` | Concourse Web Service Load Balancer Source IP ranges | `nil` |
| `web.service.tsaNodePort` | Sets the nodePort for tsa when using `NodePort` | `nil` |
| `web.service.type` | Concourse Web service type | `ClusterIP` |
| `web.syslogSecretsPath` | Specify the mount directory of the web syslog secrets | `/concourse-syslog` |
| `web.tolerations` | Tolerations for the web nodes | `[]` |
| `web.vaultSecretsPath` | Specify the mount directory of the web vault secrets | `/concourse-vault` |
| `worker.nameOverride` | Override the Concourse Worker components name | `nil` |
| `worker.replicas` | Number of Concourse Worker replicas | `2` |
| `worker.minAvailable` | Minimum number of workers available after an eviction | `1` |
| `worker.resources` | Concourse Worker resource requests and limits | `{requests: {cpu: "100m", memory: "512Mi"}}` |
| `worker.env` | Configure additional environment variables for the worker container(s) | `[]` |
| `worker.annotations` | Annotations to be added to the worker pods | `{}` |
| `worker.keysSecretsPath` | Specify the mount directory of the worker keys secrets | `/concourse-keys` |
| `worker.additionalVolumeMounts` | VolumeMounts to be added to the worker pods | `nil` |
| `worker.additionalVolumes` | Volumes to be added to the worker pods | `nil` |
| `worker.additionalAffinities` | Additional affinities to apply to worker pods. E.g: node affinity | `{}` |
| `worker.tolerations` | Tolerations for the worker nodes | `[]` |
| `worker.terminationGracePeriodSeconds` | Upper bound for graceful shutdown to allow the worker to drain its tasks | `60` |
| `worker.fatalErrors` | Newline delimited strings which, when logged, should trigger a restart of the worker | *See [values.yaml](values.yaml)* |
| `worker.updateStrategy` | `OnDelete` or `RollingUpdate` (requires Kubernetes >= 1.7) | `RollingUpdate` |
| `worker.podManagementPolicy` | `OrderedReady` or `Parallel` (requires Kubernetes >= 1.7) | `Parallel` |
| `worker.hardAntiAffinity` | Should the workers be forced (as opposed to preferred) to be on different nodes? | `false` |
| `worker.emptyDirSize` | When persistance is disabled this value will be used to limit the emptyDir volume size | `nil` |
| `persistence.enabled` | Enable Concourse persistence using Persistent Volume Claims | `true` |
| `persistence.worker.storageClass` | Concourse Worker Persistent Volume Storage Class | `generic` |
| `persistence.worker.accessMode` | Concourse Worker Persistent Volume Access Mode | `ReadWriteOnce` |
| `persistence.worker.size` | Concourse Worker Persistent Volume Storage Size | `20Gi` |
| `postgresql.enabled` | Enable PostgreSQL as a chart dependency | `true` |
| `postgresql.postgresUser` | PostgreSQL User to create | `concourse` |
| `postgresql.postgresPassword` | PostgreSQL Password for the new user | `concourse` |
| `postgresql.postgresDatabase` | PostgreSQL Database to create | `concourse` |
| `postgresql.persistence.enabled` | Enable PostgreSQL persistence using Persistent Volume Claims | `true` |
| `rbac.create` | Enables creation of RBAC resources | `true` |
| `rbac.apiVersion` | RBAC version | `v1beta1` |
| `rbac.webServiceAccountName` | Name of the service account to use for web pods if `rbac.create` is `false` | `default` |
| `rbac.workerServiceAccountName` | Name of the service account to use for workers if `rbac.create` is `false` | `default` |
| `secrets.create` | Create the secret resource from the following values. *See [Secrets](#secrets)* | `true` |
| `secrets.awsSsmAccessKey` | AWS Access Key ID for SSM access | `nil` |
| `secrets.awsSsmSecretKey` | AWS Secret Access Key ID for SSM access | `nil` |
| `secrets.awsSsmSessionToken` | AWS Session Token for SSM access | `nil` |
| `secrets.cfCaCert` | CA certificate for cf auth provider | `nil` |
| `secrets.cfClientId` | Client ID for cf auth provider | `nil` |
| `secrets.cfClientSecret` | Client secret for cf auth provider | `nil` |
| `secrets.encryptionKey` | current encryption key | `nil` |
| `secrets.githubCaCert` | CA certificate for Enterprise Github OAuth | `nil` |
| `secrets.githubClientId` | Application client ID for GitHub OAuth | `nil` |
| `secrets.githubClientSecret` | Application client secret for GitHub OAuth | `nil` |
| `secrets.gitlabClientId` | Application client ID for GitLab OAuth | `nil` |
| `secrets.gitlabClientSecret` | Application client secret for GitLab OAuth | `nil` |
| `secrets.hostKeyPub` | Concourse Host Public Key | *See [values.yaml](values.yaml)* |
| `secrets.hostKey` | Concourse Host Private Key | *See [values.yaml](values.yaml)* |
| `secrets.influxdbPassword` | Password used to authenticate with influxdb | `nil` |
| `secrets.localUsers` | Create concourse local users. Default username and password are `test:test` *See [values.yaml](values.yaml)* |
| `secrets.oauthCaCert` | CA certificate for Generic OAuth | `nil` |
| `secrets.oauthClientId` | Application client ID for Generic OAuth | `nil` |
| `secrets.oauthClientSecret` | Application client secret for Generic OAuth | `nil` |
| `secrets.oidcCaCert` | CA certificate for OIDC Oauth | `nil` |
| `secrets.oidcClientId` | Application client ID for OIDI OAuth | `nil` |
| `secrets.oidcClientSecret` | Application client secret for OIDC OAuth | `nil` |
| `secrets.oldEncryptionKey` | old encryption key, used for key rotation | `nil` |
| `secrets.postgresqlCaCert` | PostgreSQL CA certificate | `nil` |
| `secrets.postgresqlClientCert` | PostgreSQL Client certificate | `nil` |
| `secrets.postgresqlClientKey` | PostgreSQL Client key | `nil` |
| `secrets.postgresqlPassword` | PostgreSQL User Password | `nil` |
| `secrets.postgresqlUser` | PostgreSQL User Name | `nil` |
| `secrets.sessionSigningKey` | Concourse Session Signing Private Key | *See [values.yaml](values.yaml)* |
| `secrets.syslogCaCert` | SSL certificate to verify Syslog server | `nil` |
| `secrets.vaultAuthParam` | Paramter to pass when logging in via the backend | `nil` |
| `secrets.vaultCaCert` | CA certificate use to verify the vault server SSL cert | `nil` |
| `secrets.vaultClientCert` | Vault Client Certificate | `nil` |
| `secrets.vaultClientKey` | Vault Client Key | `nil` |
| `secrets.vaultClientToken` | Vault periodic client token | `nil` |
| `secrets.webTlsCert` | TLS certificate for the web component to terminate TLS connections | `nil` |
| `secrets.webTlsKey` | An RSA private key, used to encrypt HTTPS traffic  | `nil` |
| `secrets.workerKeyPub` | Concourse Worker Public Key | *See [values.yaml](values.yaml)* |
| `secrets.workerKey` | Concourse Worker Private Key | *See [values.yaml](values.yaml)* |

For configurable concourse parameters, refer to [values.yaml](values.yaml) `concourse` section. All parameters under this section are strictly mapped from concourse binary commands. For example if one needs to configure the concourse external URL, the param `concourse` -> `web` -> `externalUrl` should be set, which is equivalent to running concourse binary as `concourse web --external-url`. For those sub-sections that have `enabled`, one needs to set `enabled` to be `true` to use the following params within the section.

Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`.

Alternatively, a YAML file that specifies the values for the parameters can be provided while installing the chart. For example,

```console
$ helm install --name my-release -f values.yaml stable/concourse
```

> **Tip**: You can use the default [values.yaml](values.yaml)

### Secrets

For your convenience, this chart provides some default values for secrets, but it is recommended that you generate and manage these secrets outside the Helm chart. To do this, set `secrets.create` to `false`, create files for each secret value, and turn it all into a k8s secret. Be careful with introducing trailing newline characters; following the steps below ensures none end up in your secrets. First, perform the following to create the mandatory secret values:

```console
mkdir concourse-secrets
cd concourse-secrets
ssh-keygen -t rsa -f host-key  -N ''
mv host-key.pub host-key-pub
ssh-keygen -t rsa -f worker-key  -N ''
mv worker-key.pub worker-key-pub
ssh-keygen -t rsa -f session-signing-key  -N ''
rm session-signing-key.pub
printf "%s:%s" "concourse" "$(openssl rand -base64 24)" > local-users
```

You'll also need to create/copy secret values for optional features. See [templates/secrets.yaml](templates/secrets.yaml) for possible values. In the example below, we are not using the [PostgreSQL](#postgresql) chart dependency, and so we must set `postgresql-user` and `postgresql-password` secrets.

```console
# copy a posgres user to clipboard and paste it to file
printf "%s" "$(pbpaste)" > postgresql-user
# copy a posgres password to clipboard and paste it to file
printf "%s" "$(pbpaste)" > postgresql-password

# copy Github client id and secrets to clipboard and paste to files
printf "%s" "$(pbpaste)" > github-client-id
printf "%s" "$(pbpaste)" > github-client-secret

# set an encryption key for DB encryption at rest
printf "%s" "$(openssl rand -base64 24)" > encryption-key
```

Then create a secret called `[release-name]-concourse` from all the secret value files in the current folder:

```console
kubectl create secret generic my-release-concourse --from-file=.
```

Make sure you clean up after yourself.

### Persistence

This chart mounts a Persistent Volume for each Concourse Worker. The volume is created using dynamic volume provisioning. If you want to disable it or change the persistence properties, update the `persistence` section of your custom `values.yaml` file:

```yaml
## Persistent Volume Storage configuration.
## ref: https://kubernetes.io/docs/user-guide/persistent-volumes
##
persistence:
  ## Enable persistence using Persistent Volume Claims.
  ##
  enabled: true

  ## Worker Persistence configuration.
  ##
  worker:
    ## Persistent Volume Storage Class.
    ##
    class: generic

    ## Persistent Volume Access Mode.
    ##
    accessMode: ReadWriteOnce

    ## Persistent Volume Storage Size.
    ##
    size: "20Gi"
```

It is highly recommended to use Persistent Volumes for Concourse Workers; otherwise, the container images managed by the Worker are stored in an `emptyDir` volume on the node's disk. This will interfere with k8s ImageGC and the node's disk will fill up as a result. This will be fixed in a future release of k8s: https://github.com/kubernetes/kubernetes/pull/57020

### Ingress TLS

If your cluster allows automatic creation/retrieval of TLS certificates (e.g. [kube-lego](https://github.com/jetstack/kube-lego)), please refer to the documentation for that mechanism.

To manually configure TLS, first create/retrieve a key & certificate pair for the address(es) you wish to protect. Then create a TLS secret in the namespace:

```console
kubectl create secret tls concourse-web-tls --cert=path/to/tls.cert --key=path/to/tls.key
```

Include the secret's name, along with the desired hostnames, in the `web.ingress.tls` section of your custom `values.yaml` file:

```yaml
## Configuration values for Concourse Web components.
##
web:
  ## Ingress configuration.
  ## ref: https://kubernetes.io/docs/user-guide/ingress/
  ##
  ingress:
    ## Enable ingress.
    ##
    enabled: true

    ## Hostnames.
    ## Must be provided if Ingress is enabled.
    ##
    hosts:
      - concourse.domain.com

    ## TLS configuration.
    ## Secrets must be manually created in the namespace.
    ##
    tls:
      - secretName: concourse-web-tls
        hosts:
          - concourse.domain.com
```

### PostgreSQL

By default, this chart uses a PostgreSQL database deployed as a chart dependency, with default values for username, password, and database name. These can be modified by setting the `postgresql.*` values.

You can also bring your own PostgreSQL. To do so, set `postgresql.enabled` to false, and then configure Concourse's `postgres` values (`concourse.web.postgres.*`).

Note that some values get set in the form of secrets, like `postgresql-user`, `postgresql-password`, and others (see [templates/secrets.yaml](templates/secrets.yaml) for possible values and the [secrets section](#secrets) on this README for guidance on how to set those secrets).


### Credential Management

Pipelines usually need credentials to do things. Concourse supports the use of a [Credential Manager](https://concourse-ci.org/creds.html) so your pipelines can contain references to secrets instead of the actual secret values. You can't use more than one credential manager at a time.

#### Kubernetes Secrets

By default, this chart uses Kubernetes Secrets as a credential manager. 

For a given Concourse *team*, a pipeline looks for secrets in a namespace named `[namespacePrefix][teamName]`. The namespace prefix is the release name followed by a hyphen by default, and can be overridden with the value `concourse.web.kubernetes.namespacePrefix`. Each team listed under `concourse.web.kubernetes.teams` will have a namespace created for it, and the namespace remains after deletion of the release unless you set `concourse.web.kubernetes.keepNamespace` to `false`. By default, a namespace will be created for the `main` team.

The service account used by Concourse must have `get` access to secrets in that namespace. When `rbac.create` is true, this access is granted for each team listed under `concourse.web.kubernetes.teams`.

Here are some examples of the lookup heuristics, given release name `concourse`:

In team `accounting-dev`, pipeline `my-app`; the expression `((api-key))` resolves to:

1. the secret value in namespace: `concourse-accounting-dev` secret: `my-app.api-key`, key: `value`
2. and if not found, is the value in namespace: `concourse-accounting-dev` secret: `api-key`, key: `value`

In team accounting-dev, pipeline `my-app`, the expression `((common-secrets.api-key))` resolves to:

1. the secret value in namespace: `concourse-accounting-dev` secret: `my-app.common-secrets`, key: `api-key`
2. and if not found, is the value in namespace: `concourse-accounting-dev` secret: `common-secrets`, key: `api-key`

Be mindful of your team and pipeline names, to ensure they can be used in namespace and secret names, e.g. no underscores.

To test, create a secret in namespace `concourse-main`:

```console
kubectl create secret generic hello --from-literal 'value=Hello world!'
```

Then `fly set-pipeline` with the following pipeline, and trigger it:

```yaml
jobs:
- name: hello-world
  plan:
  - task: say-hello
    config:
      platform: linux
      image_resource:
        type: docker-image
        source: {repository: alpine}
      params:
        HELLO: ((hello))
      run:
        path: /bin/sh
        args: ["-c", "echo $HELLO"]
```

#### Hashicorp Vault

To use Vault, set `concourse.web.kubernetes.enabled` to false, and set the following values:


```yaml
## Configuration values for the Credential Manager.
## ref: https://concourse-ci.org/creds.html
##
concourse:
  web:
    vault:
      ## Use Hashicorp Vault for the Credential Manager.
      ##
      enabled: false

      ## URL pointing to vault addr (i.e. http://vault:8200).
      ##
      # url:

      ## vault path under which to namespace credential lookup, defaults to /concourse.
      ##
      # pathPrefix:
```

#### AWS Systems Manager Parameter Store (SSM)

To use SSM, set `concourse.web.kubernetes.enabled` to false, and set `concourse.web.awsSsm.enabled` to true.

For a given Concourse *team*, a pipeline looks for secrets in SSM using either `/concourse/{team}/{secret}` or `/concourse/{team}/{pipeline}/{secret}`; the patterns can be overridden using the `concourse.web.awsSsm.teamSecretTemplate` and `concourse.web.awsSsm.pipelineSecretTemplate` settings.

Concourse requires AWS credentials which are able to read from SSM for this feature to function. Credentials can be set in the `secrets.awsSsm*` settings; if your cluster is running in a different AWS region, you may also need to set `concourse.web.awsSsm.region`.

The minimum IAM policy you need to use SSM with Concourse is:

```json
{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Action": "kms:Decrypt",
      "Resource": "<kms-key-arn>",
      "Effect": "Allow"
    },
    {
      "Action": "ssm:GetParameter*",
      "Resource": "<...arn...>:parameter/concourse/*",
      "Effect": "Allow"
    }
  ]
}
```

Where `<kms-key-arn>` is the ARN of the KMS key used to encrypt the secrets in Parameter Store, and the `<...arn...>` should be replaced with a correct ARN for your account and region's Parameter Store.

#### AWS Secrets Manager

To use Secrets Manager, set `concourse.web.kubernetes.enabled` to false, and set `concourse.web.awsSecretsManager.enabled` to true.

For a given Concourse *team*, a pipeline looks for secrets in Secrets Manager using either `/concourse/{team}/{secret}` or `/concourse/{team}/{pipeline}/{secret}`; the patterns can be overridden using the `concourse.web.awsSecretsManager.teamSecretTemplate` and `concourse.web.awsSecretsManager.pipelineSecretTemplate` settings.

Concourse requires AWS credentials which are able to read from Secrets Manager for this feature to function. Credentials can be set in the `secrets.awsSecretsmanager*` settings; if your cluster is running in a different AWS region, you may also need to set `concourse.web.awsSecretsManager.region`.

The minimum IAM policy you need to use Secrets Manager with Concourse is:

```json
{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Sid": "AllowAccessToSecretManagerParameters",
      "Effect": "Allow",
      "Action": [
        "secretsmanager:ListSecrets"
      ],
      "Resource": "*"
    },
    {
      "Sid": "AllowAccessGetSecret",
      "Effect": "Allow",
      "Action": [
        "secretsmanager:GetSecretValue",
        "secretsmanager:DescribeSecret"
      ],
      "Resource": [
        "arn:aws:secretsmanager:::secret:/concourse/*"
      ]
    }
  ]
}
```
" 39 }, 40 { 41 "filePath": "more-config.yaml", 42 "fileContents": "d2ViOgogIGFkZGl0aW9uYWxWb2x1bWVzOgogIC0gbmFtZTogdGVhbS1hdXRob3JpemVkLWtleXMKICAgIGNvbmZpZ01hcDoKICAgICAgbmFtZTogaHVzaC1ob3VzZS10ZWFtLWF1dGhvcml6ZWQta2V5cwogIGFkZGl0aW9uYWxWb2x1bWVNb3VudHM6CiAgLSBuYW1lOiB0ZWFtLWF1dGhvcml6ZWQta2V5cwogICAgbW91bnRQYXRoOiAvdGVhbS1hdXRob3JpemVkLWtleXMvCg==" 43 }, 44 { 45 "filePath": "requirements.lock", 46 "fileContents": "ZGVwZW5kZW5jaWVzOgotIG5hbWU6IHBvc3RncmVzcWwKICByZXBvc2l0b3J5OiBodHRwczovL2t1YmVybmV0ZXMtY2hhcnRzLnN0b3JhZ2UuZ29vZ2xlYXBpcy5jb20vCiAgdmVyc2lvbjogMC4xMy4xCmRpZ2VzdDogc2hhMjU2OjY1ZDM1ODg3OGU0OTZhYjFiNTE3MjFhNzZlMmFmNWI3ZmQzZTZiYjc2MzBiMWQ0MDJhZjY3YTE3YmY3ODJiYjQKZ2VuZXJhdGVkOiAyMDE4LTA1LTMxVDE2OjExOjQwLjY1NTc5NDA4OCswMTowMAo=" 47 }, 48 { 49 "filePath": "requirements.yaml", 50 "fileContents": "ZGVwZW5kZW5jaWVzOgotIG5hbWU6IHBvc3RncmVzcWwKICB2ZXJzaW9uOiAwLjEzLjEKICByZXBvc2l0b3J5OiBodHRwczovL2t1YmVybmV0ZXMtY2hhcnRzLnN0b3JhZ2UuZ29vZ2xlYXBpcy5jb20vCiAgY29uZGl0aW9uOiBwb3N0Z3Jlc3FsLmVuYWJsZWQK" 51 }, 52 { 53 "filePath": "templates/NOTES.txt", 54 "fileContents": "CiogQ29uY291cnNlIGNhbiBiZSBhY2Nlc3NlZDoKCiAgKiBXaXRoaW4geW91ciBjbHVzdGVyLCBhdCB0aGUgZm9sbG93aW5nIEROUyBuYW1lIGF0IHBvcnQge3sgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLmJpbmRQb3J0IH19OgoKICAgIHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAuIH19Lnt7IC5SZWxlYXNlLk5hbWVzcGFjZSB9fS5zdmMuY2x1c3Rlci5sb2NhbAoKICB7ey0gaWYgLlZhbHVlcy53ZWIuaW5ncmVzcy5lbmFibGVkIH19CgogICogRnJvbSBvdXRzaWRlIHRoZSBjbHVzdGVyLCB0aGUgVVJMKHMpIGFyZToKICAgIHt7IHJhbmdlIC5WYWx1ZXMud2ViLmluZ3Jlc3MuaG9zdHMgfX0KICAgIGh0dHA6Ly97eyAuIH19CiAgICB7ey0gZW5kIH19CiAge3stIGVsc2UgfX0KCiAgKiBGcm9tIG91dHNpZGUgdGhlIGNsdXN0ZXIsIHJ1biB0aGVzZSBjb21tYW5kcyBpbiB0aGUgc2FtZSBzaGVsbDoKICAgIHt7LSBpZiBjb250YWlucyAiTm9kZVBvcnQiIC5WYWx1ZXMud2ViLnNlcnZpY2UudHlwZSB9fQoKICAgIGV4cG9ydCBOT0RFX1BPUlQ9JChrdWJlY3RsIGdldCAtLW5hbWVzcGFjZSB7eyAuUmVsZWFzZS5OYW1lc3BhY2UgfX0gLW8ganNvbnBhdGg9Insuc3BlYy5wb3J0c1swXS5ub2RlUG9ydH0iIHNlcnZpY2VzIHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAuIH19KQogICAgZXhwb3J0IE5PREVfSVA9JChrdWJlY3RsIGdldCBub2RlcyAtLW5hbWVzcGFjZSB7eyAuUmVsZWFzZS5OYW1lc3BhY2UgfX0gLW8ganNvbnBhdGg9InsuaXRlbXNbMF0uc3RhdHVzLmFkZHJlc3Nlc1swXS5hZGRyZXNzfSIpCiAgICBlY2hvIGh0dHA6Ly8kTk9ERV9JUDokTk9ERV9QT1JUCiAgICB7ey0gZWxzZSBpZiBjb250YWlucyAiTG9hZEJhbGFuY2VyIiAuVmFsdWVzLndlYi5zZXJ2aWNlLnR5cGUgfX0KCiAgICAgTk9URTogSXQgbWF5IHRha2UgYSBmZXcgbWludXRlcyBmb3IgdGhlIExvYWRCYWxhbmNlciBJUCB0byBiZSBhdmFpbGFibGUuCiAgICAgICAgICAgWW91IGNhbiB3YXRjaCB0aGUgc3RhdHVzIG9mIGJ5IHJ1bm5pbmcgJ2t1YmVjdGwgZ2V0IHN2YyAtdyB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndlYi5mdWxsbmFtZSIgLiB9fScKCiAgICBleHBvcnQgU0VSVklDRV9JUD0kKGt1YmVjdGwgZ2V0IHN2YyAtLW5hbWVzcGFjZSB7eyAuUmVsZWFzZS5OYW1lc3BhY2UgfX0ge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53ZWIuZnVsbG5hbWUiIC4gfX0gLW8ganNvbnBhdGg9J3suc3RhdHVzLmxvYWRCYWxhbmNlci5pbmdyZXNzWzBdLmlwfScpCiAgICBlY2hvIGh0dHA6Ly8kU0VSVklDRV9JUDp7eyAuVmFsdWVzLmNvbmNvdXJzZS53ZWIuYmluZFBvcnQgfX0KICAgIHt7LSBlbHNlIGlmIGNvbnRhaW5zICJDbHVzdGVySVAiICAuVmFsdWVzLndlYi5zZXJ2aWNlLnR5cGUgfX0KCiAgICBleHBvcnQgUE9EX05BTUU9JChrdWJlY3RsIGdldCBwb2RzIC0tbmFtZXNwYWNlIHt7IC5SZWxlYXNlLk5hbWVzcGFjZSB9fSAtbCAiYXBwPXt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAuIH19IiAtbyBqc29ucGF0aD0iey5pdGVtc1swXS5tZXRhZGF0YS5uYW1lfSIpCiAgICBlY2hvICJWaXNpdCBodHRwOi8vMTI3LjAuMC4xOjgwODAgdG8gdXNlIENvbmNvdXJzZSIKICAgIGt1YmVjdGwgcG9ydC1mb3J3YXJkIC0tbmFtZXNwYWNlIHt7IC5SZWxlYXNlLk5hbWVzcGFjZSB9fSAkUE9EX05BTUUgODA4MDp7eyAuVmFsdWVzLmNvbmNvdXJzZS53ZWIuYmluZFBvcnQgfX0KICAgIHt7LSBlbmQgfX0KICB7ey0gZW5kIH19CiogSWYgdGhpcyBpcyB5b3VyIGZpcnN0IHRpbWUgdXNpbmcgQ29uY291cnNlLCBmb2xsb3cgdGhlIHR1dG9yaWFscyBhdCBodHRwczovL2NvbmNvdXJzZS1jaS5vcmcvdHV0b3JpYWxzLmh0bWwKCnt7LSBpZiBjb250YWlucyAibmFpdmUiIC5WYWx1ZXMuY29uY291cnNlLndvcmtlci5iYWdnYWdlY2xhaW0uZHJpdmVyIH19CgoqKioqKioqKioqKioqKioqKioqCioqKioqKldBUk5JTkcqKioqKioKKioqKioqKioqKioqKioqKioqKgoKWW91IGFyZSB1c2luZyB0aGUgIm5haXZlIiBiYWdnYWdlIGNsYWltIGRyaXZlciwgd2hpY2ggaXMgYWxzbyB0aGUgZGVmYXVsdCB2YWx1ZSBmb3IgdGhpcyBjaGFydC4gCgpUaGlzIGlzIHRoZSBkZWZhdWx0IGZvciBjb21wYXRpYmlsaXR5IHJlYXNvbnMsIGJ1dCBpcyB2ZXJ5IHNwYWNlIGluZWZmaWNpZW50LCBhbmQgc2hvdWxkIGJlIGNoYW5nZWQgdG8gZWl0aGVyICJidHJmcyIgKHJlY29tbWVuZGVkKSBvciAib3ZlcmxheSIgZGVwZW5kaW5nIG9uIHRoYXQgZmlsZXN5c3RlbSdzIHN1cHBvcnQgaW4gdGhlIExpbnV4IGtlcm5lbCB5b3VyIGNsdXN0ZXIgaXMgdXNpbmcuIAoKUGxlYXNlIHNlZSBodHRwczovL2dpdGh1Yi5jb20vY29uY291cnNlL2NvbmNvdXJzZS9pc3N1ZXMvMTIzMCBhbmQgaHR0cHM6Ly9naXRodWIuY29tL2NvbmNvdXJzZS9jb25jb3Vyc2UvaXNzdWVzLzE5NjYgZm9yIGJhY2tncm91bmQuCgp7ey0gZW5kIH19CgoKCnt7LSBpZiAuVmFsdWVzLmNvbmNvdXJzZS53ZWIubG9jYWxBdXRoLmVuYWJsZWQgfX0Ke3stIGlmIGNvbnRhaW5zICJ0ZXN0OnRlc3QiIC5WYWx1ZXMuc2VjcmV0cy5sb2NhbFVzZXJzIH19CgoqKioqKioqKioqKioqKioqKioqCioqKioqKldBUk5JTkcqKioqKioKKioqKioqKioqKioqKioqKioqKgoKWW91J3JlIHVzaW5nIHRoZSBkZWZhdWx0ICJ0ZXN0IiB1c2VyIHdpdGggdGhlIGRlZmF1bHQgInRlc3QiIHBhc3N3b3JkLgoKTWFrZSBzdXJlIHlvdSBlaXRoZXIgZGlzYWJsZSBsb2NhbCBhdXRoIG9yIGNoYW5nZSB0aGUgY29tYmluYXRpb24gdG8gc29tZXRoaW5nIG1vcmUgc2VjdXJlLCBwcmVmZXJhYmx5IHNwZWNpZnlpbmcgYSBwYXNzd29yZCBpbiB0aGUgYmNyeXB0ZWQgZm9ybS4KClBsZWFzZSBzZWUgYFJFQURNRS5tZGAgZm9yIGV4YW1wbGVzLgoKe3stIGVuZCB9fQp7ey0gZW5kIH19Cg==" 55 }, 56 { 57 "filePath": "templates/_helpers.tpl", 58 "fileContents": "e3svKiB2aW06IHNldCBmaWxldHlwZT1tdXN0YWNoZTogKi99fQp7ey8qCkV4cGFuZCB0aGUgbmFtZSBvZiB0aGUgY2hhcnQuCiovfX0Ke3stIGRlZmluZSAiY29uY291cnNlLm5hbWUiIC19fQp7ey0gZGVmYXVsdCAuQ2hhcnQuTmFtZSAuVmFsdWVzLm5hbWVPdmVycmlkZSB8IHRydW5jIDYzIHwgdHJpbVN1ZmZpeCAiLSIgLX19Cnt7LSBlbmQgLX19Cgp7ey8qCkNyZWF0ZSBhIGRlZmF1bHQgZnVsbHkgcXVhbGlmaWVkIGNvbmNvdXJzZSBuYW1lLgpXZSB0cnVuY2F0ZSBhdCA2MyBjaGFycyBiZWNhdXNlIHNvbWUgS3ViZXJuZXRlcyBuYW1lIGZpZWxkcyBhcmUgbGltaXRlZCB0byB0aGlzIChieSB0aGUgRE5TIG5hbWluZyBzcGVjKS4KKi99fQp7ey0gZGVmaW5lICJjb25jb3Vyc2UuY29uY291cnNlLmZ1bGxuYW1lIiAtfX0Ke3stICRuYW1lIDo9IGRlZmF1bHQgLkNoYXJ0Lk5hbWUgLlZhbHVlcy5uYW1lT3ZlcnJpZGUgLX19Cnt7LSBwcmludGYgIiVzLSVzIiAuUmVsZWFzZS5OYW1lICRuYW1lIHwgdHJ1bmMgNjMgfCB0cmltU3VmZml4ICItIiAtfX0Ke3stIGVuZCAtfX0KCnt7LSBkZWZpbmUgImNvbmNvdXJzZS53ZWIuZnVsbG5hbWUiIC19fQp7ey0gJG5hbWUgOj0gZGVmYXVsdCAid2ViIiAuVmFsdWVzLndlYi5uYW1lT3ZlcnJpZGUgLX19Cnt7LSBwcmludGYgIiVzLSVzIiAuUmVsZWFzZS5OYW1lICRuYW1lIHwgdHJ1bmMgNjMgfCB0cmltU3VmZml4ICItIiAtfX0Ke3stIGVuZCAtfX0KCnt7LSBkZWZpbmUgImNvbmNvdXJzZS53b3JrZXIuZnVsbG5hbWUiIC19fQp7ey0gJG5hbWUgOj0gZGVmYXVsdCAid29ya2VyIiAuVmFsdWVzLndvcmtlci5uYW1lT3ZlcnJpZGUgLX19Cnt7LSBwcmludGYgIiVzLSVzIiAuUmVsZWFzZS5OYW1lICRuYW1lIHwgdHJ1bmMgNjMgfCB0cmltU3VmZml4ICItIiAtfX0Ke3stIGVuZCAtfX0KCnt7LyoKQ3JlYXRlIGEgZGVmYXVsdCBmdWxseSBxdWFsaWZpZWQgcG9zdGdyZXNxbCBuYW1lLgpXZSB0cnVuY2F0ZSBhdCA2MyBjaGFycyBiZWNhdXNlIHNvbWUgS3ViZXJuZXRlcyBuYW1lIGZpZWxkcyBhcmUgbGltaXRlZCB0byB0aGlzIChieSB0aGUgRE5TIG5hbWluZyBzcGVjKS4KKi99fQp7ey0gZGVmaW5lICJjb25jb3Vyc2UucG9zdGdyZXNxbC5mdWxsbmFtZSIgLX19Cnt7LSAkbmFtZSA6PSBkZWZhdWx0ICJwb3N0Z3Jlc3FsIiAuVmFsdWVzLnBvc3RncmVzcWwubmFtZU92ZXJyaWRlIC19fQp7ey0gcHJpbnRmICIlcy0lcyIgLlJlbGVhc2UuTmFtZSAkbmFtZSB8IHRydW5jIDYzIHwgdHJpbVN1ZmZpeCAiLSIgLX19Cnt7LSBlbmQgLX19Cgp7ey0gZGVmaW5lICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiAtfX0Ke3stIGlmIC5pcyB9fQp7ey0gcmVxdWlyZWQgKHByaW50ZiAic2VjcmV0cy4lcyBpcyByZXF1aXJlZCBiZWNhdXNlIHNlY3JldHMuY3JlYXRlIGlzIHRydWUgYW5kICVzIGlzIHRydWUiIC5rZXkgLmlzKSAoaW5kZXggLnJvb3QuVmFsdWVzLnNlY3JldHMgLmtleSApIHwgYjY0ZW5jIHwgcXVvdGUgfX0Ke3stIGVsc2UgLX19Cnt7LSByZXF1aXJlZCAocHJpbnRmICJzZWNyZXRzLiVzIGlzIHJlcXVpcmVkIGJlY2F1c2Ugc2VjcmV0cy5jcmVhdGUgaXMgdHJ1ZSBhbmQgJXMgaXNuJ3QgdHJ1ZSIgLmtleSAuaXNudCkgKGluZGV4IC5yb290LlZhbHVlcy5zZWNyZXRzIC5rZXkgKSB8IGI2NGVuYyB8IHF1b3RlIH19Cnt7LSBlbmQgLX19Cnt7LSBlbmQgLX19Cgp7ey0gZGVmaW5lICJjb25jb3Vyc2UubmFtZXNwYWNlUHJlZml4IiAtfX0Ke3stIGRlZmF1bHQgKHByaW50ZiAiJXMtIiAuUmVsZWFzZS5OYW1lICkgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLmt1YmVybmV0ZXMubmFtZXNwYWNlUHJlZml4IC19fQp7ey0gZW5kIC19fQo=" 59 }, 60 { 61 "filePath": "templates/namespace.yaml", 62 "fileContents": "e3stIGlmIGFuZCAuVmFsdWVzLmNvbmNvdXJzZS53ZWIua3ViZXJuZXRlcy5lbmFibGVkIC5WYWx1ZXMuY29uY291cnNlLndlYi5rdWJlcm5ldGVzLmNyZWF0ZVRlYW1OYW1lc3BhY2VzIC19fQp7ey0gcmFuZ2UgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLmt1YmVybmV0ZXMudGVhbXMgfX0KLS0tCmFwaVZlcnNpb246IHYxCmtpbmQ6IE5hbWVzcGFjZQptZXRhZGF0YToKe3stIGlmICQuVmFsdWVzLmNvbmNvdXJzZS53ZWIua3ViZXJuZXRlcy5rZWVwTmFtZXNwYWNlcyB9fQogIGFubm90YXRpb25zOgogICAgImhlbG0uc2gvcmVzb3VyY2UtcG9saWN5Ijoga2VlcAp7ey0gZW5kIH19CiAgbmFtZToge3sgdGVtcGxhdGUgImNvbmNvdXJzZS5uYW1lc3BhY2VQcmVmaXgiICQgfX17eyAuIH19CiAgbGFiZWxzOgogICAgYXBwOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLmNvbmNvdXJzZS5mdWxsbmFtZSIgJCB9fQogICAgY2hhcnQ6ICJ7eyAkLkNoYXJ0Lk5hbWUgfX0te3sgJC5DaGFydC5WZXJzaW9uIH19IgogICAgcmVsZWFzZTogInt7ICQuUmVsZWFzZS5OYW1lIH19IgogICAgaGVyaXRhZ2U6ICJ7eyAkLlJlbGVhc2UuU2VydmljZSB9fSIKe3stIGVuZCB9fQp7ey0gZW5kIC19fQo=" 63 }, 64 { 65 "filePath": "templates/secrets.yaml", 66 "fileContents": "e3stIGlmIC5WYWx1ZXMuc2VjcmV0cy5jcmVhdGUgfX0KYXBpVmVyc2lvbjogdjEKa2luZDogU2VjcmV0Cm1ldGFkYXRhOgogIG5hbWU6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2UuY29uY291cnNlLmZ1bGxuYW1lIiAuIH19CiAgbGFiZWxzOgogICAgYXBwOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLmNvbmNvdXJzZS5mdWxsbmFtZSIgLiB9fQogICAgY2hhcnQ6ICJ7eyAuQ2hhcnQuTmFtZSB9fS17eyAuQ2hhcnQuVmVyc2lvbiB9fSIKICAgIHJlbGVhc2U6ICJ7eyAuUmVsZWFzZS5OYW1lIH19IgogICAgaGVyaXRhZ2U6ICJ7eyAuUmVsZWFzZS5TZXJ2aWNlIH19Igp0eXBlOiBPcGFxdWUKZGF0YToKICBob3N0LWtleToge3sgLlZhbHVlcy5zZWNyZXRzLmhvc3RLZXkgfCBiNjRlbmMgfCBxdW90ZSB9fQogIGhvc3Qta2V5LXB1Yjoge3sgLlZhbHVlcy5zZWNyZXRzLmhvc3RLZXlQdWIgfCBiNjRlbmMgfCBxdW90ZSB9fQogIHNlc3Npb24tc2lnbmluZy1rZXk6IHt7IC5WYWx1ZXMuc2VjcmV0cy5zZXNzaW9uU2lnbmluZ0tleSB8IGI2NGVuYyB8IHF1b3RlIH19CiAgd29ya2VyLWtleToge3sgLlZhbHVlcy5zZWNyZXRzLndvcmtlcktleSB8IGI2NGVuYyB8IHF1b3RlIH19CiAgd29ya2VyLWtleS1wdWI6IHt7IC5WYWx1ZXMuc2VjcmV0cy53b3JrZXJLZXlQdWIgfCBiNjRlbmMgfCBxdW90ZSB9fQogIHt7LSBpZiBub3QgLlZhbHVlcy5wb3N0Z3Jlc3FsLmVuYWJsZWQgfX0KICBwb3N0Z3Jlc3FsLXVzZXI6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiBkaWN0ICJrZXkiICJwb3N0Z3Jlc1VzZXIiICJpc250IiAicG9zdGdyZXNxbC5lbmFibGVkIiAicm9vdCIgLiB9fQogIHBvc3RncmVzcWwtcGFzc3dvcmQ6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiBkaWN0ICJrZXkiICJwb3N0Z3Jlc1Bhc3N3b3JkIiAiaXNudCIgInBvc3RncmVzcWwuZW5hYmxlZCIgInJvb3QiIC4gfX0KICBwb3N0Z3Jlc3FsLWNhLWNlcnQ6IHt7IGRlZmF1bHQgIiIgLlZhbHVlcy5zZWNyZXRzLnBvc3RncmVzQ2FDZXJ0IHwgYjY0ZW5jIHwgcXVvdGUgfX0KICBwb3N0Z3Jlc3FsLWNsaWVudC1jZXJ0OiB7eyBkZWZhdWx0ICIiIC5WYWx1ZXMuc2VjcmV0cy5wb3N0Z3Jlc0NsaWVudENlcnQgfCBiNjRlbmMgfCBxdW90ZSB9fQogIHBvc3RncmVzcWwtY2xpZW50LWtleToge3sgZGVmYXVsdCAiIiAuVmFsdWVzLnNlY3JldHMucG9zdGdyZXNDbGllbnRLZXkgfCBiNjRlbmMgfCBxdW90ZSB9fQogIHt7LSBlbmQgfX0KICB7ey0gaWYgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLmVuY3J5cHRpb24uZW5hYmxlZCB9fQogIGVuY3J5cHRpb24ta2V5OiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLnNlY3JldC5yZXF1aXJlZCIgZGljdCAia2V5IiAiZW5jcnlwdGlvbktleSIgImlzIiAiY29uY291cnNlLmVuY3J5cHRpb24uZW5hYmxlZCIgInJvb3QiIC4gfX0KICBvbGQtZW5jcnlwdGlvbi1rZXk6IHt7IGRlZmF1bHQgIiIgLlZhbHVlcy5zZWNyZXRzLm9sZEVuY3J5cHRpb25LZXkgfCBiNjRlbmMgfCBxdW90ZSB9fQogIHt7LSBlbmQgfX0KICB7ey0gaWYgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLmxvY2FsQXV0aC5lbmFibGVkIH19CiAgbG9jYWwtdXNlcnM6IHt7IC5WYWx1ZXMuc2VjcmV0cy5sb2NhbFVzZXJzIHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi5hdXRoLmNmLmVuYWJsZWQgfX0KICBjZi1jbGllbnQtaWQ6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiBkaWN0ICJrZXkiICJjZkNsaWVudElkIiAiaXMiICJjb25jb3Vyc2Uud2ViLmF1dGguY2YuZW5hYmxlZCIgInJvb3QiIC4gfX0KICBjZi1jbGllbnQtc2VjcmV0OiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLnNlY3JldC5yZXF1aXJlZCIgZGljdCAia2V5IiAiY2ZDbGllbnRTZWNyZXQiICJpcyIgImNvbmNvdXJzZS53ZWIuYXV0aC5jZi5lbmFibGVkIiAicm9vdCIgLiB9fQogIGNmLWNhLWNlcnQ6IHt7IGRlZmF1bHQgIiIgLlZhbHVlcy5zZWNyZXRzLmNmQ2FDZXJ0IHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi5hdXRoLmdpdGh1Yi5lbmFibGVkIH19CiAgZ2l0aHViLWNsaWVudC1pZDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS5zZWNyZXQucmVxdWlyZWQiIGRpY3QgImtleSIgImdpdGh1YkNsaWVudElkIiAiaXMiICJjb25jb3Vyc2Uud2ViLmF1dGguZ2l0aHViLmVuYWJsZWQiICJyb290IiAuIH19CiAgZ2l0aHViLWNsaWVudC1zZWNyZXQ6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiBkaWN0ICJrZXkiICJnaXRodWJDbGllbnRTZWNyZXQiICJpcyIgImNvbmNvdXJzZS53ZWIuYXV0aC5naXRodWIuZW5hYmxlZCIgInJvb3QiIC4gfX0KICBnaXRodWItY2EtY2VydDoge3sgZGVmYXVsdCAiIiAuVmFsdWVzLnNlY3JldHMuZ2l0aHViQ2FDZXJ0IHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi5hdXRoLmdpdGxhYi5lbmFibGVkIH19CiAgZ2l0bGFiLWNsaWVudC1pZDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS5zZWNyZXQucmVxdWlyZWQiIGRpY3QgImtleSIgImdpdGxhYkNsaWVudElkIiAiaXMiICJjb25jb3Vyc2Uud2ViLmF1dGguZ2l0bGFiLmVuYWJsZWQiICJyb290IiAuIH19CiAgZ2l0bGFiLWNsaWVudC1zZWNyZXQ6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiBkaWN0ICJrZXkiICJnaXRsYWJDbGllbnRTZWNyZXQiICJpcyIgImNvbmNvdXJzZS53ZWIuYXV0aC5naXRsYWIuZW5hYmxlZCIgInJvb3QiIC4gfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi5hdXRoLmxkYXAuZW5hYmxlZCB9fQogIGxkYXAtY2EtY2VydDoge3sgZGVmYXVsdCAiIiAuVmFsdWVzLnNlY3JldHMubGRhcENhQ2VydCB8IGI2NGVuYyB8IHF1b3RlIH19CiAge3stIGVuZCB9fQogIHt7LSBpZiAuVmFsdWVzLmNvbmNvdXJzZS53ZWIuYXV0aC5vYXV0aC5lbmFibGVkIH19CiAgb2F1dGgtY2xpZW50LWlkOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLnNlY3JldC5yZXF1aXJlZCIgZGljdCAia2V5IiAib2F1dGhDbGllbnRJZCIgImlzIiAiY29uY291cnNlLndlYi5hdXRoLm9hdXRoLmVuYWJsZWQiICJyb290IiAuIH19CiAgb2F1dGgtY2xpZW50LXNlY3JldDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS5zZWNyZXQucmVxdWlyZWQiIGRpY3QgImtleSIgIm9hdXRoQ2xpZW50U2VjcmV0IiAiaXMiICJjb25jb3Vyc2Uud2ViLmF1dGgub2F1dGguZW5hYmxlZCIgInJvb3QiIC4gfX0KICBvYXV0aC1jYS1jZXJ0OiB7eyBkZWZhdWx0ICIiIC5WYWx1ZXMuc2VjcmV0cy5vYXV0aENhQ2VydCB8IGI2NGVuYyB8IHF1b3RlIH19CiAge3stIGVuZCB9fQogIHt7LSBpZiAuVmFsdWVzLmNvbmNvdXJzZS53ZWIuYXV0aC5vaWRjLmVuYWJsZWQgfX0KICBvaWRjLWNsaWVudC1pZDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS5zZWNyZXQucmVxdWlyZWQiIGRpY3QgImtleSIgIm9pZGNDbGllbnRJZCIgImlzIiAiY29uY291cnNlLndlYi5hdXRoLm9pZGMuZW5hYmxlZCIgInJvb3QiIC4gfX0KICBvaWRjLWNsaWVudC1zZWNyZXQ6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiBkaWN0ICJrZXkiICJvaWRjQ2xpZW50U2VjcmV0IiAiaXMiICJjb25jb3Vyc2Uud2ViLmF1dGgub2lkYy5lbmFibGVkIiAicm9vdCIgLiB9fQogIG9pZGMtY2EtY2VydDoge3sgZGVmYXVsdCAiIiAuVmFsdWVzLnNlY3JldHMub2lkY0NhQ2VydCB8IGI2NGVuYyB8IHF1b3RlIH19CiAge3stIGVuZCB9fQogIHt7LSBpZiAuVmFsdWVzLmNvbmNvdXJzZS53ZWIudGxzLmVuYWJsZWQgfX0KICB3ZWItdGxzLWNlcnQ6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uuc2VjcmV0LnJlcXVpcmVkIiBkaWN0ICJrZXkiICJ3ZWJUbHNDZXJ0IiAiaXMiICJjb25jb3Vyc2Uud2ViLnRscy5lbmFibGVkIiAicm9vdCIgLiB9fQogIHdlYi10bHMta2V5OiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLnNlY3JldC5yZXF1aXJlZCIgZGljdCAia2V5IiAid2ViVGxzS2V5IiAiaXMiICJjb25jb3Vyc2Uud2ViLnRscy5lbmFibGVkIiAicm9vdCIgLiB9fQogIHt7LSBlbmQgfX0KICB7ey0gaWYgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLnZhdWx0LmVuYWJsZWQgfX0KICB2YXVsdC1jYS1jZXJ0OiB7eyBkZWZhdWx0ICIiIC5WYWx1ZXMuc2VjcmV0cy52YXVsdENhQ2VydCB8IGI2NGVuYyB8IHF1b3RlIH19CiAgdmF1bHQtY2xpZW50LXRva2VuOiB7eyBkZWZhdWx0ICIiIC5WYWx1ZXMuc2VjcmV0cy52YXVsdENsaWVudFRva2VuIHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB2YXVsdC1jbGllbnQtY2VydDoge3sgZGVmYXVsdCAiIiAuVmFsdWVzLnNlY3JldHMudmF1bHRDbGllbnRDZXJ0IHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB2YXVsdC1jbGllbnQta2V5OiB7eyBkZWZhdWx0ICIiIC5WYWx1ZXMuc2VjcmV0cy52YXVsdENsaWVudEtleSB8IGI2NGVuYyB8IHF1b3RlIH19CiAgdmF1bHQtY2xpZW50LWF1dGgtcGFyYW06IHt7IGRlZmF1bHQgIiIgLlZhbHVlcy5zZWNyZXRzLnZhdWx0QXV0aFBhcmFtIHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi5hd3NTc20uZW5hYmxlZCB9fQogIGF3cy1zc20tYWNjZXNzLWtleToge3sgZGVmYXVsdCAiIiAuVmFsdWVzLnNlY3JldHMuYXdzU3NtQWNjZXNzS2V5IHwgYjY0ZW5jIHwgcXVvdGUgfX0KICBhd3Mtc3NtLXNlY3JldC1rZXk6IHt7IGRlZmF1bHQgIiIgLlZhbHVlcy5zZWNyZXRzLmF3c1NzbVNlY3JldEtleSB8IGI2NGVuYyB8IHF1b3RlIH19CiAge3stIGlmIC5WYWx1ZXMuc2VjcmV0cy5hd3NTc21TZXNzaW9uVG9rZW4gfX0KICBhd3Mtc3NtLXNlc3Npb24tdG9rZW46IHt7IC5WYWx1ZXMuc2VjcmV0cy5hd3NTc21TZXNzaW9uVG9rZW4gfCBiNjRlbmMgfCBxdW90ZSB9fQogIHt7LSBlbmQgfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi5hd3NTZWNyZXRzTWFuYWdlci5lbmFibGVkIH19CiAgYXdzLXNlY3JldHNtYW5hZ2VyLWFjY2Vzcy1rZXk6IHt7IGRlZmF1bHQgIiIgLlZhbHVlcy5zZWNyZXRzLmF3c1NlY3JldHNtYW5hZ2VyQWNjZXNzS2V5IHwgYjY0ZW5jIHwgcXVvdGUgfX0KICBhd3Mtc2VjcmV0c21hbmFnZXItc2VjcmV0LWtleToge3sgZGVmYXVsdCAiIiAuVmFsdWVzLnNlY3JldHMuYXdzU2VjcmV0c21hbmFnZXJTZWNyZXRLZXkgfCBiNjRlbmMgfCBxdW90ZSB9fQogIHt7LSBpZiAuVmFsdWVzLnNlY3JldHMuYXdzU2VjcmV0c21hbmFnZXJTZXNzaW9uVG9rZW4gfX0KICBhd3Mtc2VjcmV0c21hbmFnZXItc2Vzc2lvbi10b2tlbjoge3sgLlZhbHVlcy5zZWNyZXRzLmF3c1NlY3JldHNtYW5hZ2VyU2Vzc2lvblRva2VuIHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB7ey0gZW5kIH19CiAge3stIGVuZCB9fQogIHt7LSBpZiAuVmFsdWVzLmNvbmNvdXJzZS53ZWIuaW5mbHV4ZGIuZW5hYmxlZCB9fQogIGluZmx1eGRiLXBhc3N3b3JkOiB7eyBkZWZhdWx0ICIiIC5WYWx1ZXMuc2VjcmV0cy5pbmZsdXhkYlBhc3N3b3JkIHwgYjY0ZW5jIHwgcXVvdGUgfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi5zeXNsb2cuZW5hYmxlZCB9fQogIHN5c2xvZy1jYS1jZXJ0OiB7eyBkZWZhdWx0ICIiIC5WYWx1ZXMuc2VjcmV0cy5zeXNsb2dDYUNlcnQgfCBiNjRlbmMgfCBxdW90ZSB9fQogIHt7LSBlbmQgfX0Ke3stIGVuZCB9fQo=" 67 }, 68 { 69 "filePath": "templates/web-deployment.yaml", 70 "fileContents": "apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: {{ template "concourse.web.fullname" . }}
  labels:
    app: {{ template "concourse.web.fullname" . }}
    chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
    release: "{{ .Release.Name }}"
    heritage: "{{ .Release.Service }}"
spec:
  replicas: {{ .Values.web.replicas }}
  template:
    metadata:
      labels:
        app: {{ template "concourse.web.fullname" . }}
        release: "{{ .Release.Name }}"
      annotations:
{{ toYaml .Values.web.annotations | indent 8 }}
    spec:
    {{- with .Values.web.nodeSelector }}
      nodeSelector:
{{ toYaml . | indent 8 }}
    {{- end }}
      serviceAccountName: {{ if .Values.rbac.create }}{{ template "concourse.web.fullname" . }}{{ else }}{{ .Values.rbac.webServiceAccountName }}{{ end }}
      tolerations:
{{ toYaml .Values.web.tolerations | indent 8 }}
      {{- if .Values.imagePullSecrets }}
      imagePullSecrets:
      {{- range .Values.imagePullSecrets }}
        - name: {{ . }}
      {{- end }}
      {{- end }}
      containers:
        - name: {{ template "concourse.web.fullname" . }}
          {{- if .Values.imageDigest }}
          image: "{{ .Values.image }}@{{ .Values.imageDigest }}"
          {{- else }}
          image: "{{ .Values.image }}:{{ .Values.imageTag }}"
          {{- end }}
          imagePullPolicy: {{ .Values.imagePullPolicy | quote }}
          args:
            - "web"
            {{- if and (.Values.concourse.web.awsSecretsManager.enabled) (.Values.concourse.web.awsSecretsManager.region) }}
            - '--aws-secretsmanager-region={{ .Values.concourse.web.awsSecretsManager.region | quote }}'
            {{- end }}
            {{- if and (.Values.concourse.web.awsSsm.enabled) (.Values.concourse.web.awsSsm.region) }}
            - '--aws-ssm-region={{ .Values.concourse.web.awsSsm.region | quote }}'
            {{- end }}
          env:
            {{- if .Values.concourse.web.logLevel }}
            - name: CONCOURSE_LOG_LEVEL
              value: {{ .Values.concourse.web.logLevel | quote }}
            {{- end }}
            {{- if .Values.concourse.web.bindPort }}
            - name: CONCOURSE_BIND_PORT
              value: {{ .Values.concourse.web.bindPort | quote }}
            {{- end }}
            {{- if .Values.concourse.web.bindIp }}
            - name: CONCOURSE_BIND_IP
              value: {{ .Values.concourse.web.bindIp | quote }}
            {{- end }}
            {{- if .Values.concourse.web.localAuth.enabled }}
            - name: CONCOURSE_ADD_LOCAL_USER
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: local-users
            {{- end }}
            {{- if .Values.concourse.web.tls.enabled }}
            - name: CONCOURSE_TLS_BIND_PORT
              value: {{ .Values.concourse.web.tls.bindPort | default "443" | quote }}
            - name: CONCOURSE_TLS_CERT
              value: "{{ .Values.web.tlsSecretsPath }}/client.cert"
            - name: CONCOURSE_TLS_KEY
              value: "{{ .Values.web.tlsSecretsPath }}/client.key"
            {{- end }}
            {{- if .Values.concourse.web.tls.enabled }}
            - name: CONCOURSE_EXTERNAL_URL
              value: {{ required "Must specify HTTPS external URL when concourse.web.tls.enabled is true" .Values.concourse.web.externalUrl | quote }}
            {{- else }}
            {{- if .Values.concourse.web.externalUrl }}
            - name: CONCOURSE_EXTERNAL_URL
              value:
              value: {{ .Values.concourse.web.externalUrl | quote }}
            {{- end }}
            {{- end }}
            {{- if .Values.concourse.web.peerUrl }}
            - name: CONCOURSE_PEER_URL
              value: {{ .Values.concourse.web.peerUrl | quote }}
            {{- else }}
            - name: POD_IP
              valueFrom:
                fieldRef:
                  fieldPath: status.podIP
            - name: CONCOURSE_PEER_URL
              value: "http://$(POD_IP):$(CONCOURSE_BIND_PORT)"
            {{- end }}
            {{- if .Values.concourse.web.encryption.enabled }}
            - name: CONCOURSE_ENCRYPTION_KEY
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: encryption-key
            - name: CONCOURSE_OLD_ENCRYPTION_KEY
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: old-encryption-key
            {{- end }}
            {{- if .Values.concourse.web.debugBindIp }}
            - name: CONCOURSE_DEBUG_BIND_IP
              value: {{ .Values.concourse.web.debugBindIp | quote }}
            {{- end }}
            {{- if .Values.concourse.web.debugBindPort }}
            - name: CONCOURSE_DEBUG_BIND_PORT
              value: {{ .Values.concourse.web.debugBindPort | quote }}
            {{- end }}
            {{- if .Values.concourse.web.interceptIdleTimeout }}
            - name: CONCOURSE_INTERCEPT_IDLE_TIMEOUT
              value: {{ .Values.concourse.web.interceptIdleTimeout | quote }}
            {{- end }}
            {{- if .Values.concourse.web.globalResourceCheckTimeout }}
            - name: CONCOURSE_GLOBAL_RESOURCE_CHECK_TIMEOUT
              value: {{ .Values.concourse.web.globalResourceCheckTimeout | quote }}
            {{- end }}
            {{- if .Values.concourse.web.resourceCheckingInterval }}
            - name: CONCOURSE_RESOURCE_CHECKING_INTERVAL
              value: {{ .Values.concourse.web.resourceCheckingInterval | quote }}
            {{- end }}
            {{- if .Values.concourse.web.resourceTypeCheckingInterval }}
            - name: CONCOURSE_RESOURCE_TYPE_CHECKING_INTERVAL
              value: {{ .Values.concourse.web.resourceTypeCheckingInterval | quote }}
            {{- end }}
            {{- if .Values.concourse.web.containerPlacementStrategy }}
            - name: CONCOURSE_CONTAINER_PLACEMENT_STRATEGY
              value: {{ .Values.concourse.web.containerPlacementStrategy | quote }}
            {{- end }}
            {{- if .Values.concourse.web.baggageclaimResponseHeaderTimeout }}
            - name: CONCOURSE_BAGGAGECLAIM_RESPONSE_HEADER_TIMEOUT
              value: {{ .Values.concourse.web.baggageclaimResponseHeaderTimeout | quote }}
            {{- end }}
            {{- if .Values.concourse.web.cliArtifactsDir }}
            - name: CONCOURSE_CLI_ARTIFACTS_DIR
              value: {{ .Values.concourse.web.cliArtifactsDir | quote }}
            {{- end }}
            {{- if .Values.concourse.web.logDbQueries }}
            - name: CONCOURSE_LOG_DB_QUERIES
              value: {{ .Values.concourse.web.logDbQueries | quote }}
            {{- end }}
            {{- if .Values.concourse.web.buildTrackerInterval }}
            - name: CONCOURSE_BUILD_TRACKER_INTERVAL
              value: {{ .Values.concourse.web.buildTrackerInterval | quote  }}
            {{- end }}
            {{- if .Values.concourse.web.defaultBuildLogsToRetain }}
            - name: CONCOURSE_DEFAULT_BUILD_LOGS_TO_RETAIN
              value: {{ .Values.concourse.web.defaultBuildLogsToRetain | quote }}
            {{- end }}
            {{- if .Values.concourse.web.maxBuildLogsToRetain }}
            - name: CONCOURSE_MAX_BUILD_LOGS_TO_RETAIN
              value: {{ .Values.concourse.web.maxBuildLogsToRetain | quote }}
            {{- end }}
            {{- if .Values.concourse.web.defaultTaskCpuLimit }}
            - name: CONCOURSE_DEFAULT_TASK_CPU_LIMIT
              value: {{ .Values.concourse.web.defaultTaskCpuLimit | quote }}
            {{- end }}
            {{- if .Values.concourse.web.defaultTaskMemoryLimit }}
            - name: CONCOURSE_DEFAULT_TASK_MEMORY_LIMIT
              value: {{ .Values.concourse.web.defaultTaskMemoryLimit | quote }}
            {{- end }}

            {{- if .Values.postgresql.enabled }}
            - name: CONCOURSE_POSTGRES_HOST
              value: {{ template "concourse.postgresql.fullname" . }}
            - name: CONCOURSE_POSTGRES_USER
              value: {{ .Values.postgresql.postgresUser | quote }}
            - name: CONCOURSE_POSTGRES_PASSWORD
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.postgresql.fullname" . }}
                  key: postgres-password
            - name: CONCOURSE_POSTGRES_DATABASE
              value: {{ .Values.postgresql.postgresDatabase | quote }}
            {{- else }}
            {{- if .Values.concourse.web.postgres.host }}
            - name: CONCOURSE_POSTGRES_HOST
              value: {{ .Values.concourse.web.postgres.host | quote }}
            {{- end }}
            {{- if .Values.concourse.web.postgres.port }}
            - name: CONCOURSE_POSTGRES_PORT
              value: {{ .Values.concourse.web.postgres.port | quote }}
            {{- end }}
            {{- if .Values.concourse.web.postgres.socket }}
            - name: CONCOURSE_POSTGRES_SOCKET
              value: {{ .Values.concourse.web.postgres.socket | quote }}
            {{- end }}
            - name: CONCOURSE_POSTGRES_USER
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: postgresql-user
            - name: CONCOURSE_POSTGRES_PASSWORD
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: postgresql-password
            {{- if .Values.concourse.web.postgres.sslmode }}
            - name: CONCOURSE_POSTGRES_SSLMODE
              value: {{ .Values.concourse.web.postgres.sslmode | quote }}
            {{- end }}
            {{- if .Values.secrets.postgresCaCert }}
            - name: CONCOURSE_POSTGRES_CA_CERT
              value: "{{ .Values.web.postgresqlSecretsPath }}/ca.cert"
            {{- end }}
            {{- if .Values.secrets.postgresClientCert }}
            - name: CONCOURSE_POSTGRES_CLIENT_CERT
              value: "{{ .Values.web.postgresqlSecretsPath }}/client.cert"
            {{- end }}
            {{- if .Values.secrets.postgresClientKey }}
            - name: CONCOURSE_POSTGRES_CLIENT_KEY
              value: "{{ .Values.web.postgresqlSecretsPath }}/client.key"
            {{- end }}
            {{- if .Values.concourse.web.postgres.connectTimeout }}
            - name: CONCOURSE_POSTGRES_CONNECT_TIMEOUT
              value: {{ .Values.concourse.web.postgres.connectTimeout | quote }}
            {{- end }}
            {{- if .Values.concourse.web.postgres.database }}
            - name: CONCOURSE_POSTGRES_DATABASE
              value: {{ .Values.concourse.web.postgres.database | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.kubernetes.enabled }}
            - name: CONCOURSE_KUBERNETES_IN_CLUSTER
              value: "true"
            - name: CONCOURSE_KUBERNETES_NAMESPACE_PREFIX
              value: {{ template "concourse.namespacePrefix" . }}
            {{- else}}
            {{- if .Values.concourse.web.kubernetes.configPath }}
            - name: CONCOURSE_KUBERNETES_CONFIG_PATH
              value: {{ .Values.concourse.web.kubernetes.configPath | quote }}
            {{- end }}
            {{- if .Values.concourse.web.kubernetes.namespacePrefix }}
            - name: CONCOURSE_KUBERNETES_NAMESPACE_PREFIX
              value: {{ .Values.concourse.web.kubernetes.namespacePrefix | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.awsSecretsManager.enabled }}
            - name: CONCOURSE_AWS_SECRETSMANAGER_ACCESS_KEY
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: aws-secretsmanager-access-key
            - name: CONCOURSE_AWS_SECRETSMANAGER_SECRET_KEY
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: aws-secretsmanager-secret-key
            {{- if .Values.secrets.awsSecretsManagerSessionToken }}
            - name: CONCOURSE_AWS_SECRETSMANAGER_SESSION_TOKEN
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: aws-secretsmanager-session-token
            {{- end }}
            {{- if .Values.concourse.web.awsSecretsManager.pipelineSecretTemplate }}
            - name: CONCOURSE_AWS_SECRETSMANAGER_PIPELINE_SECRET_TEMPLATE
              value: {{ .Values.concourse.web.awsSecretsManager.pipelineSecretTemplate | quote }}
            {{- end }}
            {{- if .Values.concourse.web.awsSecretsManager.teamSecretTemplate }}
            - name: CONCOURSE_AWS_SECRETSMANAGER_TEAM_SECRET_TEMPLATE
              value: {{ .Values.concourse.web.awsSecretsManager.teamSecretTemplate | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.awsSsm.enabled }}
            - name: CONCOURSE_AWS_SSM_ACCESS_KEY
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: aws-ssm-access-key
            - name: CONCOURSE_AWS_SSM_SECRET_KEY
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: aws-ssm-secret-key
            {{- if .Values.secrets.awsSsmSessionToken }}
            - name: CONCOURSE_AWS_SSM_SESSION_TOKEN
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: aws-ssm-session-token
            {{- end }}
            {{- if .Values.concourse.web.awsSsm.pipelineSecretTemplate }}
            - name: CONCOURSE_AWS_SSM_PIPELINE_SECRET_TEMPLATE
              value: {{ .Values.concourse.web.awsSsm.pipelineSecretTemplate | quote }}
            {{- end }}
            {{- if .Values.concourse.web.awsSsm.teamSecretTemplate }}
            - name: CONCOURSE_AWS_SSM_TEAM_SECRET_TEMPLATE
              value: {{ .Values.concourse.web.awsSsm.teamSecretTemplate | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.vault.enabled }}
            - name: CONCOURSE_VAULT_URL
              value: {{ .Values.concourse.web.vault.url | quote }}
            - name: CONCOURSE_VAULT_PATH_PREFIX
              value: {{ .Values.concourse.web.vault.pathPrefix | quote }}
            - name: CONCOURSE_VAULT_AUTH_BACKEND
              value: {{ .Values.concourse.web.vault.authBackend | quote }}
            {{- if .Values.concourse.web.vault.useCaCert }}
            - name: CONCOURSE_VAULT_CA_CERT
              value: "{{ .Values.web.vaultSecretsPath }}/ca.cert"
            {{- end }}
            {{- if eq (default "" .Values.concourse.web.vault.authBackend) "token" }}
            - name: CONCOURSE_VAULT_CLIENT_TOKEN
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: vault-client-token
            {{- end }}
            {{- if eq (default "" .Values.concourse.web.vault.authBackend) "cert" }}
            - name: CONCOURSE_VAULT_CLIENT_CERT
              value: "{{ .Values.web.vaultSecretsPath }}/client.cert"
            - name: CONCOURSE_VAULT_CLIENT_KEY
              value: "{{ .Values.web.vaultSecretsPath }}/client.key"
            {{- end }}
            {{- if eq (default "" .Values.concourse.web.vault.authBackend) "approle" }}
            - name: CONCOURSE_VAULT_AUTH_PARAM
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: vault-client-auth-param
            {{- end }}
            {{- if .Values.concourse.web.vault.authBackendMaxTtl }}
            - name: CONCOURSE_VAULT_AUTH_BACKEND_MAX_TTL
              value: {{ .Values.concourse.web.vault.authBackendMaxTtl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.vault.cache }}
            - name: CONCOURSE_VAULT_CACHE
              value: {{ .Values.concourse.web.vault.cache | quote }}
            {{- end }}
            {{- if .Values.concourse.web.vault.caPath }}
            - name: CONCOURSE_VAULT_CA_PATH
              value: {{ .Values.concourse.web.vault.caPath | quote }}
            {{- end }}
            {{- if .Values.concourse.web.vault.insecureSkipVerify }}
            - name: CONCOURSE_VAULT_INSECURE_SKIP_VERIFY
              value: {{ .Values.concourse.web.vault.insecureSkipVerify | quote }}
            {{- end }}
            {{- if .Values.concourse.web.vault.maxLease }}
            - name: CONCOURSE_VAULT_MAX_LEASE
              value: {{ .Values.concourse.web.vault.maxLease | quote }}
            {{- end }}
            {{- if .Values.concourse.web.vault.retryInitial }}
            - name: CONCOURSE_VAULT_RETRY_INITIAL
              value: {{ .Values.concourse.web.vault.retryInitial | quote }}
            {{- end }}
            {{- if .Values.concourse.web.vault.retryMax }}
            - name: CONCOURSE_VAULT_RETRY_MAX
              value: {{ .Values.concourse.web.vault.retryMax | quote }}
            {{- end }}
            {{- if .Values.concourse.web.vault.serverName }}
            - name: CONCOURSE_VAULT_SERVER_NAME
              value: {{ .Values.concourse.web.vault.serverName | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.noop }}
            - name: CONCOURSE_NOOP
              value: {{ .Values.concourse.web.noop | quote }}
            {{- end }}

            {{- if .Values.concourse.web.staticWorker.enabled }}
            {{- if .Values.concourse.web.staticWorker.gardenUrl }}
            - name: CONCOURSE_WORKER_GARDEN_URL
              value: {{ .Values.concourse.web.staticWorker.gardenUrl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.staticWorker.baggageclaimUrl }}
            - name: CONCOURSE_WORKER_BAGGAGECLAIM_URL
              value: {{ .Values.concourse.web.staticWorker.baggageclaimUrl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.staticWorker.resource }}
            - name: CONCOURSE_WORKER_RESOURCE
              value: {{ .Values.concourse.web.staticWorker.resource | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.metrics.hostName }}
            - name: CONCOURSE_METRICS_HOST_NAME
              value: {{ .Values.concourse.web.metrics.hostName | quote }}
            {{- end }}
            {{- if .Values.concourse.web.metrics.attribute }}
            - name: CONCOURSE_METRICS_ATTRIBUTE
              value: {{ .Values.concourse.web.metrics.attribute | quote }}
            {{- end }}

            {{- if .Values.concourse.web.datadog.enabled }}
            - name: CONCOURSE_DATADOG_AGENT_HOST
            {{- if .Values.concourse.web.datadog.agentHostUseHostIP }}
              valueFrom:
                fieldRef:
                  fieldPath: status.hostIP
            {{- else }}
              value: {{ .Values.concourse.web.datadog.agentHost | quote }}
            {{- end }}
            - name: CONCOURSE_DATADOG_AGENT_PORT
              value: {{ .Values.concourse.web.datadog.agentPort | quote }}
            {{- if .Values.concourse.web.datadog.prefix }}
            - name: CONCOURSE_DATADOG_PREFIX
              value: {{ .Values.concourse.web.datadog.prefix | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.influxdb.enabled }}
            - name: CONCOURSE_INFLUXDB_URL
              value: {{ .Values.concourse.web.influxdb.url | quote }}
            - name: CONCOURSE_INFLUXDB_DATABASE
              value: {{ .Values.concourse.web.influxdb.database | quote }}
            - name: CONCOURSE_INFLUXDB_USERNAME
              value: {{ .Values.concourse.web.influxdb.username | quote }}
            - name: CONCOURSE_INFLUXDB_PASSWORD
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: influxdb-password
            - name: CONCOURSE_INFLUXDB_INSECURE_SKIP_VERIFY
              value: {{ .Values.concourse.web.influxdb.insecureSkipVerify | quote}}
            {{- end }}

            {{- if .Values.concourse.web.emitToLogs }}
            - name: CONCOURSE_EMIT_TO_LOGS
              value: {{ .Values.concourse.web.emitToLogs | quote }}
            {{- end }}

            {{- if .Values.concourse.web.newrelic.enabled }}
            {{- if .Values.concourse.web.newrelic.accountId }}
            - name: CONCOURSE_NEWRELIC_ACCOUNT_ID
              value: {{ .Values.concourse.web.newrelic.accountId | quote }}
            {{- end }}
            {{- if .Values.concourse.web.newrelic.apiKey }}
            - name: CONCOURSE_NEWRELIC_API_KEY
              value: {{ .Values.concourse.web.newrelic.apiKey | quote }}
            {{- end }}
            {{- if .Values.concourse.web.newrelic.servicePrefix }}
            - name: CONCOURSE_NEWRELIC_SERVICE_PREFIX
              value: {{ .Values.concourse.web.newrelic.servicePrefix | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.prometheus.enabled }}
            - name: CONCOURSE_PROMETHEUS_BIND_IP
              value: {{ .Values.concourse.web.prometheus.bindIp | quote }}
            - name: CONCOURSE_PROMETHEUS_BIND_PORT
              value: {{ .Values.concourse.web.prometheus.bindPort | quote }}
            {{- end }}

            {{- if .Values.concourse.web.riemann.enabled }}
            {{- if .Values.concourse.web.riemann.host }}
            - name: CONCOURSE_RIEMANN_HOST
              value: {{ .Values.concourse.web.riemann.host | quote }}
            {{- end }}
            {{- if .Values.concourse.web.riemann.port }}
            - name: CONCOURSE_RIEMANN_PORT
              value: {{ .Values.concourse.web.riemann.port | quote }}
            {{- end }}
            {{- if .Values.concourse.web.riemann.servicePrefix }}
            - name: CONCOURSE_RIEMANN_SERVICE_PREFIX
              value: {{ .Values.concourse.web.riemann.servicePrefix | quote }}
            {{- end }}
            {{- if .Values.concourse.web.riemann.tag }}
            - name: CONCOURSE_RIEMANN_TAG
              value: {{ .Values.concourse.web.riemann.tag | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.xFrameOptions }}
            - name: CONCOURSE_X_FRAME_OPTIONS
              value: {{ .Values.concourse.web.xFrameOptions | quote }}
            {{- end }}

            {{- if .Values.concourse.web.gc.overrideDefaults }}
            {{- if .Values.concourse.web.gc.interval }}
            - name: CONCOURSE_GC_INTERVAL
              value: {{ .Values.concourse.web.gc.interval | quote }}
            {{- end }}
            {{- if .Values.concourse.web.gc.oneOffGracePeriod }}
            - name: CONCOURSE_GC_ONE_OFF_GRACE_PERIOD
              value: {{ .Values.concourse.web.gc.oneOffGracePeriod | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.syslog.enabled }}
            {{- if .Values.concourse.web.syslog.hostname }}
            - name: CONCOURSE_SYSLOG_HOSTNAME
              value: {{ .Values.concourse.web.syslog.hostname | quote }}
            {{- end }}
            {{- if .Values.concourse.web.syslog.address }}
            - name: CONCOURSE_SYSLOG_ADDRESS
              value: {{ .Values.concourse.web.syslog.address | quote }}
            {{- end }}
            {{- if .Values.concourse.web.syslog.transport }}
            - name: CONCOURSE_SYSLOG_TRANSPORT
              value: {{ .Values.concourse.web.syslog.transport | quote }}
            {{- end }}
            {{- if .Values.concourse.web.syslog.drainInterval }}
            - name: CONCOURSE_SYSLOG_DRAIN_INTERVAL
              value: {{ .Values.concourse.web.syslog.drainInterval | quote }}
            {{- end }}
            {{- if .Values.concourse.web.syslog.useCaCert }}
            - name: CONCOURSE_SYSLOG_CA_CERT
              value: "{{ .Values.web.syslogSecretsPath }}/ca.cert"
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.auth.cookieSecure }}
            - name: CONCOURSE_COOKIE_SECURE
              value: {{ .Values.concourse.web.auth.cookieSecure | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.duration }}
            - name: CONCOURSE_AUTH_DURATION
              value: {{ .Values.concourse.web.auth.duration | quote }}
            {{- end }}
            - name: CONCOURSE_SESSION_SIGNING_KEY
              value: "{{ .Values.web.keySecretsPath }}/session_signing_key"

            {{- if .Values.concourse.web.auth.mainTeam.localUser }}
            - name: CONCOURSE_MAIN_TEAM_LOCAL_USER
              value: {{ .Values.concourse.web.auth.mainTeam.localUser | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.allowAllUsers }}
            - name: CONCOURSE_MAIN_TEAM_ALLOW_ALL_USERS
              value: {{ .Values.concourse.web.auth.mainTeam.allowAllUsers | quote }}
            {{- end }}

            {{- if .Values.concourse.web.auth.mainTeam.cf.org }}
            - name: CONCOURSE_MAIN_TEAM_CF_ORG
              value: {{ .Values.concourse.web.auth.mainTeam.cf.org | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.cf.space }}
            - name: CONCOURSE_MAIN_TEAM_CF_SPACE
              value: {{ .Values.concourse.web.auth.mainTeam.cf.space | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.cf.spaceGuid }}
            - name: CONCOURSE_MAIN_TEAM_CF_SPACE_GUID
              value: {{ .Values.concourse.web.auth.mainTeam.cf.spaceGuid | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.cf.user }}
            - name: CONCOURSE_MAIN_TEAM_CF_USER
              value: {{ .Values.concourse.web.auth.mainTeam.cf.user | quote }}
            {{- end }}

            {{- if .Values.concourse.web.auth.mainTeam.github.user }}
            - name: CONCOURSE_MAIN_TEAM_GITHUB_USER
              value: {{ .Values.concourse.web.auth.mainTeam.github.user | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.github.org }}
            - name: CONCOURSE_MAIN_TEAM_GITHUB_ORG
              value: {{ .Values.concourse.web.auth.mainTeam.github.org | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.github.team }}
            - name: CONCOURSE_MAIN_TEAM_GITHUB_TEAM
              value: {{ .Values.concourse.web.auth.mainTeam.github.team | quote }}
            {{- end }}

            {{- if .Values.concourse.web.auth.mainTeam.gitlab.user }}
            - name: CONCOURSE_MAIN_TEAM_GITLAB_USER
              value: {{ .Values.concourse.web.auth.mainTeam.gitlab.user | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.gitlab.group }}
            - name: CONCOURSE_MAIN_TEAM_GITLAB_GROUP
              value: {{ .Values.concourse.web.auth.mainTeam.gitlab.group | quote }}
            {{- end }}

            {{- if .Values.concourse.web.auth.mainTeam.ldap.user }}
            - name: CONCOURSE_MAIN_TEAM_LDAP_USER
              value: {{ .Values.concourse.web.auth.mainTeam.ldap.user | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.ldap.group }}
            - name: CONCOURSE_MAIN_TEAM_LDAP_GROUP
              value: {{ .Values.concourse.web.auth.mainTeam.ldap.group | quote }}
            {{- end }}

            {{- if .Values.concourse.web.auth.mainTeam.oauth.user }}
            - name: CONCOURSE_MAIN_TEAM_OAUTH_USER
              value: {{ .Values.concourse.web.auth.mainTeam.oauth.user | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.oauth.group }}
            - name: CONCOURSE_MAIN_TEAM_OAUTH_GROUP
              value: {{ .Values.concourse.web.auth.mainTeam.oauth.group | quote }}
            {{- end }}

            {{- if .Values.concourse.web.auth.mainTeam.oidc.group }}
            - name: CONCOURSE_MAIN_TEAM_OIDC_GROUP
              value: {{ .Values.concourse.web.auth.mainTeam.oidc.group | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.mainTeam.oidc.user }}
            - name: CONCOURSE_MAIN_TEAM_OIDC_USER
              value: {{ .Values.concourse.web.auth.mainTeam.oidc.user | quote }}
            {{- end }}

            {{- if .Values.concourse.web.auth.cf.enabled }}
            - name: CONCOURSE_CF_CLIENT_ID
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: cf-client-id
            - name: CONCOURSE_CF_CLIENT_SECRET
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: cf-client-secret
            {{- if .Values.concourse.web.auth.cf.apiUrl }}
            - name: CONCOURSE_CF_API_URL
              value: {{ .Values.concourse.web.auth.cf.apiUrl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.cf.useCaCert }}
            - name: CONCOURSE_CF_CA_CERT
              value: "{{ .Values.web.authSecretsPath }}/cf_ca.cert"
            {{- end }}
            {{- if .Values.concourse.web.auth.cf.skipSslValidation }}
            - name: CONCOURSE_CF_SKIP_SSL_VALIDATION
              value: {{ .Values.concourse.web.auth.cf.skipSslValidation | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.auth.github.enabled }}
            - name: CONCOURSE_GITHUB_CLIENT_ID
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: github-client-id
            - name: CONCOURSE_GITHUB_CLIENT_SECRET
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: github-client-secret
            {{- if .Values.concourse.web.auth.github.host }}
            - name: CONCOURSE_GITHUB_HOST
              value: {{ .Values.concourse.web.auth.github.host | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.github.useCaCert }}
            - name: CONCOURSE_GITHUB_CA_CERT
              value: "{{ .Values.web.authSecretsPath }}/github_ca.cert"
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.auth.gitlab.enabled }}
            - name: CONCOURSE_GITLAB_CLIENT_ID
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: gitlab-client-id
            - name: CONCOURSE_GITLAB_CLIENT_SECRET
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: gitlab-client-secret
            {{- if .Values.concourse.web.auth.gitlab.host }}
            - name: CONCOURSE_GITLAB_HOST
              value: {{ .Values.concourse.web.auth.gitlab.host | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.auth.ldap.enabled }}
            {{- if .Values.concourse.web.auth.ldap.bindDn }}
            - name: CONCOURSE_LDAP_BIND_DN
              value: {{ .Values.concourse.web.auth.ldap.bindDn | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.bindPw }}
            - name: CONCOURSE_LDAP_BIND_PW
              value: {{ .Values.concourse.web.auth.ldap.bindPw | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.useCaCert }}
            - name: CONCOURSE_LDAP_CA_CERT
              value: "{{ .Values.web.authSecretsPath }}/ldap_ca.cert"
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.displayName }}
            - name: CONCOURSE_LDAP_DISPLAY_NAME
              value: {{ .Values.concourse.web.auth.ldap.displayName | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.groupSearchBaseDn }}
            - name: CONCOURSE_LDAP_GROUP_SEARCH_BASE_DN
              value: {{ .Values.concourse.web.auth.ldap.groupSearchBaseDn | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.groupSearchFilter }}
            - name: CONCOURSE_LDAP_GROUP_SEARCH_FILTER
              value: {{ .Values.concourse.web.auth.ldap.groupSearchFilter | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.groupSearchGroupAttr }}
            - name: CONCOURSE_LDAP_GROUP_SEARCH_GROUP_ATTR
              value: {{ .Values.concourse.web.auth.ldap.groupSearchGroupAttr | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.groupSearchNameAttr }}
            - name: CONCOURSE_LDAP_GROUP_SEARCH_NAME_ATTR
              value: {{ .Values.concourse.web.auth.ldap.groupSearchNameAttr | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.groupSearchScope }}
            - name: CONCOURSE_LDAP_GROUP_SEARCH_SCOPE
              value: {{ .Values.concourse.web.auth.ldap.groupSearchScope | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.groupSearchUserAttr }}
            - name: CONCOURSE_LDAP_GROUP_SEARCH_USER_ATTR
              value: {{ .Values.concourse.web.auth.ldap.groupSearchUserAttr | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.host }}
            - name: CONCOURSE_LDAP_HOST
              value: {{ .Values.concourse.web.auth.ldap.host | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.insecureNoSsl }}
            - name: CONCOURSE_LDAP_INSECURE_NO_SSL
              value: {{ .Values.concourse.web.auth.ldap.insecureNoSsl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.insecureSkipVerify }}
            - name: CONCOURSE_LDAP_INSECURE_SKIP_VERIFY
              value: {{ .Values.concourse.web.auth.ldap.insecureSkipVerify | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.startTls }}
            - name: CONCOURSE_LDAP_START_TLS
              value: {{ .Values.concourse.web.auth.ldap.startTls | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.userSearchBaseDn }}
            - name: CONCOURSE_LDAP_USER_SEARCH_BASE_DN
              value: {{ .Values.concourse.web.auth.ldap.userSearchBaseDn | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.userSearchEmailAttr }}
            - name: CONCOURSE_LDAP_USER_SEARCH_EMAIL_ATTR
              value: {{ .Values.concourse.web.auth.ldap.userSearchEmailAttr | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.userSearchFilter }}
            - name: CONCOURSE_LDAP_USER_SEARCH_FILTER
              value: {{ .Values.concourse.web.auth.ldap.userSearchFilter | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.userSearchIdAttr }}
            - name: CONCOURSE_LDAP_USER_SEARCH_ID_ATTR
              value: {{ .Values.concourse.web.auth.ldap.userSearchIdAttr | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.userSearchNameAttr }}
            - name: CONCOURSE_LDAP_USER_SEARCH_NAME_ATTR
              value: {{ .Values.concourse.web.auth.ldap.userSearchNameAttr | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.userSearchScope }}
            - name: CONCOURSE_LDAP_USER_SEARCH_SCOPE
              value: {{ .Values.concourse.web.auth.ldap.userSearchScope | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.ldap.userSearchUsername }}
            - name: CONCOURSE_LDAP_USER_SEARCH_USERNAME
              value: {{ .Values.concourse.web.auth.ldap.userSearchUsername | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.auth.oauth.enabled }}
            {{- if .Values.concourse.web.auth.oauth.displayName }}
            - name: CONCOURSE_OAUTH_DISPLAY_NAME
              value: {{ .Values.concourse.web.auth.oauth.displayName | quote }}
            {{- end }}
            - name: CONCOURSE_OAUTH_CLIENT_ID
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: oauth-client-id
            - name: CONCOURSE_OAUTH_CLIENT_SECRET
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: oauth-client-secret
            {{- if .Values.concourse.web.auth.oauth.authUrl }}
            - name: CONCOURSE_OAUTH_AUTH_URL
              value: {{ .Values.concourse.web.auth.oauth.authUrl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oauth.tokenUrl }}
            - name: CONCOURSE_OAUTH_TOKEN_URL
              value: {{ .Values.concourse.web.auth.oauth.tokenUrl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oauth.userinfoUrl }}
            - name: CONCOURSE_OAUTH_USERINFO_URL
              value: {{ .Values.concourse.web.auth.oauth.userinfoUrl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oauth.scope }}
            - name: CONCOURSE_OAUTH_SCOPE
              value: {{ .Values.concourse.web.auth.oauth.scope | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oauth.groupsKey }}
            - name: CONCOURSE_OAUTH_GROUPS_KEY
              value: {{ .Values.concourse.web.auth.oauth.groupsKey | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oauth.useCaCert }}
            - name: CONCOURSE_OAUTH_CA_CERT
              value: "{{ .Values.web.authSecretsPath }}/oauth_ca.cert"
            {{- end }}
            {{- if .Values.concourse.web.auth.oauth.skipSslValidation }}
            - name: CONCOURSE_OAUTH_SKIP_SSL_VALIDATION
              value: {{ .Values.concourse.web.auth.oauth.skipSslValidation | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.auth.oidc.enabled }}
            {{- if .Values.concourse.web.auth.oidc.displayName }}
            - name: CONCOURSE_OIDC_DISPLAY_NAME
              value: {{ .Values.concourse.web.auth.oidc.displayName | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oidc.issuer }}
            - name: CONCOURSE_OIDC_ISSUER
              value: {{ .Values.concourse.web.auth.oidc.issuer | quote }}
            {{- end }}
            - name: CONCOURSE_OIDC_CLIENT_ID
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: oidc-client-id
            - name: CONCOURSE_OIDC_CLIENT_SECRET
              valueFrom:
                secretKeyRef:
                  name: {{ template "concourse.concourse.fullname" . }}
                  key: oidc-client-secret
            {{- if .Values.concourse.web.auth.oidc.scope }}
            - name: CONCOURSE_OIDC_SCOPE
              value: {{ .Values.concourse.web.auth.oidc.scope | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oidc.groupsKey }}
            - name: CONCOURSE_OIDC_GROUPS_KEY
              value: {{ .Values.concourse.web.auth.oidc.groupsKey | quote}}
            {{- end }}
            {{- if .Values.concourse.web.auth.oidc.hostedDomains }}
            - name: CONCOURSE_OIDC_HOSTED_DOMAINS
              value: {{ .Values.concourse.web.auth.oidc.hostedDomains | quote }}
            {{- end }}
            {{- if .Values.concourse.web.auth.oidc.useCaCert }}
            - name: CONCOURSE_OIDC_CA_CERT
              value: "{{ .Values.web.authSecretsPath }}/oidc_ca.cert"
            {{- end }}
            {{- if .Values.concourse.web.auth.oidc.skipSslValidation }}
            - name: CONCOURSE_OIDC_SKIP_SSL_VALIDATION
              value: {{ .Values.concourse.web.auth.oidc.skipSslValidation | quote }}
            {{- end }}
            {{- end }}

            {{- if .Values.concourse.web.tsa.logLevel }}
            - name: CONCOURSE_TSA_LOG_LEVEL
              value: {{ .Values.concourse.web.tsa.logLevel | quote }}
            {{- end }}
            {{- if .Values.concourse.web.tsa.bindIp }}
            - name: CONCOURSE_TSA_BIND_IP
              value: {{ .Values.concourse.web.tsa.bindIp | quote }}
            {{- end }}
            - name: CONCOURSE_TSA_BIND_PORT
              value: {{ .Values.concourse.web.tsa.bindPort | quote }}
            {{- if .Values.concourse.web.tsa.bindDebugPort }}
            - name: CONCOURSE_TSA_BIND_DEBUG_PORT
              value: {{ .Values.concourse.web.tsa.bindDebugPort | quote }}
            {{- end }}
            {{- if .Values.concourse.web.tsa.peerIp }}
            - name: CONCOURSE_TSA_PEER_IP
              value: {{ .Values.concourse.web.tsa.peerIp | quote }}
            {{- end }}
            - name: CONCOURSE_TSA_HOST_KEY
              value: "{{ .Values.web.keySecretsPath }}/host_key"
            - name: CONCOURSE_TSA_AUTHORIZED_KEYS
              value: "{{ .Values.web.keySecretsPath }}/worker_key.pub"
            {{- if .Values.concourse.web.tsa.teamAuthorizedKeys }}
            - name: CONCOURSE_TSA_TEAM_AUTHORIZED_KEYS
              value: {{ .Values.concourse.web.tsa.teamAuthorizedKeys | quote }}
            {{- end }}
            {{- if .Values.concourse.web.tsa.atcUrl }}
            - name: CONCOURSE_TSA_ATC_URL
              value: {{ .Values.concourse.web.tsa.atcUrl | quote }}
            {{- end }}
            {{- if .Values.concourse.web.tsa.sessionSigningKey }}
            - name: CONCOURSE_TSA_SESSION_SIGNING_KEY
              value: {{ .Values.concourse.web.tsa.sessionSigningKey | quote }}
            {{- end }}
            {{- if .Values.concourse.web.tsa.heartbeatInterval }}
            - name: CONCOURSE_TSA_HEARTBEAT_INTERVAL
              value: {{ .Values.concourse.web.tsa.heartbeatInterval | quote }}
            {{- end }}
{{- if .Values.web.env }}
{{ toYaml .Values.web.env | indent 12 }}
{{- end }}
          ports:
            - name: atc
              containerPort: {{ .Values.concourse.web.bindPort }}
            {{- if .Values.concourse.web.tls.enabled }}
            - name: atc-tls
              containerPort: {{ .Values.concourse.web.tls.bindPort }}
            {{- end }}
            - name: tsa
              containerPort: {{ .Values.concourse.web.tsa.bindPort }}
            {{- if .Values.concourse.web.debugBindPort }}
            - name: atc-debug
              containerPort: {{ .Values.concourse.web.debugBindPort }}
            {{- end }}
            {{- if .Values.concourse.web.tsa.bindDebugPort }}
            - name: tsa-debug
              containerPort: {{ .Values.concourse.web.tsa.bindDebugPort }}
            {{- end }}
            {{- if .Values.concourse.web.prometheus.enabled }}
            - name: prometheus
              containerPort: {{ .Values.concourse.web.prometheus.bindPort }}
            {{- end }}
          livenessProbe:
{{ toYaml .Values.web.livenessProbe | indent 12 }}
          readinessProbe:
{{ toYaml .Values.web.readinessProbe | indent 12 }}
          resources:
{{ toYaml .Values.web.resources | indent 12 }}
          volumeMounts:
            - name: concourse-keys
              mountPath: {{ .Values.web.keySecretsPath | quote }}
              readOnly: true
            {{- if .Values.concourse.web.tls.enabled }}
            - name: web-tls
              mountPath: {{ .Values.web.tlsSecretsPath | quote }}
              readOnly: true
            {{- end }}
            {{- if .Values.concourse.web.vault.enabled }}
            - name: vault-keys
              mountPath: {{ .Values.web.vaultSecretsPath | quote }}
              readOnly: true
            {{- end }}
            {{- if not (eq (default "disable" .Values.concourse.web.postgres.sslmode) "disable") }}
            - name: postgresql-keys
              mountPath: {{ .Values.web.postgresqlSecretsPath | quote }}
              readOnly: true
            {{- end }}
            {{- if .Values.concourse.web.syslog.enabled }}
            - name: syslog-keys
              mountPath: {{ .Values.web.syslogSecretsPath | quote }}
              readOnly: true
            {{- end }}
            - name: auth-keys
              mountPath: {{ .Values.web.authSecretsPath | quote }}
              readOnly: true
{{- if .Values.web.additionalVolumeMounts }}
{{ toYaml .Values.web.additionalVolumeMounts | indent 12 }}
{{- end }}
      affinity:
{{- if .Values.web.additionalAffinities }}
{{ toYaml .Values.web.additionalAffinities | indent 8 }}
{{- end }}
      volumes:
{{- if .Values.web.additionalVolumes }}
{{ toYaml .Values.web.additionalVolumes | indent 8 }}
{{- end }}
        - name: concourse-keys
          secret:
            secretName: {{ template "concourse.concourse.fullname" . }}
            defaultMode: 0400
            items:
              - key: host-key
                path: host_key
              - key: session-signing-key
                path: session_signing_key
              - key: worker-key-pub
                path: worker_key.pub
        {{- if .Values.concourse.web.tls.enabled }}
        - name: web-tls
          secret:
            secretName: {{ template "concourse.concourse.fullname" . }}
            defaultMode: 0400
            items:
              - key: web-tls-cert
                path: client.cert
              - key: web-tls-key
                path: client.key
        {{- end }}
        {{- if .Values.concourse.web.vault.enabled }}
        - name: vault-keys
          secret:
            secretName: {{ template "concourse.concourse.fullname" . }}
            defaultMode: 0400
            items:
            {{- if .Values.concourse.web.vault.useCaCert }}
              - key: vault-ca-cert
                path: ca.cert
            {{- end }}
            {{- if eq (default "" .Values.concourse.web.vault.authBackend) "cert" }}
              - key: vault-client-cert
                path: client.cert
              - key: vault-client-key
                path: client.key
            {{- end }}
        {{- end }}
        {{- if not (eq (default "disable" .Values.concourse.web.postgres.sslmode) "disable") }}
        - name: postgresql-keys
          secret:
            secretName: {{ template "concourse.concourse.fullname" . }}
            defaultMode: 0400
            items:
              - key: postgresql-ca-cert
                path: ca.cert
              - key: postgresql-client-cert
                path: client.cert
              - key: postgresql-client-key
                path: client.key
        {{- end }}
        {{- if .Values.concourse.web.syslog.enabled }}
        - name: syslog-keys
          secret:
            secretName: {{ template "concourse.concourse.fullname" . }}
            defaultMode: 0400
            items:
              - key: syslog-ca-cert
                path: ca.cert
        {{- end }}
        - name: auth-keys
          secret:
            secretName: {{ template "concourse.concourse.fullname" . }}
            defaultMode: 0400
            items:
              {{- if .Values.concourse.web.auth.cf.useCaCert }}
              - key: cf-ca-cert
                path: cf_ca.cert
              {{- end }}
              {{- if .Values.concourse.web.auth.github.useCaCert }}
              - key: github-ca-cert
                path: github_ca.cert
              {{- end }}
              {{- if .Values.concourse.web.auth.ldap.useCaCert }}
              - key: ldap-ca-cert
                path: ldap_ca.cert
              {{- end }}
              {{- if .Values.concourse.web.auth.oauth.useCaCert }}
              - key: oauth-ca-cert
                path: oauth_ca.cert
              {{- end }}
              {{- if .Values.concourse.web.auth.oidc.useCaCert }}
              - key: oidc-ca-cert
                path: oidc_ca.cert
              {{- end }}
" 71 }, 72 { 73 "filePath": "templates/web-ingress.yaml", 74 "fileContents": "e3stIGlmIC5WYWx1ZXMud2ViLmluZ3Jlc3MuZW5hYmxlZCAtfX0Ke3stICRyZWxlYXNlTmFtZSA6PSAuUmVsZWFzZS5OYW1lIC19fQp7ey0gJHNlcnZpY2VOYW1lIDo9IGRlZmF1bHQgIndlYiIgLlZhbHVlcy53ZWIubmFtZU92ZXJyaWRlIC19fQp7ey0gJHNlcnZpY2VQb3J0IDo9IC5WYWx1ZXMuY29uY291cnNlLndlYi5iaW5kUG9ydCAtfX0KYXBpVmVyc2lvbjogZXh0ZW5zaW9ucy92MWJldGExCmtpbmQ6IEluZ3Jlc3MKbWV0YWRhdGE6CiAgbmFtZToge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53ZWIuZnVsbG5hbWUiIC4gfX0KICBsYWJlbHM6CiAgICBhcHA6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAuIH19CiAgICBjaGFydDogInt7IC5DaGFydC5OYW1lIH19LXt7IC5DaGFydC5WZXJzaW9uIH19IgogICAgcmVsZWFzZTogInt7IC5SZWxlYXNlLk5hbWUgfX0iCiAgICBoZXJpdGFnZTogInt7IC5SZWxlYXNlLlNlcnZpY2UgfX0iCiAgYW5ub3RhdGlvbnM6CiAgICB7ey0gcmFuZ2UgJGtleSwgJHZhbHVlIDo9IC5WYWx1ZXMud2ViLmluZ3Jlc3MuYW5ub3RhdGlvbnMgfX0KICAgIHt7ICRrZXkgfX06IHt7ICR2YWx1ZSB8IHF1b3RlIH19CiAgICB7ey0gZW5kIH19CnNwZWM6CiAgcnVsZXM6CiAgICB7ey0gcmFuZ2UgLlZhbHVlcy53ZWIuaW5ncmVzcy5ob3N0cyB9fQogICAgLSBob3N0OiB7eyAuIH19CiAgICAgIGh0dHA6CiAgICAgICAgcGF0aHM6CiAgICAgICAgICAtIGJhY2tlbmQ6CiAgICAgICAgICAgICAgc2VydmljZU5hbWU6IHt7IHByaW50ZiAiJXMtJXMiICRyZWxlYXNlTmFtZSAkc2VydmljZU5hbWUgfCB0cnVuYyA2MyB8IHRyaW1TdWZmaXggIi0iIH19CiAgICAgICAgICAgICAgc2VydmljZVBvcnQ6IHt7ICRzZXJ2aWNlUG9ydCB9fQogICAge3stIGVuZCAtfX0KICB7ey0gaWYgLlZhbHVlcy53ZWIuaW5ncmVzcy50bHMgfX0KICB0bHM6Cnt7IHRvWWFtbCAuVmFsdWVzLndlYi5pbmdyZXNzLnRscyB8IGluZGVudCA0IH19CiAge3stIGVuZCAtfX0Ke3stIGVuZCAtfX0K" 75 }, 76 { 77 "filePath": "templates/web-role.yaml", 78 "fileContents": "e3stIGlmIC5WYWx1ZXMucmJhYy5jcmVhdGUgLX19Cnt7LSBpZiAuVmFsdWVzLmNvbmNvdXJzZS53ZWIua3ViZXJuZXRlcy5lbmFibGVkIC19fQphcGlWZXJzaW9uOiByYmFjLmF1dGhvcml6YXRpb24uazhzLmlvL3t7IC5WYWx1ZXMucmJhYy5hcGlWZXJzaW9uIH19CmtpbmQ6IENsdXN0ZXJSb2xlCm1ldGFkYXRhOgogIG5hbWU6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAuIH19CiAgbGFiZWxzOgogICAgYXBwOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndlYi5mdWxsbmFtZSIgLiB9fQogICAgY2hhcnQ6IHt7IC5DaGFydC5OYW1lIH19LXt7IC5DaGFydC5WZXJzaW9uIH19CiAgICBoZXJpdGFnZToge3sgLlJlbGVhc2UuU2VydmljZSB9fQogICAgcmVsZWFzZToge3sgLlJlbGVhc2UuTmFtZSB9fQpydWxlczoKLSBhcGlHcm91cHM6IFsiIl0KICByZXNvdXJjZXM6IFsic2VjcmV0cyJdCiAgdmVyYnM6IFsiZ2V0Il0Ke3stIGVuZCAtfX0Ke3stIGVuZCAtfX0K" 79 }, 80 { 81 "filePath": "templates/web-rolebinding.yaml", 82 "fileContents": "e3stIGlmIC5WYWx1ZXMucmJhYy5jcmVhdGUgLX19Cnt7LSBpZiAuVmFsdWVzLmNvbmNvdXJzZS53ZWIua3ViZXJuZXRlcy5lbmFibGVkIC19fQp7ey0gcmFuZ2UgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLmt1YmVybmV0ZXMudGVhbXMgfX0KLS0tCmFwaVZlcnNpb246IHJiYWMuYXV0aG9yaXphdGlvbi5rOHMuaW8ve3sgJC5WYWx1ZXMucmJhYy5hcGlWZXJzaW9uIH19CmtpbmQ6IFJvbGVCaW5kaW5nCm1ldGFkYXRhOgogIG5hbWU6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAkIH19LXt7IC4gfX0KICBuYW1lc3BhY2U6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2UubmFtZXNwYWNlUHJlZml4IiAkIH19e3sgLiB9fQogIGxhYmVsczoKICAgIGFwcDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53ZWIuZnVsbG5hbWUiICQgfX0KICAgIGNoYXJ0OiB7eyAkLkNoYXJ0Lk5hbWUgfX0te3sgJC5DaGFydC5WZXJzaW9uIH19CiAgICBoZXJpdGFnZToge3sgJC5SZWxlYXNlLlNlcnZpY2UgfX0KICAgIHJlbGVhc2U6IHt7ICQuUmVsZWFzZS5OYW1lIH19CnJvbGVSZWY6CiAgYXBpR3JvdXA6IHJiYWMuYXV0aG9yaXphdGlvbi5rOHMuaW8KICBraW5kOiBDbHVzdGVyUm9sZQogIG5hbWU6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAkIH19CnN1YmplY3RzOgotIGtpbmQ6IFNlcnZpY2VBY2NvdW50CiAgbmFtZToge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53ZWIuZnVsbG5hbWUiICQgfX0KICBuYW1lc3BhY2U6IHt7ICQuUmVsZWFzZS5OYW1lc3BhY2UgfX0Ke3stIGVuZCB9fQp7ey0gZW5kIC19fQp7ey0gZW5kIC19fQo=" 83 }, 84 { 85 "filePath": "templates/web-serviceaccount.yaml", 86 "fileContents": "e3stIGlmIC5WYWx1ZXMucmJhYy5jcmVhdGUgLX19CmFwaVZlcnNpb246IHYxCmtpbmQ6IFNlcnZpY2VBY2NvdW50Cm1ldGFkYXRhOgogIG5hbWU6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud2ViLmZ1bGxuYW1lIiAuIH19CiAgbGFiZWxzOgogICAgYXBwOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndlYi5mdWxsbmFtZSIgLiB9fQogICAgY2hhcnQ6IHt7IC5DaGFydC5OYW1lIH19LXt7IC5DaGFydC5WZXJzaW9uIH19CiAgICBoZXJpdGFnZToge3sgLlJlbGVhc2UuU2VydmljZSB9fQogICAgcmVsZWFzZToge3sgLlJlbGVhc2UuTmFtZSB9fQp7ey0gZW5kIC19fQo=" 87 }, 88 { 89 "filePath": "templates/web-svc.yaml", 90 "fileContents": "YXBpVmVyc2lvbjogdjEKa2luZDogU2VydmljZQptZXRhZGF0YToKICBuYW1lOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndlYi5mdWxsbmFtZSIgLiB9fQogIGxhYmVsczoKICAgIGFwcDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53ZWIuZnVsbG5hbWUiIC4gfX0KICAgIGNoYXJ0OiAie3sgLkNoYXJ0Lk5hbWUgfX0te3sgLkNoYXJ0LlZlcnNpb24gfX0iCiAgICByZWxlYXNlOiAie3sgLlJlbGVhc2UuTmFtZSB9fSIKICAgIGhlcml0YWdlOiAie3sgLlJlbGVhc2UuU2VydmljZSB9fSIKICAgIHt7LSByYW5nZSAka2V5LCAkdmFsdWUgOj0gLlZhbHVlcy53ZWIuc2VydmljZS5sYWJlbHMgfX0KICAgIHt7ICRrZXkgfX06IHt7ICR2YWx1ZSB8IHF1b3RlIH19CiAgICB7ey0gZW5kIH19CiAgYW5ub3RhdGlvbnM6CiAgICB7ey0gcmFuZ2UgJGtleSwgJHZhbHVlIDo9IC5WYWx1ZXMud2ViLnNlcnZpY2UuYW5ub3RhdGlvbnMgfX0KICAgIHt7ICRrZXkgfX06IHt7ICR2YWx1ZSB8IHF1b3RlIH19CiAgICB7ey0gZW5kIH19CiAgICB7ey0gaWYgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLnByb21ldGhldXMuZW5hYmxlZCB9fQogICAgcHJvbWV0aGV1cy5pby9zY3JhcGU6ICJ0cnVlIgogICAgcHJvbWV0aGV1cy5pby9wb3J0OiB7eyAuVmFsdWVzLmNvbmNvdXJzZS53ZWIucHJvbWV0aGV1cy5iaW5kUG9ydCB8IHF1b3RlIH19CiAgICB7ey0gZW5kIH19CnNwZWM6CiAgdHlwZToge3sgLlZhbHVlcy53ZWIuc2VydmljZS50eXBlIH19CiAge3sgaWYgLlZhbHVlcy53ZWIuc2VydmljZS5sb2FkQmFsYW5jZXJTb3VyY2VSYW5nZXMgfX0KICBsb2FkQmFsYW5jZXJTb3VyY2VSYW5nZXM6CiAgICB7ey0gcmFuZ2UgLlZhbHVlcy53ZWIuc2VydmljZS5sb2FkQmFsYW5jZXJTb3VyY2VSYW5nZXMgfX0KICAgIC0ge3sgLiB9fQogICAge3stIGVuZCB9fQogIHt7IGVuZCB9fQogIHt7IGlmIGFuZCAoZXEgIkxvYWRCYWxhbmNlciIgLlZhbHVlcy53ZWIuc2VydmljZS50eXBlKSAuVmFsdWVzLndlYi5zZXJ2aWNlLmxvYWRCYWxhbmNlcklQIH19CiAgbG9hZEJhbGFuY2VySVA6IHt7IC5WYWx1ZXMud2ViLnNlcnZpY2UubG9hZEJhbGFuY2VySVAgfX0KICB7eyBlbmQgfX0KICBwb3J0czoKICAgIC0gbmFtZTogYXRjCiAgICAgIHBvcnQ6IHt7IC5WYWx1ZXMuY29uY291cnNlLndlYi5iaW5kUG9ydCB9fQogICAgICB0YXJnZXRQb3J0OiBhdGMKICAgICAge3sgaWYgYW5kIChlcSAiTm9kZVBvcnQiIC5WYWx1ZXMud2ViLnNlcnZpY2UudHlwZSkgLlZhbHVlcy53ZWIuc2VydmljZS5hdGNOb2RlUG9ydCB9fQogICAgICBub2RlUG9ydDoge3sgLlZhbHVlcy53ZWIuc2VydmljZS5hdGNOb2RlUG9ydH19CiAgICAgIHt7IGVuZCB9fQogICAge3stIGlmIC5WYWx1ZXMuY29uY291cnNlLndlYi50bHMuZW5hYmxlZCB9fQogICAgLSBuYW1lOiBhdGMtdGxzCiAgICAgIHBvcnQ6IHt7IC5WYWx1ZXMuY29uY291cnNlLndlYi50bHMuYmluZFBvcnQgfX0KICAgICAgdGFyZ2V0UG9ydDogYXRjLXRscwogICAgICB7eyBpZiBhbmQgKGVxICJOb2RlUG9ydCIgLlZhbHVlcy53ZWIuc2VydmljZS50eXBlKSAuVmFsdWVzLndlYi5zZXJ2aWNlLmF0Y1Rsc05vZGVQb3J0IH19CiAgICAgIG5vZGVQb3J0OiB7eyAuVmFsdWVzLndlYi5zZXJ2aWNlLmF0Y1Rsc05vZGVQb3J0fX0KICAgICAge3sgZW5kIH19CiAgICB7ey0gZW5kIH19CiAgICAtIG5hbWU6IHRzYQogICAgICBwb3J0OiB7eyAuVmFsdWVzLmNvbmNvdXJzZS53ZWIudHNhLmJpbmRQb3J0IH19CiAgICAgIHRhcmdldFBvcnQ6IHRzYQogICAgICB7eyBpZiBhbmQgKGVxICJOb2RlUG9ydCIgLlZhbHVlcy53ZWIuc2VydmljZS50eXBlKSAuVmFsdWVzLndlYi5zZXJ2aWNlLnRzYU5vZGVQb3J0IH19CiAgICAgIG5vZGVQb3J0OiB7eyAuVmFsdWVzLndlYi5zZXJ2aWNlLnRzYU5vZGVQb3J0fX0KICAgICAge3sgZW5kIH19CiAgICB7ey0gaWYgLlZhbHVlcy5jb25jb3Vyc2Uud2ViLnByb21ldGhldXMuZW5hYmxlZCB9fQogICAgLSBuYW1lOiBwcm9tZXRoZXVzCiAgICAgIHBvcnQ6IHt7IC5WYWx1ZXMuY29uY291cnNlLndlYi5wcm9tZXRoZXVzLmJpbmRQb3J0IH19CiAgICAgIHRhcmdldFBvcnQ6IHByb21ldGhldXMKICAgIHt7LSBlbmQgfX0KICBzZWxlY3RvcjoKICAgIGFwcDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53ZWIuZnVsbG5hbWUiIC4gfX0K" 91 }, 92 { 93 "filePath": "templates/worker-policy.yaml", 94 "fileContents": "YXBpVmVyc2lvbjogcG9saWN5L3YxYmV0YTEKa2luZDogUG9kRGlzcnVwdGlvbkJ1ZGdldAptZXRhZGF0YToKICBuYW1lOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndvcmtlci5mdWxsbmFtZSIgLiB9fQogIGxhYmVsczoKICAgIGFwcDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53b3JrZXIuZnVsbG5hbWUiIC4gfX0KICAgIGNoYXJ0OiAie3sgLkNoYXJ0Lk5hbWUgfX0te3sgLkNoYXJ0LlZlcnNpb24gfX0iCiAgICByZWxlYXNlOiAie3sgLlJlbGVhc2UuTmFtZSB9fSIKICAgIGhlcml0YWdlOiAie3sgLlJlbGVhc2UuU2VydmljZSB9fSIKc3BlYzoKICBtaW5BdmFpbGFibGU6IHt7IC5WYWx1ZXMud29ya2VyLm1pbkF2YWlsYWJsZSB9fQogIHNlbGVjdG9yOgogICAgbWF0Y2hMYWJlbHM6CiAgICAgIGFwcDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53b3JrZXIuZnVsbG5hbWUiIC4gfX0K" 95 }, 96 { 97 "filePath": "templates/worker-role.yaml", 98 "fileContents": "e3stIGlmIC5WYWx1ZXMucmJhYy5jcmVhdGUgLX19CmFwaVZlcnNpb246IHJiYWMuYXV0aG9yaXphdGlvbi5rOHMuaW8ve3sgLlZhbHVlcy5yYmFjLmFwaVZlcnNpb24gfX0Ka2luZDogUm9sZQptZXRhZGF0YToKICBuYW1lOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndvcmtlci5mdWxsbmFtZSIgLiB9fQogIGxhYmVsczoKICAgIGFwcDoge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53b3JrZXIuZnVsbG5hbWUiIC4gfX0KICAgIGNoYXJ0OiB7eyAuQ2hhcnQuTmFtZSB9fS17eyAuQ2hhcnQuVmVyc2lvbiB9fQogICAgaGVyaXRhZ2U6IHt7IC5SZWxlYXNlLlNlcnZpY2UgfX0KICAgIHJlbGVhc2U6IHt7IC5SZWxlYXNlLk5hbWUgfX0KcnVsZXM6Ci0gYXBpR3JvdXBzOgogIC0gZXh0ZW5zaW9ucwogIHJlc291cmNlczoKICAtIHBvZHNlY3VyaXR5cG9saWNpZXMKICByZXNvdXJjZU5hbWVzOgogIC0gcHJpdmlsZWdlZAogIHZlcmJzOgogIC0gdXNlCnt7LSBlbmQgLX19Cg==" 99 }, 100 { 101 "filePath": "templates/worker-rolebinding.yaml", 102 "fileContents": "e3stIGlmIC5WYWx1ZXMucmJhYy5jcmVhdGUgLX19CmFwaVZlcnNpb246IHJiYWMuYXV0aG9yaXphdGlvbi5rOHMuaW8ve3sgLlZhbHVlcy5yYmFjLmFwaVZlcnNpb24gfX0Ka2luZDogUm9sZUJpbmRpbmcKbWV0YWRhdGE6CiAgbmFtZToge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53b3JrZXIuZnVsbG5hbWUiIC4gfX0KICBsYWJlbHM6CiAgICBhcHA6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud29ya2VyLmZ1bGxuYW1lIiAuIH19CiAgICBjaGFydDoge3sgLkNoYXJ0Lk5hbWUgfX0te3sgLkNoYXJ0LlZlcnNpb24gfX0KICAgIGhlcml0YWdlOiB7eyAuUmVsZWFzZS5TZXJ2aWNlIH19CiAgICByZWxlYXNlOiB7eyAuUmVsZWFzZS5OYW1lIH19CnJvbGVSZWY6CiAgYXBpR3JvdXA6IHJiYWMuYXV0aG9yaXphdGlvbi5rOHMuaW8KICBraW5kOiBSb2xlCiAgbmFtZToge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53b3JrZXIuZnVsbG5hbWUiIC4gfX0Kc3ViamVjdHM6Ci0ga2luZDogU2VydmljZUFjY291bnQKICBuYW1lOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndvcmtlci5mdWxsbmFtZSIgLiB9fQp7ey0gZW5kIC19fQo=" 103 }, 104 { 105 "filePath": "templates/worker-serviceaccount.yaml", 106 "fileContents": "e3stIGlmIC5WYWx1ZXMucmJhYy5jcmVhdGUgLX19CmFwaVZlcnNpb246IHYxCmtpbmQ6IFNlcnZpY2VBY2NvdW50Cm1ldGFkYXRhOgogIG5hbWU6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud29ya2VyLmZ1bGxuYW1lIiAuIH19CiAgbGFiZWxzOgogICAgYXBwOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndvcmtlci5mdWxsbmFtZSIgLiB9fQogICAgY2hhcnQ6IHt7IC5DaGFydC5OYW1lIH19LXt7IC5DaGFydC5WZXJzaW9uIH19CiAgICBoZXJpdGFnZToge3sgLlJlbGVhc2UuU2VydmljZSB9fQogICAgcmVsZWFzZToge3sgLlJlbGVhc2UuTmFtZSB9fQp7ey0gZW5kIC19fQo=" 107 }, 108 { 109 "filePath": "templates/worker-statefulset.yaml", 110 "fileContents": "apiVersion: apps/v1beta1
kind: StatefulSet
metadata:
  name: {{ template "concourse.worker.fullname" . }}
  labels:
    app: {{ template "concourse.worker.fullname" . }}
    chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
    release: "{{ .Release.Name }}"
    heritage: "{{ .Release.Service }}"

spec:
  serviceName: {{ template "concourse.worker.fullname" . }}
  replicas: {{ .Values.worker.replicas }}
  template:
    metadata:
      labels:
        app: {{ template "concourse.worker.fullname" . }}
        release: "{{ .Release.Name }}"
      annotations:
        {{- range $key, $value := .Values.worker.annotations }}
        {{ $key }}: {{ $value | quote }}
        {{- end }}
    spec:
    {{- with .Values.worker.nodeSelector }}
      nodeSelector:
{{ toYaml . | indent 8 }}
    {{- end }}
      serviceAccountName: {{ if .Values.rbac.create }}{{ template "concourse.worker.fullname" . }}{{ else }}{{ .Values.rbac.workerServiceAccountName }}{{ end }}
      tolerations:
{{ toYaml .Values.worker.tolerations | indent 8 }}
      {{- if .Values.imagePullSecrets }}
      imagePullSecrets:
      {{- range .Values.imagePullSecrets }}
        - name: {{ . }}
      {{- end }}
      {{- end }}
      terminationGracePeriodSeconds: {{ .Values.worker.terminationGracePeriodSeconds }}
      containers:
        - name: {{ template "concourse.worker.fullname" . }}
          {{- if .Values.imageDigest }}
          image: "{{ .Values.image }}@{{ .Values.imageDigest }}"
          {{- else }}
          image: "{{ .Values.image }}:{{ .Values.imageTag }}"
          {{- end }}
          imagePullPolicy: {{ .Values.imagePullPolicy | quote }}
          command:
            - /bin/sh
          args:
            - -c
            - |-
              cp /dev/null /tmp/.liveness_probe
              rm -rf ${CONCOURSE_WORK_DIR:-/concourse-work-dir}/*
              while ! concourse retire-worker --name=${HOSTNAME} | grep -q worker-not-found; do
                touch /tmp/.pre_start_cleanup
                sleep 5
              done
              rm -f /tmp/.pre_start_cleanup
              concourse worker --name=${HOSTNAME} | tee -a /tmp/.liveness_probe
          livenessProbe:
            exec:
              command:
                - /bin/sh
                - -c
                - |-
                  FATAL_ERRORS=$( echo "${LIVENESS_PROBE_FATAL_ERRORS}" | grep -q '\S' && \
                      grep -F "${LIVENESS_PROBE_FATAL_ERRORS}" /tmp/.liveness_probe )
                  cp /dev/null /tmp/.liveness_probe
                  if [ ! -z "${FATAL_ERRORS}" ]; then
                    >&2 echo "Fatal error detected: ${FATAL_ERRORS}"
                    exit 1
                  fi
                  if [ -f /tmp/.pre_start_cleanup ]; then
                    >&2 echo "Still trying to clean up before starting concourse. 'fly prune-worker -w ${HOSTNAME}' might need to be called to force cleanup."
                    exit 1
                  fi
            failureThreshold: 1
            initialDelaySeconds: 10
            periodSeconds: 10
          lifecycle:
            preStop:
              exec:
                command:
                  - /bin/sh
                  - -c
                  - |-
                    while ! concourse retire-worker --name=${HOSTNAME} | grep -q worker-not-found; do
                      sleep 5
                    done
          env:
            {{- if .Values.concourse.worker.name }}
            - name: CONCOURSE_NAME
              value: {{ .Values.concourse.worker.name | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.tag }}
            - name: CONCOURSE_TAG
              value: {{ .Values.concourse.worker.tag | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.team }}
            - name: CONCOURSE_TEAM
              value: {{ .Values.concourse.worker.team | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.http_proxy }}
            - name: http_proxy
              value: {{ .Values.concourse.worker.http_proxy | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.https_proxy }}
            - name: https_proxy
              value: {{ .Values.concourse.worker.https_proxy | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.no_proxy }}
            - name: no_proxy
              value: {{ .Values.concourse.worker.no_proxy | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.ephemeral }}
            - name: CONCOURSE_EPHEMERAL
              value: {{ .Values.concourse.worker.ephemeral | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.bindDebugPort }}
            - name: CONCOURSE_BIND_DEBUG_PORT
              value: {{ .Values.concourse.worker.bindDebugPort | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.certsDir }}
            - name: CONCOURSE_CERTS_DIR
              value: {{ .Values.concourse.worker.certsDir | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.workDir }}
            - name: CONCOURSE_WORK_DIR
              value: {{ .Values.concourse.worker.workDir | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.bindIp }}
            - name: CONCOURSE_BIND_IP
              value: {{ .Values.concourse.worker.bindIp | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.bindPort }}
            - name: CONCOURSE_BIND_PORT
              value: {{ .Values.concourse.worker.bindPort | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.peerIp }}
            - name: CONCOURSE_PEER_IP
              value: {{ .Values.concourse.worker.peerIp | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.logLevel }}
            - name: CONCOURSE_LOG_LEVEL
              value: {{ .Values.concourse.worker.logLevel | quote }}
            {{- end }}

            - name: CONCOURSE_TSA_HOST
              value: "{{ template "concourse.web.fullname" . }}:{{ .Values.concourse.web.tsa.bindPort}}"
            - name: CONCOURSE_TSA_PUBLIC_KEY
              value: "{{ .Values.worker.keySecretsPath }}/host_key.pub"
            - name: CONCOURSE_TSA_WORKER_PRIVATE_KEY
              value: "{{ .Values.worker.keySecretsPath }}/worker_key"

            {{- if .Values.concourse.worker.garden.logLevel }}
            - name: CONCOURSE_GARDEN_LOG_LEVEL
              value: {{ .Values.concourse.worker.garden.logLevel | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.timeFormat }}
            - name: CONCOURSE_GARDEN_TIME_FORMAT
              value: {{ .Values.concourse.worker.garden.timeFormat | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.bindIp }}
            - name: CONCOURSE_GARDEN_BIND_IP
              value: {{ .Values.concourse.worker.garden.bindIp | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.bindPort }}
            - name: CONCOURSE_GARDEN_BIND_PORT
              value: {{ .Values.concourse.worker.garden.bindPort | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.bindSocket }}
            - name: CONCOURSE_GARDEN_BIND_SOCKET
              value: {{ .Values.concourse.worker.garden.bindSocket | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.debugBindIp }}
            - name: CONCOURSE_GARDEN_DEBUG_BIND_IP
              value: {{ .Values.concourse.worker.garden.debugBindIp | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.debugBindPort }}
            - name: CONCOURSE_GARDEN_DEBUG_BIND_PORT
              value: {{ .Values.concourse.worker.garden.debugBindPort | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.skipSetup }}
            - name: CONCOURSE_GARDEN_SKIP_SETUP
              value: {{ .Values.concourse.worker.garden.skipSetup | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.depot }}
            - name: CONCOURSE_GARDEN_DEPOT
              value: {{ .Values.concourse.worker.garden.depot | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.propertiesPath }}
            - name: CONCOURSE_GARDEN_PROPERTIES_PATH
              value: {{ .Values.concourse.worker.garden.propertiesPath | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.consoleSocketsPath }}
            - name: CONCOURSE_GARDEN_CONSOLE_SOCKETS_PATH
              value: {{ .Values.concourse.worker.garden.consoleSocketsPath | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.cleanupProcessDirsOnWait }}
            - name: CONCOURSE_GARDEN_CLEANUP_PROCESS_DIRS_ON_WAIT
              value: {{ .Values.concourse.worker.garden.cleanupProcessDirsOnWait | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.disablePrivilegedContainers }}
            - name: CONCOURSE_GARDEN_DISABLE_PRIVILEGED_CONTAINERS
              value: {{ .Values.concourse.worker.garden.disablePrivilegedContainers | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.uidMapStart }}
            - name: CONCOURSE_GARDEN_UID_MAP_START
              value: {{ .Values.concourse.worker.garden.uidMapStart | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.uidMapLength }}
            - name: CONCOURSE_GARDEN_UID_MAP_LENGTH
              value: {{ .Values.concourse.worker.garden.uidMapLength | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.gidMapStart }}
            - name: CONCOURSE_GARDEN_GID_MAP_START
              value: {{ .Values.concourse.worker.garden.gidMapStart | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.gidMapLength }}
            - name: CONCOURSE_GARDEN_GID_MAP_LENGTH
              value: {{ .Values.concourse.worker.garden.gidMapLength | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.defaultRootfs }}
            - name: CONCOURSE_GARDEN_DEFAULT_ROOTFS
              value: {{ .Values.concourse.worker.garden.defaultRootfs | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.defaultGraceTime }}
            - name: CONCOURSE_GARDEN_DEFAULT_GRACE_TIME
              value: {{ .Values.concourse.worker.garden.defaultGraceTime | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.destroyContainersOnStartup }}
            - name: CONCOURSE_GARDEN_DESTROY_CONTAINERS_ON_STARTUP
              value: {{ .Values.concourse.worker.garden.destroyContainersOnStartup | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.apparmor }}
            - name: CONCOURSE_GARDEN_APPARMOR
              value: {{ .Values.concourse.worker.garden.apparmor | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.assetsDir }}
            - name: CONCOURSE_GARDEN_ASSETS_DIR
              value: {{ .Values.concourse.worker.garden.assetsDir | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.dadooBin }}
            - name: CONCOURSE_GARDEN_DADOO_BIN
              value: {{ .Values.concourse.worker.garden.dadooBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.nstarBin }}
            - name: CONCOURSE_GARDEN_NSTAR_BIN
              value: {{ .Values.concourse.worker.garden.nstarBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.tarBin }}
            - name: CONCOURSE_GARDEN_TAR_BIN
              value: {{ .Values.concourse.worker.garden.tarBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.iptablesBin }}
            - name: CONCOURSE_GARDEN_IPTABLES_BIN
              value: {{ .Values.concourse.worker.garden.iptablesBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.iptablesRestoreBin }}
            - name: CONCOURSE_GARDEN_IPTABLES_RESTORE_BIN
              value: {{ .Values.concourse.worker.garden.iptablesRestoreBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.initBin }}
            - name: CONCOURSE_GARDEN_INIT_BIN
              value: {{ .Values.concourse.worker.garden.initBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.runtimePlugin }}
            - name: CONCOURSE_GARDEN_RUNTIME_PLUGIN
              value: {{ .Values.concourse.worker.garden.runtimePlugin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.runtimePluginExtraArg }}
            - name: CONCOURSE_GARDEN_RUNTIME_PLUGIN_EXTRA_ARG
              value: {{ .Values.concourse.worker.garden.runtimePluginExtraArg | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.graph }}
            - name: CONCOURSE_GARDEN_GRAPH
              value: {{ .Values.concourse.worker.garden.graph | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.graphCleanupThresholdInMegabytes }}
            - name: CONCOURSE_GARDEN_GRAPH_CLEANUP_THRESHOLD_IN_MEGABYTES
              value: {{ .Values.concourse.worker.garden.graphCleanupThresholdInMegabytes | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.persistentImage }}
            - name: CONCOURSE_GARDEN_PERSISTENT_IMAGE
              value: {{ .Values.concourse.worker.garden.persistentImage | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.imagePlugin }}
            - name: CONCOURSE_GARDEN_IMAGE_PLUGIN
              value: {{ .Values.concourse.worker.garden.imagePlugin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.imagePluginExtraArg }}
            - name: CONCOURSE_GARDEN_IMAGE_PLUGIN_EXTRA_ARG
              value: {{ .Values.concourse.worker.garden.imagePluginExtraArg | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.privilegedImagePlugin }}
            - name: CONCOURSE_GARDEN_PRIVILEGED_IMAGE_PLUGIN
              value: {{ .Values.concourse.worker.garden.privilegedImagePlugin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.privilegedImagePluginExtraArg }}
            - name: CONCOURSE_GARDEN_PRIVILEGED_IMAGE_PLUGIN_EXTRA_ARG
              value: {{ .Values.concourse.worker.garden.privilegedImagePluginExtraArg | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.dockerRegistry }}
            - name: CONCOURSE_GARDEN_DOCKER_REGISTRY
              value: {{ .Values.concourse.worker.garden.dockerRegistry | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.insecureDockerRegistry }}
            - name: CONCOURSE_GARDEN_INSECURE_DOCKER_REGISTRY
              value: {{ .Values.concourse.worker.garden.insecureDockerRegistry | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.networkPool }}
            - name: CONCOURSE_GARDEN_NETWORK_POOL
              value: {{ .Values.concourse.worker.garden.networkPool | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.allowHostAccess }}
            - name: CONCOURSE_GARDEN_ALLOW_HOST_ACCESS
              value: {{ .Values.concourse.worker.garden.allowHostAccess | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.denyNetwork }}
            - name: CONCOURSE_GARDEN_DENY_NETWORK
              value: {{ .Values.concourse.worker.garden.denyNetwork | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.dnsServer }}
            - name: CONCOURSE_GARDEN_DNS_SERVER
              value: {{ .Values.concourse.worker.garden.dnsServer | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.additionalDnsServer }}
            - name: CONCOURSE_GARDEN_ADDITIONAL_DNS_SERVER
              value: {{ .Values.concourse.worker.garden.additionalDnsServer | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.additionalHostEntry }}
            - name: CONCOURSE_GARDEN_ADDITIONAL_HOST_ENTRY
              value: {{ .Values.concourse.worker.garden.additionalHostEntry | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.externalIp }}
            - name: CONCOURSE_GARDEN_EXTERNAL_IP
              value: {{ .Values.concourse.worker.garden.externalIp | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.portPoolStart }}
            - name: CONCOURSE_GARDEN_PORT_POOL_START
              value: {{ .Values.concourse.worker.garden.portPoolStart | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.portPoolSize }}
            - name: CONCOURSE_GARDEN_PORT_POOL_SIZE
              value: {{ .Values.concourse.worker.garden.portPoolSize | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.portPoolPropertiesPath }}
            - name: CONCOURSE_GARDEN_PORT_POOL_PROPERTIES_PATH
              value: {{ .Values.concourse.worker.garden.portPoolPropertiesPath | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.mtu }}
            - name: CONCOURSE_GARDEN_MTU
              value: {{ .Values.concourse.worker.garden.mtu | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.networkPlugin }}
            - name: CONCOURSE_GARDEN_NETWORK_PLUGIN
              value: {{ .Values.concourse.worker.garden.networkPlugin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.networkPluginExtraArg }}
            - name: CONCOURSE_GARDEN_NETWORK_PLUGIN_EXTRA_ARG
              value: {{ .Values.concourse.worker.garden.networkPluginExtraArg | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.cpuQuotaPerShare }}
            - name: CONCOURSE_GARDEN_CPU_QUOTA_PER_SHARE
              value: {{ .Values.concourse.worker.garden.cpuQuotaPerShare | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.tcpMemoryLimit }}
            - name: CONCOURSE_GARDEN_TCP_MEMORY_LIMIT
              value: {{ .Values.concourse.worker.garden.tcpMemoryLimit | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.defaultContainerBlockioWeight }}
            - name: CONCOURSE_GARDEN_DEFAULT_CONTAINER_BLOCKIO_WEIGHT
              value: {{ .Values.concourse.worker.garden.defaultContainerBlockioWeight | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.maxContainers }}
            - name: CONCOURSE_GARDEN_MAX_CONTAINERS
              value: {{ .Values.concourse.worker.garden.maxContainers | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.disableSwapLimit }}
            - name: CONCOURSE_GARDEN_DISABLE_SWAP_LIMIT
              value: {{ .Values.concourse.worker.garden.disableSwapLimit | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.metricsEmissionInterval }}
            - name: CONCOURSE_GARDEN_METRICS_EMISSION_INTERVAL
              value: {{ .Values.concourse.worker.garden.metricsEmissionInterval | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.dropsondeOrigin }}
            - name: CONCOURSE_GARDEN_DROPSONDE_ORIGIN
              value: {{ .Values.concourse.worker.garden.dropsondeOrigin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.dropsondeDestination }}
            - name: CONCOURSE_GARDEN_DROPSONDE_DESTINATION
              value: {{ .Values.concourse.worker.garden.dropsondeDestination | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.containerdSocket }}
            - name: CONCOURSE_GARDEN_CONTAINERD_SOCKET
              value: {{ .Values.concourse.worker.garden.containerdSocket | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.useContainerdForProcesses }}
            - name: CONCOURSE_GARDEN_USE_CONTAINERD_FOR_PROCESSES
              value: {{ .Values.concourse.worker.garden.useContainerdForProcesses | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.garden.dnsProxyEnable }}
            - name: CONCOURSE_GARDEN_DNS_PROXY_ENABLE
              value: {{ .Values.concourse.worker.garden.dnsProxyEnable | quote }}
            {{- end }}

            {{- if .Values.concourse.worker.baggageclaim.logLevel }}
            - name: CONCOURSE_BAGGAGECLAIM_LOG_LEVEL
              value: {{ .Values.concourse.worker.baggageclaim.logLevel | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.bindIp }}
            - name: CONCOURSE_BAGGAGECLAIM_BIND_IP
              value: {{ .Values.concourse.worker.baggageclaim.bindIp | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.bindPort }}
            - name: CONCOURSE_BAGGAGECLAIM_BIND_PORT
              value: {{ .Values.concourse.worker.baggageclaim.bindPort | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.bindDebugPort }}
            - name: CONCOURSE_BAGGAGECLAIM_BIND_DEBUG_PORT
              value: {{ .Values.concourse.worker.baggageclaim.bindDebugPort | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.volumes }}
            - name: CONCOURSE_BAGGAGECLAIM_VOLUMES
              value: {{ .Values.concourse.worker.baggageclaim.volumes | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.driver }}
            - name: CONCOURSE_BAGGAGECLAIM_DRIVER
              value: {{ .Values.concourse.worker.baggageclaim.driver | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.btrfsBin }}
            - name: CONCOURSE_BAGGAGECLAIM_BTRFS_BIN
              value: {{ .Values.concourse.worker.baggageclaim.btrfsBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.mkfsBin }}
            - name: CONCOURSE_BAGGAGECLAIM_MKFS_BIN
              value: {{ .Values.concourse.worker.baggageclaim.mkfsBin | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.overlaysDir }}
            - name: CONCOURSE_BAGGAGECLAIM_OVERLAYS_DIR
              value: {{ .Values.concourse.worker.baggageclaim.overlaysDir | quote }}
            {{- end }}
            {{- if .Values.concourse.worker.baggageclaim.reapInterval }}
            - name: CONCOURSE_BAGGAGECLAIM_REAP_INTERVAL
              value: {{ .Values.concourse.worker.baggageclaim.reapInterval | quote }}
            {{- end }}
            - name: LIVENESS_PROBE_FATAL_ERRORS
              value: {{ .Values.worker.fatalErrors | quote }}

{{- if .Values.worker.env }}
{{ toYaml .Values.worker.env | indent 12 }}
{{- end }}
          resources:
{{ toYaml .Values.worker.resources | indent 12 }}
          securityContext:
            privileged: true
          volumeMounts:
            - name: concourse-keys
              mountPath: {{ .Values.worker.keySecretsPath | quote }}
              readOnly: true
            - name: concourse-work-dir
              mountPath: {{ .Values.concourse.workingDirectory | default "/concourse-work-dir" | quote }}
{{- if .Values.worker.additionalVolumeMounts }}
{{ toYaml .Values.worker.additionalVolumeMounts | indent 12 }}
{{- end }}
      affinity:
{{- if .Values.worker.additionalAffinities }}
{{ toYaml .Values.worker.additionalAffinities | indent 8 }}
{{- end }}
        podAntiAffinity:
          {{- if .Values.worker.hardAntiAffinity }}
          requiredDuringSchedulingIgnoredDuringExecution:
          - labelSelector:
              matchLabels:
                app: {{ template "concourse.worker.fullname" . }}
                release: {{ .Release.Name | quote }}
            topologyKey: kubernetes.io/hostname
          {{- else }}
          preferredDuringSchedulingIgnoredDuringExecution:
          - weight: 100
            podAffinityTerm:
              topologyKey: kubernetes.io/hostname
              labelSelector:
                matchLabels:
                  app: {{ template "concourse.worker.fullname" . }}
                  release: {{ .Release.Name | quote }}
          {{- end }}
      volumes:
{{- if .Values.worker.additionalVolumes }}
{{ toYaml .Values.worker.additionalVolumes | indent 8 }}
{{- end }}
        - name: concourse-keys
          secret:
            secretName: {{ template "concourse.concourse.fullname" . }}
            defaultMode: 0400
            items:
              - key: host-key-pub
                path: host_key.pub
              - key: worker-key
                path: worker_key
              - key: worker-key-pub
                path: worker_key.pub
{{- define "concourse.are-there-additional-volumes.with-the-name.concourse-work-dir" }}
  {{- range .Values.worker.additionalVolumes }}
    {{- if .name | eq "concourse-work-dir" }}
      {{- .name }}
    {{- end }}
  {{- end }}
{{- end }}
  {{- if .Values.persistence.enabled }}
  volumeClaimTemplates:
    - metadata:
        name: concourse-work-dir
      spec:
        accessModes:
          - {{ .Values.persistence.worker.accessMode | quote }}
        resources:
          requests:
            storage: {{ .Values.persistence.worker.size | quote }}
      {{- if .Values.persistence.worker.storageClass }}
      {{- if (eq "-" .Values.persistence.worker.storageClass) }}
        storageClassName: ""
      {{- else }}
        storageClassName: "{{ .Values.persistence.worker.storageClass }}"
      {{- end }}
      {{- end }}
  {{- else }}
      {{ if include "concourse.are-there-additional-volumes.with-the-name.concourse-work-dir" . | not }}
        - name: concourse-work-dir
          emptyDir:
            {{- if .Values.worker.emptyDirSize }}
            sizeLimit: {{ .Values.worker.emptyDirSize | quote }}
            {{- end }}
      {{- end }}
  {{- end }}
{{- if semverCompare "^1.7-0" .Capabilities.KubeVersion.GitVersion }}
  updateStrategy:
    type: {{ .Values.worker.updateStrategy }}
{{- end }}
  podManagementPolicy: {{ .Values.worker.podManagementPolicy }}
" 111 }, 112 { 113 "filePath": "templates/worker-svc.yaml", 114 "fileContents": "IyMgQSBIZWFkbGVzcyBTZXJ2aWNlIGlzIHJlcXVpcmVkIHdoZW4gdXNpbmcgYSBTdGF0ZWZ1bFNldAojIyByZWY6IGh0dHBzOi8va3ViZXJuZXRlcy5pby9kb2NzL3R1dG9yaWFscy9zdGF0ZWZ1bC1hcHBsaWNhdGlvbi9iYXNpYy1zdGF0ZWZ1bC1zZXQvCiMjCmFwaVZlcnNpb246IHYxCmtpbmQ6IFNlcnZpY2UKbWV0YWRhdGE6CiAgbmFtZToge3sgdGVtcGxhdGUgImNvbmNvdXJzZS53b3JrZXIuZnVsbG5hbWUiIC4gfX0KICBsYWJlbHM6CiAgICBhcHA6IHt7IHRlbXBsYXRlICJjb25jb3Vyc2Uud29ya2VyLmZ1bGxuYW1lIiAuIH19CiAgICBjaGFydDogInt7IC5DaGFydC5OYW1lIH19LXt7IC5DaGFydC5WZXJzaW9uIH19IgogICAgcmVsZWFzZTogInt7IC5SZWxlYXNlLk5hbWUgfX0iCiAgICBoZXJpdGFnZTogInt7IC5SZWxlYXNlLlNlcnZpY2UgfX0iCnNwZWM6CiAgdHlwZTogQ2x1c3RlcklQCiAgY2x1c3RlcklQOiBOb25lCiAgIyMgV2UgZG8gTk9UIGV4cG9zZSBhbnkgcG9ydCBhcyB3b3JrZXJzIHdpbGwgZm9yd2FyZCBjb25uZWN0aW9ucyB3aXRoIHRoZSBBVEMgdGhyb3VnaCBhIFRTQSByZXZlcnNlLXR1bm5lbAogICMjIHJlZjogaHR0cHM6Ly9jb25jb3Vyc2UtY2kub3JnL2FyY2hpdGVjdHVyZS5odG1sI2FyY2hpdGVjdHVyZS13b3JrZXIKICAjIwogIHBvcnRzOiBbXQogIHNlbGVjdG9yOgogICAgYXBwOiB7eyB0ZW1wbGF0ZSAiY29uY291cnNlLndvcmtlci5mdWxsbmFtZSIgLiB9fQo=" 115 }, 116 { 117 "filePath": "values.yaml", 118 "fileContents": "## Default values for Concourse Helm Chart.
## This is a YAML-formatted file.
## Declare variables to be passed into your templates.

## Override the name of the Chart.
##
# nameOverride:

## Concourse image.
##
image: concourse/concourse

## Concourse image version.
## ref: https://hub.docker.com/r/concourse/concourse/tags/
##
imageTag: "4.2.2"

## Specific image digest to use in place of a tag.
## ref: https://kubernetes.io/docs/concepts/configuration/overview/#container-images
##
# imageDigest: sha256:54ea351808b55ecc14af6590732932e2a6a0ed8f6d10f45e8be3b51165d5526a

## Specify a imagePullPolicy: 'Always' if imageTag is 'latest', else set to 'IfNotPresent'.
## ref: https://kubernetes.io/docs/user-guide/images/#pre-pulling-images
##
imagePullPolicy: IfNotPresent

## Optionally specify an array of imagePullSecrets.
## Secrets must be manually created in the namespace.
## ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/
##
# imagePullSecrets:
#   - myRegistrKeySecretName

## Configuration values for Concourse.
## ref: https://concourse-ci.org/setting-up.html
##
concourse:
  web:
    ## Minimum level of logs to see.
    # logLevel: info
    ## IP address on which to listen for web traffic.
    # bindIp: 0.0.0.0
    ## Port on which to listen for HTTP traffic.
    bindPort: 8080
    ## TLS configurations for the web component to be able to serve HTTPS traffic.
    ## Once enabled, consumes the certificates set via secrets.
    #
    tls:
      enabled: false
      ## Port on which to listen for HTTPS traffic.
      # bindPort:
    ## URL used to reach any ATC from the outside world.
    # externalUrl: http://127.0.0.1:8080
    ## URL used to reach this ATC from other ATCs in the cluster.
    # peerUrl: http://127.0.0.1:8080
    ## Enable encryption of pipeline configuration. Encryption keys can be set via secrets.
    ## See https://concourse-ci.org/encryption.html
    ##
    encryption:
      enabled: false
    localAuth:
      enabled: true
    ## IP address on which to listen for the pprof debugger endpoints.
    # debugBindIp: 127.0.0.1
    ## Port on which to listen for the pprof debugger endpoints.
    # debugBindPort: 8079
    ## Length of time for a intercepted session to be idle before terminating.
    # interceptIdleTimeout: 0m
    ## Time limit on checking for new versions of resources.
    # globalResourceCheckTimeout: 1h
    ## Interval on which to check for new versions of resources.
    # resourceCheckingInterval: 1m
    ## Interval on which to check for new versions of resource types.
    # resourceTypeCheckingInterval: 1m
    ## Method by which a worker is selected during container placement.
    # containerPlacementStrategy: volume-locality
    ## How long to wait for Baggageclaim to send the response header.
    # baggageclaimResponseHeaderTimeout: 1m
    ## Directory containing downloadable CLI binaries.
    # cliArtifactsDir:
    ## Log database queries.
    # logDbQueries:
    ## Interval on which to run build tracking.
    # buildTrackerInterval: 10s
    ## Default build logs to retain, 0 means all
    # defaultBuildLogsToRetain:
    ## Maximum build logs to retain, 0 means not specified. Will override values configured in jobs
    # maxBuildLogsToRetain:
    ## Default max number of cpu shares per task, 0 means unlimited
    # defaultTaskCpuLimit:
    ## Default maximum memory per task, 0 means unlimited
    # defaultTaskMemoryLimit:
    postgres:
      ## The host to connect to.
      host: 127.0.0.1
      ## The port to connect to.
      port: 5432
      ## Path to a UNIX domain socket to connect to.
      # socket:
      ## Whether or not to use SSL.
      sslmode: disable
      ## Dialing timeout. (0 means wait indefinitely)
      connectTimeout: 5m
      ## The name of the database to use.
      database: atc

    kubernetes:

      ## Enable the use of in-cluster Kubernetes Secrets.
      ##
      enabled: true

      ## Prefix to use for Kubernetes namespaces under which secrets will be looked up. Defaults to
      ## the Release name hyphen, e.g. "my-release-" produces namespace "my-release-main" for the
      ## "main" Concourse team.
      ##
      ## namespacePrefix:

      ## Teams to create namespaces for to hold secrets.
      teams:
        - main

      ## Create the Kubernetes namespace for each team listed above.
      createTeamNamespaces: true

      ## When true, namespaces are not deleted when the release is deleted.
      ## Irrelevant if the namespaces are not created by this chart.
      keepNamespaces: true

      ## Path to Kubernetes config when running ATC outside Kubernetes.
      # configPath:

    awsSecretsManager:
      ## Enable the use of AWS Secrets Manager.
      ##
      enabled: false

      ## AWS region to use when reading from Secrets Manager
      ##
      # region:

      ## pipeline-specific template for Secrets Manager parameters, defaults to: /concourse/{team}/{pipeline}/{secret}
      ##
      # pipelineSecretTemplate:

      ## team-specific template for Secrets Manager parameters, defaults to: /concourse/{team}/{secret}
      ##
      # teamSecretTemplate: ''

    awsSsm:
      ## Enable the use of AWS SSM.
      ##
      enabled: false

      ## AWS region to use when reading from SSM
      ##
      # region:

      ## pipeline-specific template for SSM parameters, defaults to: /concourse/{team}/{pipeline}/{secret}
      ##
      # pipelineSecretTemplate:

      ## team-specific template for SSM parameters, defaults to: /concourse/{team}/{secret}
      ##
      # teamSecretTemplate: ''


    vault:
      enabled: false

      ## URL pointing to vault addr (i.e. http://vault:8200).
      ##
      # url:

      ## vault path under which to namespace credential lookup, defaults to /concourse.
      ##
      pathPrefix: /concourse

      ## if the Vault server is using a self-signed certificate, set this to true,
      ## and provide a value for the cert in secrets.
      ##
      # useCaCert:

      ## vault authentication backend, leave this blank if using an initial periodic token
      ## currently supported backends: token, approle, cert.
      ##
      # authBackend:

      ## Cache returned secrets for their lease duration in memory
      # cache:
      ## If the cache is enabled, and this is set, override secrets lease duration with a maximum value
      # maxLease:
      ## Path to a directory of PEMEncoded CA cert files to verify the vault server SSL cert.
      # caPath:
      ## If set, is used to set the SNI host when connecting via TLS.
      # serverName:
      ## Enable insecure SSL verification.
      # insecureSkipVerify:
        ## Client token for accessing secrets within the Vault server.
        # clientToken:
      ## Auth backend to use for logging in to Vault.
      # authBackend:
      ## Time after which to force a reLogin. If not set, the token will just be continuously renewed.
      # authBackendMaxTtl:
      ## The maximum time between retries when logging in or reAuthing a secret.
      retryMax: 5m
      ## The initial time between retries when logging in or reAuthing a secret.
      retryInitial: 1s
    ## Don't actually do any automatic scheduling or checking.
    # noop:
    staticWorker:
      enabled: false
      ## A Garden API endpoint to register as a worker.
      gardenUrl:
      ## A Baggageclaim API endpoint to register with the worker.
      baggageclaimUrl:
      ## A resource type to advertise for the worker. Can be specified multiple times.
      resource:
    metrics:
      ## Host string to attach to emitted metrics.
      hostName:
      ## A keyValue attribute to attach to emitted metrics. Can be specified multiple times.
      attribute:
    datadog:
      enabled: false
      ## Use IP of node the pod is scheduled on, overrides `agentHost`
      agentHostUseHostIP: false
      ## Datadog agent host to expose dogstatsd metrics
      agentHost: 127.0.0.1
      ## Datadog agent port to expose dogstatsd metrics
      agentPort: 8125
      ## Prefix for all metrics to easily find them in Datadog
      # prefix: concoursedev
    influxdb:
      enabled: false
      ## InfluxDB server address to emit points to.
      url: http://127.0.0.1:8086
      ## InfluxDB database to write points to.
      database: concourse
      ## InfluxDB server username.
      # username:
      ## Skip SSL verification when emitting to InfluxDB.
      insecureSkipVerify: false
    ## Emit metrics to logs.
    # emitToLogs:
    newrelic:
      enabled: false
      ## New Relic Account ID
      # accountId:
      ## New Relic Insights API Key
      # apiKey:
      ## An optional prefix for emitted New Relic events
      # servicePrefix:
    prometheus:
      enabled: false
      ## IP to listen on to expose Prometheus metrics.
      bindIp: "0.0.0.0"
      ## Port to listen on to expose Prometheus metrics.
      bindPort: 9391
    riemann:
      enabled: false
      ## Riemann server address to emit metrics to.
      # host:
      ## Port of the Riemann server to emit metrics to.
      port: 5555
      ## An optional prefix for emitted Riemann services
      # servicePrefix:
      ## Tag to attach to emitted metrics. Can be specified multiple times.
      # tag:
    ## The value to set for XFrame-Options. If omitted, the header is not set.
    # xFrameOptions:
    gc:
      overrideDefaults: false
      ## Interval on which to perform garbage collection.
      interval: 30s
      ## Grace period before reaping oneOff task containers
      oneOffGracePeriod: 5m
    syslog:
      enabled: false
      ## Client hostname with which the build logs will be sent to the syslog server.
      hostName: atc-syslog-drainer
      ## Remote syslog server address with port (Example: 0.0.0.0:514).
      # address:
      ## Transport protocol for syslog messages (Currently supporting tcp, udp & tls).
      # transport:
      ## Interval over which checking is done for new build logs to send to syslog server (duration measurement units are s/m/h; eg. 30s/30m/1h)
      drainInterval: 30s
      ## if the syslog server is using a self-signed certificate, set this to true,
      ## and provide a value for the cert in secrets.
      useCaCert: false
    auth:
      ## Force sending secure flag on http cookies
      # cookieSecure:
      ## Length of time for which tokens are valid. Afterwards, users will have to log back in.
      # duration: 24h
      mainTeam:
        ## List of whitelisted local concourse users. These are the users you've added at atc startup with the addLocalUser setting.
        localUser: "test"
        ## Setting this flag will whitelist all logged in users in the system. ALL OF THEM. If, for example, you've configured GitHub, any user with a GitHub account will have access to your team.
        # allowAllUsers:
        ## Authentication (Main Team) (CloudFoundry)
        cf:
          ## List of whitelisted CloudFoundry users.
          user:
          ## List of whitelisted CloudFoundry orgs
          org:
          ## List of whitelisted CloudFoundry spaces
          space:
          ## (Deprecated) List of whitelisted CloudFoundry space guids
          spaceGuid:
        ## Authentication (Main Team) (GitHub)
        github:
          ## List of whitelisted GitHub users
          user:
          ## List of whitelisted GitHub orgs
          org:
          ## List of whitelisted GitHub teams
          team:
        ## Authentication (Main Team) (GitLab)
        gitlab:
          ## List of whitelisted GitLab users
          user:
          ## List of whitelisted GitLab groups
          group:
        ## Authentication (Main Team) (LDAP)
        ldap:
          ## List of whitelisted LDAP users
          user:
          ## List of whitelisted LDAP groups
          group:
        ## Authentication (Main Team) (OAuth2)
        oauth:
          ## List of whitelisted OAuth2 users
          user:
          ## List of whitelisted OAuth2 groups
          group:
        ## Authentication (Main Team) (OIDC)
        oidc:
          ## List of whitelisted OIDC users
          user:
          ## List of whitelisted OIDC groups
          group:
      ## Authentication (CloudFoundry)
      cf:
        enabled: false
        ## (Required) The base API URL of your CF deployment. It will use this information to discover information about the authentication provider.
        # apiUrl: https://api.run.pivotal.io
        ## CA Certificate
        # useCaCert:
        ## Skip SSL validation
        # skipSslValidation:
      ## Authentication (GitHub)
      github:
        enabled: false
        ## Hostname of GitHub Enterprise deployment (No scheme, No trailing slash)
        # host:
        ## CA certificate of GitHub Enterprise deployment
        # useCaCert:
      ## Authentication (GitLab)
      gitlab:
        enabled: false
        ## Hostname of Gitlab Enterprise deployment (Include scheme, No trailing slash)
        # host:
      ## Authentication (LDAP)
      ldap:
        enabled: false
        ## The auth provider name displayed to users on the login page
        # displayName:
        ## (Required) The host and optional port of the LDAP server. If port isn't supplied, it will be guessed based on the TLS configuration. 389 or 636.
        # host:
        ## (Required) Bind DN for searching LDAP users and groups. Typically this is a readOnly user.
        # bindDn:
        ## (Required) Bind Password for the user specified by 'bindDn'
        # bindPw:
        ## Required if LDAP host does not use TLS.
        # insecureNoSsl:
        ## Skip certificate verification
        # insecureSkipVerify:
        ## Start on insecure port, then negotiate TLS
        # startTls:
        ## CA certificate
        # useCaCert:
        ## BaseDN to start the search from. For example 'cn=users,dc=example,dc=com'
        # userSearchBaseDn:
        ## Optional filter to apply when searching the directory. For example '(objectClass=person)'
        # userSearchFilter:
        ## Attribute to match against the inputted username. This will be translated and combined with the other filter as '(<attr>=<username>)'.
        # userSearchUsername:
        ## Can either be: 'sub'  search the whole sub tree or 'one' - only search one level. Defaults to 'sub'.
        # userSearchScope:
        ## A mapping of attributes on the user entry to claims. Defaults to 'uid'.
        # userSearchIdAttr:
        ## A mapping of attributes on the user entry to claims. Defaults to 'mail'.
        # userSearchEmailAttr:
        ## A mapping of attributes on the user entry to claims.
        # userSearchNameAttr:
        ## BaseDN to start the search from. For example 'cn=groups,dc=example,dc=com'
        # groupSearchBaseDn:
        ## Optional filter to apply when searching the directory. For example '(objectClass=posixGroup)'
        # groupSearchFilter:
        ## Can either be: 'sub'  search the whole sub tree or 'one' - only search one level. Defaults to 'sub'.
        # groupSearchScope:
        ## Adds an additional requirement to the filter that an attribute in the group match the user's attribute value. The exact filter being added is: (<groupAttr>=<userAttr value>)
        # groupSearchUserAttr:
        ## Adds an additional requirement to the filter that an attribute in the group match the user's attribute value. The exact filter being added is: (<groupAttr>=<userAttr value>)
        # groupSearchGroupAttr:
        ## The attribute of the group that represents its name.
        # groupSearchNameAttr:
      ## Authentication (OAuth2)
      oauth:
        enabled: false
        ## The auth provider name displayed to users on the login page
        # displayName:
        ## (Required) Authorization URL
        # authUrl:
        ## (Required) Token URL
        # tokenUrl:
        ## UserInfo URL
        # userinfoUrl:
        ## Any additional scopes that need to be requested during authorization
        # scope:
        ## The groups key indicates which claim to use to map external groups to Concourse teams.
        # groupsKey:
        ## CA Certificate
        # useCaCert:
        ## Skip SSL validation
        # skipSslValidation:
      ## Authentication (OIDC)
      oidc:
        enabled: false
        ## The auth provider name displayed to users on the login page
        # displayName:
        ## (Required) An OIDC issuer URL that will be used to discover provider configuration using the .wellKnown/openid-configuration
        # issuer:
        ## Any additional scopes that need to be requested during authorization
        # scope:
        ## The groups key indicates which claim to use to map external groups to Concourse teams.
        # groupsKey:
        ## CA Certificate
        # useCaCert:
        ## Skip SSL validation
        # skipSslValidation:
    tsa:
      ## Minimum level of logs to see.
      # logLevel: info
      ## IP address on which to listen for SSH.
      # bindIp: 0.0.0.0
      ## Port on which to listen for SSH.
      bindPort: 2222
      ## Port on which to listen for TSA pprof server.
      # bindDebugPort: 8089
      ## IP address of this TSA, reachable by the ATCs. Used for forwarded worker addresses.
      # peerIp:
      ## Path to private key to use for the SSH server.
      # hostKey:
      ## Path to file containing keys to authorize, in SSH authorized_keys format (one public key per line).
      # authorizedKeys:
      ## Path to file containing keys to authorize, in SSH authorized_keys format (one public key per line).
      # teamAuthorizedKeys:
      ## ATC API endpoints to which workers will be registered.
      # atcUrl:
      ## Path to private key to use when signing tokens in reqests to the ATC during registration.
      # sessionSigningKey:
      ## interval on which to heartbeat workers to the ATC
      # heartbeatInterval: 30s
  worker:
    ## The name to set for the worker during registration. If not specified, the hostname will be used.
    # name:
    ## A tag to set during registration. Can be specified multiple times.
    # tag:
    ## The name of the team that this worker will be assigned to.
    # team:
    ## HTTP proxy endpoint to use for containers.
    # http_proxy:
    ## HTTPS proxy endpoint to use for containers.
    # https_proxy:
    ## Blacklist of addresses to skip the proxy when reaching.
    # no_proxy:
    ## If set, the worker will be immediately removed upon stalling.
    # ephemeral:
    ## Port on which to listen for beacon pprof server.
    # bindDebugPort: 9099
    ## Version of the worker. This is normally baked in to the binary, so this flag is hidden.
    # version:
    ## Directory in which to place container data.
    workDir: /concourse-work-dir
    ## IP address on which to listen for the Garden server.
    # bindIp: 127.0.0.1
    ## Port on which to listen for the Garden server.
    # bindPort: 7777
    ## IP used to reach this worker from the ATC nodes.
    # peerIp:
    ## Minimum level of logs to see.
    # logLevel: info
    tsa:
      ## TSA host to forward the worker through. Can be specified multiple times.
      host: 127.0.0.1:2222
      ## File containing a public key to expect from the TSA.
      # publicKey:
      ## File containing the private key to use when authenticating to the TSA.
      # workerPrivateKey:
    garden:
      ## Minimum level of logs to see.
      # logLevel: info
      ## format of log timestamps
      # timeFormat: unix-epoch
      ## Bind with TCP on the given IP.
      # bindIp:
      ## Bind with TCP on the given port.
      bindPort: 7777
      ## Bind with Unix on the given socket path.
      # bindSocket: /tmp/garden.sock
      ## Bind the debug server on the given IP.
      # debugBindIp:
      ## Bind the debug server to the given port.
      # debugBindPort: 17013
      ## Skip the preparation part of the host that requires root privileges
      # skipSetup:
      ## Directory in which to store container data.
      # depot: /var/run/gdn/depot
      ## Path in which to store properties.
      # propertiesPath:
      ## Path in which to store temporary sockets
      # consoleSocketsPath:
      ## Clean up proccess dirs on first invocation of wait
      # cleanupProcessDirsOnWait:
      ## Disable creation of privileged containers
      # disablePrivilegedContainers:
      ## The lowest numerical subordinate user ID the user is allowed to map
      # uidMapStart: 1
      ## The number of numerical subordinate user IDs the user is allowed to map
      # uidMapLength:
      ## The lowest numerical subordinate group ID the user is allowed to map
      # gidMapStart: 1
      ## The number of numerical subordinate group IDs the user is allowed to map
      # gidMapLength:
      ## Default rootfs to use when not specified on container creation.
      # defaultRootfs:
      ## Default time after which idle containers should expire.
      # defaultGraceTime:
      ## Clean up all the existing containers on startup.
      # destroyContainersOnStartup:
      ## Apparmor profile to use for unprivileged container processes
      # apparmor:
      ## Directory in which to extract packaged assets
      # assetsDir: /var/gdn/assets
      ## Path to the 'dadoo' binary.
      # dadooBin:
      ## Path to the 'nstar' binary.
      # nstarBin:
      ## Path to the 'tar' binary.
      # tarBin:
      ## path to the iptables binary
      # iptablesBin: /sbin/iptables
      ## path to the iptables-restore binary
      # iptablesRestoreBin: /sbin/iptables-restore
      ## Path execute as pid 1 inside each container.
      # initBin:
      ## Path to the runtime plugin binary.
      # runtimePlugin: runc
      ## Extra argument to pass to the runtime plugin. Can be specified multiple times.
      # runtimePluginExtraArg:
      ## Directory on which to store imported rootfs graph data.
      # graph:
      ## Disk usage of the graph dir at which cleanup should trigger, or -1 to disable graph cleanup.
      # graphCleanupThresholdInMegabytes: -1
      ## Image that should never be garbage collected. Can be specified multiple times.
      # persistentImage:
      ## Path to image plugin binary.
      # imagePlugin:
      ## Extra argument to pass to the image plugin to create unprivileged images. Can be specified multiple times.
      # imagePluginExtraArg:
      ## Path to privileged image plugin binary.
      # privilegedImagePlugin:
      ## Extra argument to pass to the image plugin to create privileged images. Can be specified multiple times.
      # privilegedImagePluginExtraArg:
      ## Docker registry API endpoint.
      # dockerRegistry: registry-1.docker.io
      ## Docker registry to allow connecting to even if not secure. Can be specified multiple times.
      # insecureDockerRegistry:
      ## Network range to use for dynamically allocated container subnets.
      # networkPool: 10.254.0.0/22
      ## Allow network access to the host machine.
      # allowHostAccess:
      ## Network ranges to which traffic from containers will be denied. Can be specified multiple times.
      # denyNetwork:
      ## DNS server IP address to use instead of automatically determined servers. Can be specified multiple times.
      # dnsServer:
      ## DNS server IP address to append to the automatically determined servers. Can be specified multiple times.
      # additionalDnsServer:
      ## Per line hosts entries. Can be specified multiple times and will be appended verbatim in order to /etc/hosts
      # additionalHostEntry:
      ## IP address to use to reach container's mapped ports. Autodetected if not specified.
      # externalIp:
      ## Start of the ephemeral port range used for mapped container ports.
      # portPoolStart: 61001
      ## Size of the port pool used for mapped container ports.
      # portPoolSize: 4534
      ## Path in which to store port pool properties.
      # portPoolPropertiesPath:
      ## MTU size for container network interfaces. Defaults to the MTU of the interface used for outbound access by the host. Max allowed value is 1500.
      # mtu:
      ## Path to network plugin binary.
      # networkPlugin:
      ## Extra argument to pass to the network plugin. Can be specified multiple times.
      # networkPluginExtraArg:
      ## Maximum number of microseconds each cpu share assigned to a container allows per quota period
      # cpuQuotaPerShare: 0
      ## Set hard limit for the tcp buf memory, value in bytes
      # tcpMemoryLimit: 0
      ## Default block IO weight assigned to a container
      # defaultContainerBlockioWeight: 0
      ## Maximum number of containers that can be created.
      # maxContainers: 0
      ## Disable swap memory limit
      # disableSwapLimit:
      ## Interval on which to emit metrics.
      # metricsEmissionInterval: 1m
      ## Origin identifier for Dropsonde-emitted metrics.
      # dropsondeOrigin: garden-linux
      ## Destination for Dropsonde-emitted metrics.
      # dropsondeDestination: 127.0.0.1:3457
      ## Path to a containerd socket.
      # containerdSocket:
      ## Use containerd to run processes in containers.
      # useContainerdForProcesses:
      ## Enable proxy DNS server.
      # dnsProxyEnable:
    baggageclaim:
      ## Minimum level of logs to see.
      # logLevel: info
      ## IP address on which to listen for API traffic.
      # bindIp: 127.0.0.1
      ## Port on which to listen for API traffic.
      # bindPort: 7788
      ## Port on which to listen for baggageclaim pprof server.
      # bindDebugPort: 8099
      ## Directory in which to place volume data.
      # volumes:
      ## Driver to use for managing volumes.
      driver: naive
      ## Path to btrfs binary
      # btrfsBin: btrfs
      ## Path to mkfs.btrfs binary
      # mkfsBin: mkfs.btrfs
      ## Path to directory in which to store overlay data
      # overlaysDir:
      ## Interval on which to reap expired volumes.
      # reapInterval: 10s

## Configuration values for Concourse Web components.
##
web:
  ## Override the components name (defaults to web).
  ##
  # nameOverride:

  ## Number of replicas.
  ##
  replicas: 1

  ## Configures the liveness probe used to determine
  ## if the Web component is up.
  ## Note.: if you're upgrading Concourse from one version
  ## to another, the probe will probably fail for some time
  ## before migrations are finished - in such situations,
  ## either consider bumping the values set here.
  livenessProbe:
    failureThreshold: 5
    httpGet:
      path: /api/v1/info
      port: atc
    initialDelaySeconds: 10
    periodSeconds: 15
    timeoutSeconds: 3

  ## Configures the readiness probes.
  readinessProbe:
    httpGet:
      path: /api/v1/info
      port: atc

  ## Configure resource requests and limits.
  ## ref: https://kubernetes.io/docs/user-guide/compute-resources/
  ##
  resources:
    requests:
      cpu: "100m"
      memory: "128Mi"

  ## Configure additional environment variables for the
  ## web containers.
  # env:
  #   - name: CONCOURSE_LOG_LEVEL
  #     value: "debug"
  #   - name: CONCOURSE_TSA_LOG_LEVEL
  #     value: "debug"

  ## For managing where secrets should be mounted for the web agents
  keySecretsPath: "/concourse-keys"
  authSecretsPath: "/concourse-auth"
  vaultSecretsPath: "/concourse-vault"
  postgresqlSecretsPath: "/concourse-postgresql"
  syslogSecretsPath: "/concourse-syslog"
  tlsSecretsPath: "/concourse-web-tls"

  ## Configure additional volumes for the
  ## web container(s)
  ##
  # additionalVolumes:
  #   - name: my-team-authorized-keys
  #     configMap:
  #       name: my-team-authorized-keys-config

  ## Configure additional volumeMounts for the
  ## web container(s)
  ##
  # additionalVolumeMounts:
  #   - name: my-team-authorized-keys
  #     mountPath: /my-team-authorized-keys

  ## Additional affinities to add to the web pods.
  ##
  # additionalAffinities:
  #   nodeAffinity:
  #     preferredDuringSchedulingIgnoredDuringExecution:
  #       - weight: 50
  #         preference:
  #           matchExpressions:
  #             - key: spot
  #               operator: NotIn
  #               values:
  #                 - "true"

  ## Annotations for the web nodes.
  ## Ref: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/
  annotations: {}
  # annotations:
  #   key1: "value1"
  #   key2: "value2"

  ## Node selector for web nodes.
  nodeSelector: {}

  ## Tolerations for the web nodes.
  ## Ref: https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
  tolerations: []
  # tolerations:
  #  - key: "toleration=key"
  #    operator: "Equal"
  #    value: "value"
  #    effect: "NoSchedule"

  ## Service configuration.
  ## ref: https://kubernetes.io/docs/user-guide/services/
  ##
  service:
    ## For minikube, set this to ClusterIP, elsewhere use LoadBalancer or NodePort
    ## ref: https://kubernetes.io/docs/user-guide/services/#publishing-services---service-types
    ##
    type: ClusterIP

    ## When using web.service.type: LoadBalancer, sets the user-specified load balancer IP
    # loadBalancerIP: 172.217.1.174

    # # Additional Labels to be added to the web service.
    # labels:

    ## Annotations to be added to the web service.
    ##
    # annotations:
    #   prometheus.io/probe: "true"
    #   prometheus.io/probe_path: "/"
    #
    #   ## When using web.service.type: LoadBalancer, enable HTTPS with an ACM cert
    #   service.beta.kubernetes.io/aws-load-balancer-ssl-cert: "arn:aws:acm:eu-west-1:123456789:certificate/abc123-abc123-abc123-abc123"
    #   service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http"
    #   service.beta.kubernetes.io/aws-load-balancer-backend-port: "atc"
    #   service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "443"
    #
    # ## When using web.service.type: LoadBalancer, whitelist the load balancer to particular IPs
    # loadBalancerSourceRanges:
    #   - 192.168.1.10/32

  # When using web.service.type: NodePort, sets the nodePort for atc
  #  atcNodePort: 30150
  #
  # When using web.service.type: NodePort, sets the nodePort for atc tls
  #  atcTlsNodePort: 30151
  #
  # When using web.service.type: NodePort, sets the nodePort for tsa
  #  tsaNodePort: 30152

  ## Ingress configuration.
  ## ref: https://kubernetes.io/docs/user-guide/ingress/
  ##
  ingress:
    ## Enable Ingress.
    ##
    enabled: false

    ## Annotations to be added to the web ingress.
    ##
    # annotations:
    #   kubernetes.io/ingress.class: nginx
    #   kubernetes.io/tls-acme: 'true'

    ## Hostnames.
    ## Must be provided if Ingress is enabled.
    ##
    # hosts:
    #   - concourse.domain.com

    ## TLS configuration.
    ## Secrets must be manually created in the namespace.
    ##
    # tls:
    #   - secretName: concourse-web-tls
    #     hosts:
    #       - concourse.domain.com
    #
    #

## Configuration values for Concourse Worker components.
##
worker:
  ## Override the components name (defaults to worker).
  ##
  # nameOverride:

  ## Number of replicas.
  ##
  replicas: 2

  ## Minimum number of workers available after an eviction
  ## ref: https://kubernetes.io/docs/admin/disruptions/
  ##
  minAvailable: 1

  ## Configure resource requests and limits.
  ## ref: https://kubernetes.io/docs/user-guide/compute-resources/
  ##
  resources:
    requests:
      cpu: "100m"
      memory: "512Mi"

  ## Configure additional environment variables for the
  ## worker container(s)
  # env:
  #   - name: http_proxy
  #     value: "http://proxy.your-domain.com:3128"
  #   - name: https_proxy
  #     value: "http://proxy.your-domain.com:3128"
  #   - name: no_proxy
  #     value: "your-domain.com"
  #   - name: CONCOURSE_GARDEN_DNS_SERVER
  #     value: "8.8.8.8"
  #   - name: CONCOURSE_GARDEN_DNS_PROXY_ENABLE
  #     value: "true"
  #   - name: CONCOURSE_GARDEN_ALLOW_HOST_ACCESS
  #     value: "true"


  ## For managing where secrets should be mounted for worker agents
  keySecretsPath: "/concourse-keys"

  ## Configure additional volumeMounts for the
  ## worker container(s)
  # additionalVolumeMounts:
  #   - name: concourse-baggageclaim
  #     mountPath: /baggageclaim

  ## Annotations to be added to the worker pods.
  ##
  # annotations:
  #   iam.amazonaws.com/role: arn:aws:iam::123456789012:role/concourse
  #

  ## Node selector for the worker nodes.
  ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#nodeselector
  nodeSelector: {}
  # nodeSelector: {type: concourse}

  ## Additional affinities to add to the worker pods.
  ## Useful if you prefer to run workers on non-spot instances, for example
  ##
  # additionalAffinities:
  #   nodeAffinity:
  #     preferredDuringSchedulingIgnoredDuringExecution:
  #       - weight: 50
  #         preference:
  #           matchExpressions:
  #             - key: spot
  #               operator: NotIn
  #               values:
  #                 - "true"

  ## Configure additional volumes for the
  ## worker container(s)
  # additionalVolumes:
  #   - name: concourse-baggageclaim
  #     hostPath:
  #       path: /dev/nvme0n1
  #       type: BlockDevice
  #
  # As a special exception, this allows taking over the `concourse-work-dir`
  # volume (from the default emptyDir) if `persistence.enabled` is false:
  #
  # additionalVolumes:
  #   - name: concourse-work-dir
  #     hostPath:
  #       path: /mnt/locally-mounted-fast-disk/concourse
  #       type: DirectoryOrCreate

  ## Whether the workers should be forced to run on separate nodes.
  ## This is accomplished by setting their AntiAffinity with requiredDuringSchedulingIgnoredDuringExecution as opposed to preferred
  ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#inter-pod-affinity-and-anti-affinity-beta-feature
  hardAntiAffinity: false

  ## Tolerations for the worker nodes.
  ## Ref: https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
  tolerations: []
  # tolerations:
  #  - key: "toleration=key"
  #    operator: "Equal"
  #    value: "value"
  #    effect: "NoSchedule"

  ## Time to allow the pod to terminate before being forcefully terminated. This should provide time for
  ## the worker to retire, i.e. drain its tasks. See https://concourse-ci.org/worker-internals.html for worker
  ## lifecycle semantics.
  terminationGracePeriodSeconds: 60

  ## If any of the strings are found in logs, the worker's livenessProbe will fail and trigger a pod restart.
  ## Specify one string per line, exact matching is used.
  ##
  fatalErrors: |-
    guardian.api.garden-server.create.failed
    baggageclaim.api.volume-server.create-volume-async.failed-to-create

  ## Strategy for StatefulSet updates (requires Kubernetes 1.6+)
  ## Ref: https://kubernetes.io/docs/concepts/workloads/controllers/statefulset
  ##
  updateStrategy: RollingUpdate

  ## Pod Management strategy (requires Kubernetes 1.7+)
  ## Ref: https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/#pod-management-policies
  ##
  ## "OrderedReady" is default. "Parallel" means worker pods will launch or terminate
  ## in parallel.
  podManagementPolicy: Parallel

  ## When persistance is disabled this value will be used to limit the emptyDir volume size
  ## Ref: https://kubernetes.io/docs/concepts/storage/volumes/#emptydir
  # emptyDirSize: 20Gi

## Persistent Volume Storage configuration.
## ref: https://kubernetes.io/docs/user-guide/persistent-volumes
##
persistence:
  ## Enable persistence using Persistent Volume Claims.
  ##
  enabled: true

  ## Worker Persistence configuration.
  ##
  worker:
    ## concourse data Persistent Volume Storage Class
    ## If defined, storageClassName: <storageClass>
    ## If set to "-", storageClassName: "", which disables dynamic provisioning
    ## If undefined (the default) or set to null, no storageClassName spec is
    ##   set, choosing the default provisioner.  (gp2 on AWS, standard on
    ##   GKE, AWS & OpenStack)
    ##
    # storageClass: "-"

    ## Persistent Volume Access Mode.
    ##
    accessMode: ReadWriteOnce

    ## Persistent Volume Storage Size.
    ##
    size: 20Gi

## Configuration values for the postgresql dependency.
## ref: https://github.com/kubernetes/charts/blob/master/stable/postgresql/README.md
##
postgresql:

  ## Use the PostgreSQL chart dependency.
  ## Set to false if bringing your own PostgreSQL, and set secret value postgresql-uri.
  ##
  enabled: true

  ### PostgreSQL User to create.
  ##
  postgresUser: concourse

  ## PostgreSQL Password for the new user.
  ## If not set, a random 10 characters password will be used.
  ##
  postgresPassword: concourse

  ## PostgreSQL Database to create.
  ##
  postgresDatabase: concourse

  ## Persistent Volume Storage configuration.
  ## ref: https://kubernetes.io/docs/user-guide/persistent-volumes
  ##
  persistence:
    ## Enable PostgreSQL persistence using Persistent Volume Claims.
    ##
    enabled: true
    ## concourse data Persistent Volume Storage Class
    ## If defined, storageClassName: <storageClass>
    ## If set to "-", storageClassName: "", which disables dynamic provisioning
    ## If undefined (the default) or set to null, no storageClassName spec is
    ##   set, choosing the default provisioner.  (gp2 on AWS, standard on
    ##   GKE, AWS & OpenStack)
    ##
    # storageClass: "-"
    ## Persistent Volume Access Mode.
    ##
    accessMode: ReadWriteOnce
    ## Persistent Volume Storage Size.
    ##
    size: 8Gi

## For RBAC support:
rbac:
  # true here enables creation of rbac resources
  create: true

  # rbac version
  apiVersion: v1beta1

  ## The name of the service account to use for web pods if rbac.create is false
  ##
  webServiceAccountName: default

  ## The name of the service account to use for worker pods if rbac.create is false
  ##
  workerServiceAccountName: default

## For managing secrets using Helm
##
secrets:

  ## List of username:password or username:bcrypted_password combinations for all your local concourse users.
  localUsers: "test:test"
  ## Create the secret resource from the following values. Set this to
  ## false to manage these secrets outside Helm.
  ##
  create: true

  ## The TLS certificate and private key for the web component to be able to terminate
  ## TLS connections.
  # webTlsCert:
  # webTlsKey:

  ## Concourse Host Keys.
  ## ref: https://concourse-ci.org/install.html#generating-keys
  ##
  hostKey: |-
    -----BEGIN RSA PRIVATE KEY-----
    MIIEogIBAAKCAQEA2AUPXxuiDC/qrBWjIdT5fvNcMlMEYpR3X4SLQIgLC1ULDsCO
    fleKZ+Wi4RzwbkUKiKmJm5GeyNVVCDdfvdD1Sd1+5faqmp2/OQBzLS7o8NY/btMw
    8h9lx4KVJaJJ1EM1EiyGY41Nx591KP14pBfr0/NdOIrDu2JvF6e7CHEbrzkN57kb
    BVQkaIMaS01Rw/5Oe68GFalli2ii8L8dNWVVzquBh5PwVWimvTgwv3TYG2TH8L1V
    V7n+/zRRpkjMl2+PUouGqD+Bp+4wF+hp4AW5v24CqjtLJEMv4IEJv2FRfrOauBIZ
    XjAS1SSg9VaTOS3iwxaYrv8uG1XfMFHICvkEPQIDAQABAoIBAG87W8jrX6vK2Jm3
    ooJ/OeFmymiXWsCwFi+2/kVCR/2T0tfLyxO/W+NX2WD1F9CP+HaaZeMXPp3HS7up
    V8FT4ZohVYBwXTS0WYyucKApcYThrVQRpzhldnEfClGQmVeVK7Sp/KEyV4Sc1SVA
    L2i/cI142N2Ohm7spquVkLcuFsVINzZ0fXCv25dTqbkEgjTJzNdBzyFXvc4z0Mt9
    gW14M7mz+YKYOfsCxIEm438fC9b16C96yIFBdN+/jaP8pmb2RoIE2D0F8bj5K1hR
    YyGFKMOU4e6cYq59iWfubKuu2WNJEBk/5aO7x7Xu2S0k8wIYlwxFuu4LfR2Kvizu
    +mFVf3kCgYEA9e0+40tJGpOPM8hAB3DwXjYc8lCuyYf3z30T3RqVNCUVSWnlaj/s
    3ENi6+Ng3u+Zs8cR2CFou+jAClTyWLuSnI9yACD0eyW9n4bzYMUbgdC6vneLjpzx
    wWR9Xv5RmZVly7xWuqcgEeEf8RNcYI3oXby0laF3EObvuAx/4ETIkFcCgYEA4N42
    w1UEWGopWBIIXYHkEPHQuF0SxR2CZyh9ExTeSxFphyibkcHRjDW+t91ZLnSm5k1N
    TOdYuc0ApBV3U+TexeFvDI94L/Oze6Ht5MatRQz8kRwMFGJL3TrpbgTmWdfG05Ad
    oiScJzwY16oJXnKusxik7V+gCCNNE0/2UuMnY4sCgYAEf82pvOPef5qcGOrK+A79
    ukG3UTCRcVJgUmp9nhHivVbxW+WdlwPPV9BEfol0KrAGMPsrmBjhbzWsOregVfYt
    tRYh2HiAlEUu2Po06AZDzrzL5UYBWu+1WRBOH5sAk1IkcxKnIY2dph++elszTQVW
    SbCIGEckYQU7ucbRJJECywKBgBb4vHFx8vKxTa3wkagzx7+vZFohL/SxEgxFx5k2
    bYsPqU8kZ9gZC7YeG3CfDShAxHgMd5QeoiLA/YrFop4QaG2gnP6UfXuwkqpTnYDc
    hwDh1b9hNR6z9/oOtaAGoh2VfHtKYqyYvtcHPaZyeWiLoKstHlQdi7SpHouVhJ1t
    FS4HAoGAGy+56+zvdROjJy9A2Mn/4BvWrsu4RSQILBJ6Hb4TpF46p2fn0rwqyhOj
    Occs+xkdEsI9w5phXzIEeOq2LqvWHDPxtdLpxOrrmx4AftAWdM8S1+OqTpzHihK1
    y1ZOrWfvON+XjWFFAEej/CpQZkNUkTzjTtSC0dnfAveZlasQHdI=
    -----END RSA PRIVATE KEY-----

  hostKeyPub: |-
    ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDYBQ9fG6IML+qsFaMh1Pl+81wyUwRilHdfhItAiAsLVQsOwI5+V4pn5aLhHPBuRQqIqYmbkZ7I1VUIN1+90PVJ3X7l9qqanb85AHMtLujw1j9u0zDyH2XHgpUloknUQzUSLIZjjU3Hn3Uo/XikF+vT8104isO7Ym8Xp7sIcRuvOQ3nuRsFVCRogxpLTVHD/k57rwYVqWWLaKLwvx01ZVXOq4GHk/BVaKa9ODC/dNgbZMfwvVVXuf7/NFGmSMyXb49Si4aoP4Gn7jAX6GngBbm/bgKqO0skQy/ggQm/YVF+s5q4EhleMBLVJKD1VpM5LeLDFpiu/y4bVd8wUcgK+QQ9 Concourse

  ## Concourse Session Signing Keys.
  ## ref: https://concourse-ci.org/install.html#generating-keys
  ##
  sessionSigningKey: |-
    -----BEGIN RSA PRIVATE KEY-----
    MIIEowIBAAKCAQEAwLql/rUIaI+PX7Tl3FWcTee4sQf8/daakALXx955tPwkhqlY
    e4T2V84p/ylFvNWpM4vfcMYKfMY0JLKgAgBvJhCytSkDBhTBoWmN6yE0AB11P9En
    lIZRBWNYqaC2cSge2ZD8qOSnwfFhnQAW8+7pE+ElJAVh7dtdF3A478H50lIigq8I
    zMWp2EGJpFC7/Uu36oIL/03MNGCmrH1jvtTuJiAMQUZYyL1ReBkvvHOzw9i4HXPy
    SMVtcllm4NBs2aVPtwhr2kwSkLt8t1bPdRn6OIyEAw5WktzAKaiZnkTvj6g3xzdp
    zKcrdlBr9aznlNvoSinBUfvtwyFmvFN1HHbA9wIDAQABAoIBAE7G/DrUfI9gvtX7
    90jMpYsigFe8UCjho2PiBZlo0o6r0bJJXiV+/8J8PqZRlHPPUc4EClzqVjcSPRYS
    /VxUGRqSELoD/Xxq14rGvn+xnrO9VsOzFl6bWFq/dOpBCtHN+G4t2VifvgKES8YE
    11z19sdta+UBXjn/RFnkQSGfRCI3QqTaYvjxevt0uWlyPmqkFPQQw8bvHIXzoB+B
    rzeiMa++nMvbX5pAH9XA0BvhyuH3fHidTUwiVBpkMcpLWtjP0A0JTsecDdbinDDq
    un2EIo8zMWRwKQN/JnUxsi8AUEigBTCUqeDgREXtW62uvFkSpcVMXwmVityLYIVy
    qnVLUCECgYEA6IwXkP1qnSfcNeoVI/ypDuz1/kdqcjSPhLYe+jdiLLoFkMW9AlDm
    lzwNaWlTFD9ygo+NjJCo63/A8HCm55sajws5hZ6r20vdZcKFMk9h0qF5oVA7lkQ2
    gvG2WaznuU7KkqhfP+pXhiLgZKoJkst/+g7r6uHpredwDY6hxeBK4vsCgYEA1CqH
    8ywC5qUo/36kQg/TU2adN/YEHdJAAbU23EVrGQSVmnXW08H2NLFk0tsxrwoNnbgp
    PIk2J7BimbJvbND17ibr4GAklDTsR8aJkDl+0JgNCAK9N07qVt1s7FXzhg95jUL9
    EQW55z60GAJpecqNwA4Jsa8P852N0355Obp92TUCgYBkOBvf7JcJ66fHxH4f6D+j
    oxPQ5k5Fsck4VJS9GSlCRVkor09ptBvsiYDuMOoRC9b51YwXTDDAbWplNOd5YSrt
    AtVjdKJz/BoKRO7KY9Owxs54au+DLxqfDDSeKRokjoRW+CE0lnXp5RX3zCAcF3+r
    8MpTi9D9lYSBEzs84BDmCQKBgQCMcH6/K3HcJJVn0fd+tyUGftUw9sswxjySJNbk
    pZrH263/qWMDls+Xf5kire9MU1ZCAWZiaN0NFoed/2wcVpGEDAV0548u/30r4bKr
    YjOcdhmiJNYFJ1qdF0MDib2CDvpB1IbZXrX46RujDO2urbJ435HxKNVhR/had8xc
    tyKYxQKBgCVDhN0MhnlUQJVZfX42APmF4gQg0r3sfL/NGXjEjMIKKFe5a88eZVHr
    L8x1+dp0q7czC8a/l1DUuiwDKl8OEpxLsGCq/J/wAfrSMPifu6EUlbUwlJOPdgha
    +p/KFAelHXJ2w/8yackAcarh35VP7ixhuvxswHNdgvfsBTFcjn30
    -----END RSA PRIVATE KEY-----

  ## Concourse Worker Keys.
  ## ref: https://concourse-ci.org/install.html#generating-keys
  ##
  workerKey: |-
    -----BEGIN RSA PRIVATE KEY-----
    MIIEpAIBAAKCAQEAuPehUmBXAQCoA7TLAQCYhf+vzcZVyj+VGXnMhLHnWLk7dRjo
    CU8GgNamdS5h7G3ywxOvKA3YjOLr8XyOMLS4c+e8N7tIzlMWdiXhe0lcBH9Z1ai5
    +Bof3/BlDUBksiKdc1A+QcfX6tDwMkOO5re1H4vOK3H/Cype58wCB03HYNgb05ED
    fW1Bj2qvz29VtmyjwEMuDs100iMqwCfPUx9oxXmmX8sUBRmw/Y1Rx/8pdKIjKw3m
    kWIHHBOSCPimO1qC47Aa8v/UH9hERCykyuFHiBiKlnIvZWm9bYvhsRTz4gt5KzRY
    6OI0oVeHlLOHDSK48Da8VWij15lOqO2Nx6WssQIDAQABAoIBADET22UNFOi6MNpS
    5S5N5ypezlnOD0NLnZcV3zMyNQ0wkNsgEakuo64Zxi7/cJIYFjq2hVoeWl//cdUw
    VFYODYcLbMBo3AeKukH9CRf6PgUfeUmcrENtQxnbIiTi+hTd5GMNXod7rAmtCJ59
    mHQVOGS3ZqvWYnKm+mmMktk3RPinynX/A4y3WHPacuAS58HM09Ck43WcHMxbGpsL
    /gZpICyFYZ2DviM+AHyWGcmw7LJrpC0QHo6+BAFMs4xlUecNgVIFUpfOoAcfsdtG
    K9j4AbuZ47iFisbay+1pyg/7O5eRTdGVQRtc7PBMOjea5jGsfmlDmdn1ZS50ykun
    ANfoQ5UCgYEA9Ak73PRy9nLlRkt4OBCF/4fwThUCMedsnWaVjQBMJYim4FB2ivF5
    cKdWt3y/RZI85KKYu0EXhLEoSIEAfz057R8t3QdVK4tZx6B47UFjBjCYeVMtwHDQ
    prxQiOPHIHCplBNFuGzA5VXL9gQLRD+ek0uOy2GJJ0Wu1xyeouI+SW8CgYEAwgkO
    TOtOogqmcAALjWgeeQiZetflSKbJlpQNhmCPAMm0SFI8eF4SpRXLzd41VC2mLIwT
    L3tjc7/8ocXoElFM4L0fo9Lx/SHFH4JEn5FT0PXPmvsF2JRhsXJFLJSihxF/91Xs
    2aBcQILPFzLcrI6OFUakNwGTU/CIxpkzRvQrG98CgYEAzNVnUuo4CNadzagRK3Xr
    E3Yl5VRK+FpY17FAfA6w25xc/dFr/un61e0Po4no/ltmEz7LVfmn5O/ScTEemq5o
    jbjrBShfe+JGpIH0nqiQlqR5hvSjZXEMIbfVHWGbRYZrQGgA0HEwZA7k2QXB8zI3
    R0lXfSzMM5OQ0uwp12xxfa8CgYBHILq1R6zTicPpWprhg0FobNaWSX4rW7iaEjvC
    /rJtP4Nu33Z7SUDcc1j6ZnJ2ISXBPrfpt/mE/OPHCZ1A2bysxadLjpBWkoKIQmCV
    fdiTyQgJb+t8sSf+vDzPUs0hZjDaogzo2ff3TfxMLMDoIHnFItgfsdwn8QyygIZj
    hC4pUQKBgQDqsxnkI6yXFE5gshnW7H8zqKNlzKd/dZEL6e+lRz4R3UY/KcEkRAfq
    Yi3cwo9fE3U3kSmpl5MQwUjWm/BZ7JyueoY/4ndwaFPgc34IKsgJ0wau9pZiQAB1
    DxpOSF+BR71Jx3sxvIdCODNTtm645j5yrZVnJAuMPofo5XFmunDoJA==
    -----END RSA PRIVATE KEY-----

  workerKeyPub: |-
    ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC496FSYFcBAKgDtMsBAJiF/6/NxlXKP5UZecyEsedYuTt1GOgJTwaA1qZ1LmHsbfLDE68oDdiM4uvxfI4wtLhz57w3u0jOUxZ2JeF7SVwEf1nVqLn4Gh/f8GUNQGSyIp1zUD5Bx9fq0PAyQ47mt7Ufi84rcf8LKl7nzAIHTcdg2BvTkQN9bUGPaq/Pb1W2bKPAQy4OzXTSIyrAJ89TH2jFeaZfyxQFGbD9jVHH/yl0oiMrDeaRYgccE5II+KY7WoLjsBry/9Qf2ERELKTK4UeIGIqWci9lab1ti+GxFPPiC3krNFjo4jShV4eUs4cNIrjwNrxVaKPXmU6o7Y3Hpayx Concourse

  ## Secrets for DB access
  # postgresUser:
  # postgresPassword:
  # postgresCaCert:
  # postgresClientCert:
  # postgresClientKey:

  ## Secrets for DB encryption
  ##
  # encryptionKey:
  # oldEncryptionKey:

  ## Secrets for SSM AWS access
  # awsSsmAccessKey:
  # awsSsmSecretKey:
  # awsSsmSessionToken:

  ## Secrets for Secrets Manager AWS access
  # awsSecretsmanagerAccessKey:
  # awsSecretsmanagerSecretKey:
  # awsSecretsmanagerSessionToken:

  ## Secrets for CF OAuth
  # cfClientId:
  # cfClientSecret:
  # cfCaCert: |-

  ## Secrets for GitHub OAuth.
  ##
  # githubClientId:
  # githubClientSecret:
  # githubCaCert: |-

  ## Secrets for GitLab OAuth.
  ##
  # gitlabClientId:
  # gitlabClientSecret:

  ## Secrets for LDAP Auth.
  ##
  # ldapCaCert: |-

  ## Secrets for generic OAuth.
  ##
  # oauthClientId:
  # oauthClientSecret:
  # oauthCaCert: |-

  ## Secrets for oidc OAuth.
  ##
  # oidcClientId:
  # oidcClientSecret:
  # oidcCaCert: |-

  ## Secrets for using Hashcorp Vault as a credential manager.
  ##
  ## if the Vault server is using a self-signed certificate, provide the CA public key.
  ## the value will be written to /concourse-vault/ca.cert
  ##
  # vaultCaCert: |-

  ## initial periodic token issued for concourse
  ## ref: https://www.vaultproject.io/docs/concepts/tokens.html#periodic-tokens
  ##
  # vaultClientToken:

  ## vault authentication parameters
  ## Paramter to pass when logging in via the backend
  ## Required for "approle" authenication method
  ## e.g. "role_id=x,secret_id=x"
  ## ref: https://concourse-ci.org/creds.html#vault-auth-param=NAME=VALUE
  ##
  # vaultAuthParam:

  ## provide the client certificate for authenticating with the [TLS](https://www.vaultproject.io/docs/auth/cert.html) backend
  ## the value will be written to /concourse-vault/client.cert
  ## make sure to also set credentialManager.vault.authBackend to `cert`
  ##
  # vaultClientCert: |-

  ## provide the client key for authenticating with the [TLS](https://www.vaultproject.io/docs/auth/cert.html) backend
  ## the value will be written to /concourse-vault/client.key
  ## make sure to also set credentialManager.vault.authBackend to `cert`
  ##
  # vaultClientKey: |-

  ## If influxdb metrics are enabled and authentication is required,
  ## provide a password here to authenticate with the influxdb server configured.
  ##
  # influxdbPassword:

  ## SSL certificate used to verify the Syslog server for draining build logs.
  # syslogCaCert: |-
" 119 } 120 ] 121 }, 122 "contentSHA": "99183db72b179080361aae192a23e926cf0fca14d098c2ce4227d01c843fcec6" 123 } 124 }