
This patchset supports Dex Helm charts to be used for deploying Dex on a CAPI Target cluster. Change-Id: Ic318788f0a2e2a3e5ca33a39e1adfbddcda8f5c4
193 lines
11 KiB
YAML
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;
|
|
}
|
|
|
|
}
|
|
}
|