charts/charts/dex-aio/values.yaml
Sidney Shiba ed49ac5aac Dex Charts - Airship 2 Integration
This patchset supports Dex Helm charts to be used for deploying Dex on a
CAPI Target cluster.

Change-Id: Ic318788f0a2e2a3e5ca33a39e1adfbddcda8f5c4
2021-02-25 18:43:10 -06:00

193 lines
11 KiB
YAML

# Default values for dex-aio.
# This is a YAML-formatted file.
# Declare variables to be passed into your templates.
images:
applications:
dex:
tag: v2.20.0
name: dexidp/dex
repo: quay.io
nginx:
tag: 1.17.10-alpine
name: nginx
repo: docker.io
authenticator:
tag: 1.2.0
name: mintel/dex-k8s-authenticator
repo: docker.io
tls_init:
tag: latest
name: metal3-io/ironic
repo: quay.io
pull:
policy: IfNotPresent
node_labels:
dex:
key: node-role.kubernetes.io/master
value: ""
params:
site:
name: PDL1
service:
type: NodePort
endpoints:
hostname: vm-capi-docker.lan
port:
https: 5556
http: 5554
k8s: 6443
nodePort:
https: 30556
http: 30554
tls:
cert_manager: false
issuer:
name: workload-cluster-ca-issuer
kind: Issuer
oidc:
client_id: my-cluster
client_secret: pUBnBOY80SnXgjibTYM9ZWNzY2xreNGQok
ldap:
bind_password: super-secure
over_rides:
deployment:
dex:
spec:
replicas: 1
# advanced config below:
config:
dex.yaml:
issuer: https://{{ .Values.params.endpoints.hostname }}:{{ .Values.params.endpoints.port.https }}/dex
storage:
type: kubernetes
config:
inCluster: true
web:
https: 127.0.0.1:{{ .Values.params.endpoints.port.https }}
tlsCert: "/var/run/secrets/airshipit.org/tls/crt/tls.crt"
tlsKey: "/var/run/secrets/airshipit.org/tls/key/tls.key"
frontend:
theme: coreos
issuer: Airship
issuerUrl: https://www.airshipit.org/
logoUrl: ""
expiry:
signingKeys: 6h
idTokens: 24h
logger:
level: debug
format: json
oauth2:
responseTypes:
- code
- token
- id_token
skipApprovalScreen: true
staticClients:
- id: "{{ .Values.params.oidc.client_id }}"
name: "{{ .Values.params.site.name }}"
secret: "{{ .Values.params.oidc.client_secret }}"
redirectURIs:
- "https://{{ .Values.params.endpoints.hostname }}:{{ .Values.params.endpoints.port.https }}/ui/callback/{{ .Values.params.oidc.client_id }}"
enablePasswordDB: true
staticPasswords:
- email: tenantadmin@atttest.com
# this is "password" bcrypt'd
hash: "$2a$10$2b2cU8CPhOTaGrs1HRQuAueS7JTT5ZHsHSzYiFPm1leZck7Mc8T4W"
username: tenantadmin
userID: "08a8684b-db88-4b73-90a9-3cd1661f5466"
authenticator.yaml:
listen: https://127.0.0.1:5555
web_path_prefix: "/ui"
tls_cert: "/var/run/secrets/airshipit.org/tls/crt/tls.crt"
tls_key: "/var/run/secrets/airshipit.org/tls/key/tls.key"
debug: true
clusters:
- client_id: "{{ .Values.params.oidc.client_id }}"
client_secret: "{{ .Values.params.oidc.client_secret }}"
description: "Airship Cluster Kubernetes OpenIDC for {{ .Values.params.site.name }}"
issuer: "https://{{ .Values.params.endpoints.hostname }}:{{.Values.params.endpoints.port.https }}/dex"
k8s_ca_uri: "http://{{ .Values.params.endpoints.hostname }}:{{ .Values.params.endpoints.port.http }}/ca.crt"
k8s_master_uri: "https://{{ .Values.params.endpoints.hostname }}:{{.Values.params.endpoints.port.k8s}}/"
name: "{{ .Values.params.site.name }}"
redirect_uri: "https://{{ .Values.params.endpoints.hostname }}:{{ .Values.params.endpoints.port.https }}/ui/callback/{{ .Values.params.oidc.client_id }}"
short_description: "{{ .Values.params.site.name }} OpenIDC"
nsswitch.conf: |-
hosts: files dns
nginx.conf: |
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name {{ .Values.params.endpoints.hostname }};
absolute_redirect off;
location / { # the default location redirects to https
return 301 https://$server_name:{{ .Values.params.endpoints.port.https }}$request_uri;
}
location = /ca.crt {
alias /usr/share/nginx/html/ca.crt;
}
}
server {
listen 443 ssl;
server_name {{ .Values.params.endpoints.hostname }};
absolute_redirect off; #RFC 7231
ssl_certificate /var/run/secrets/airshipit.org/tls/crt/tls.crt;
ssl_certificate_key /var/run/secrets/airshipit.org/tls/key/tls.key;
location = / {
return 301 /ui/;
}
location = /ca.crt {
alias /usr/share/nginx/html/ca.crt;
}
location /dex/ {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass https://127.0.0.1:{{ .Values.params.endpoints.port.https }}/dex/;
proxy_ssl_trusted_certificate /usr/share/nginx/html/ca.crt;
}
location /ui/ {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass https://127.0.0.1:5555/ui/;
proxy_ssl_trusted_certificate /usr/share/nginx/html/ca.crt;
}
}
}