feat: hydra-oidc deployment
This commit is contained in:
parent
4190225f5a
commit
fb773a98d1
|
@ -11,6 +11,7 @@ cadoles_pod_hydra_dispatcher_v1_package_version: '*'
|
||||||
cadoles_pod_shibboleth_sp_v3_package_version: '*'
|
cadoles_pod_shibboleth_sp_v3_package_version: '*'
|
||||||
cadoles_pod_hydra_remote_user_v1_package_version: '*'
|
cadoles_pod_hydra_remote_user_v1_package_version: '*'
|
||||||
cadoles_pod_hydra_passwordless_v1_package_version: '*'
|
cadoles_pod_hydra_passwordless_v1_package_version: '*'
|
||||||
|
cadoles_pod_hydra_oidc_v1_package_version: '*'
|
||||||
|
|
||||||
# Hydra database configuration
|
# Hydra database configuration
|
||||||
hydra_use_external_database: no
|
hydra_use_external_database: no
|
||||||
|
@ -28,7 +29,8 @@ haproxy_hydra_base_path: /auth
|
||||||
haproxy_hydra_dispatcher_base_path: /auth/dispatcher
|
haproxy_hydra_dispatcher_base_path: /auth/dispatcher
|
||||||
haproxy_hydra_passwordless_base_path: /auth/passwordless
|
haproxy_hydra_passwordless_base_path: /auth/passwordless
|
||||||
haproxy_hydra_saml_base_path: /auth/saml
|
haproxy_hydra_saml_base_path: /auth/saml
|
||||||
haproxy_oidc_test_base_path: /auth/oidc-test
|
haproxy_hydra_oidc_base_path: /auth/oidc
|
||||||
|
haproxy_oidc_test_base_path: /auth/test
|
||||||
|
|
||||||
haproxy_forwarded_proto: https
|
haproxy_forwarded_proto: https
|
||||||
haproxy_forwarded_host: "%[req.hdr(Host)]"
|
haproxy_forwarded_host: "%[req.hdr(Host)]"
|
||||||
|
@ -57,6 +59,14 @@ hydra_clients:
|
||||||
|
|
||||||
hydra_dispatcher_cookie_path: "{{ haproxy_hydra_dispatcher_base_path }}"
|
hydra_dispatcher_cookie_path: "{{ haproxy_hydra_dispatcher_base_path }}"
|
||||||
hydra_dispatcher_debug: no
|
hydra_dispatcher_debug: no
|
||||||
|
hydra_dispatcher_admin_authorized_hosts:
|
||||||
|
- '10.0.0.0/8'
|
||||||
|
- '172.16.0.0/12'
|
||||||
|
- '192.168.0.0/16'
|
||||||
|
hydra_dispatcher_default_locale: fr
|
||||||
|
hydra_dispatcher_available_locales:
|
||||||
|
- fr
|
||||||
|
- en
|
||||||
|
|
||||||
# Hydra Passwordless configuration
|
# Hydra Passwordless configuration
|
||||||
|
|
||||||
|
@ -134,4 +144,37 @@ saml_attribute_policies: []
|
||||||
enable_oidc_test_app: yes
|
enable_oidc_test_app: yes
|
||||||
oidc_test_app_client_id: oidc-test
|
oidc_test_app_client_id: oidc-test
|
||||||
oidc_test_app_client_secret: '$oidc-test&123456$'
|
oidc_test_app_client_secret: '$oidc-test&123456$'
|
||||||
oidc_test_app_public_base_url: "{{ haproxy_public_base_url }}{{ haproxy_oidc_test_base_path }}"
|
oidc_test_app_public_base_url: "{{ haproxy_public_base_url }}{{ haproxy_oidc_test_base_path }}"
|
||||||
|
|
||||||
|
# Hydra OIDC configuration
|
||||||
|
|
||||||
|
enable_hydra_oidc: no
|
||||||
|
hydra_oidc_debug: no
|
||||||
|
hydra_oidc_cookie_path: "{{ haproxy_hydra_oidc_base_path }}"
|
||||||
|
hydra_oidc_app_title: OpenID Connect
|
||||||
|
hydra_oidc_app_description: Authentification via OpenID Connect
|
||||||
|
hydra_oidc_app_icon_url: https://openid.net/wordpress-content/uploads/2014/09/openid-r-logo-900x360.png
|
||||||
|
hydra_oidc_authorize_endpoint:
|
||||||
|
hydra_oidc_token_endpoint:
|
||||||
|
hydra_oidc_userinfo_endpoint:
|
||||||
|
hydra_oidc_logout_url_pattern:
|
||||||
|
hydra_oidc_post_logout_redirect_url:
|
||||||
|
hydra_oidc_scope: openid email
|
||||||
|
hydra_oidc_client_id:
|
||||||
|
hydra_oidc_client_secret:
|
||||||
|
|
||||||
|
hydra_oidc_attributes_rewrite_rules:
|
||||||
|
email:
|
||||||
|
- consent.session.id_token.email
|
||||||
|
family_name:
|
||||||
|
- consent.session.id_token.family_name
|
||||||
|
given_name:
|
||||||
|
- consent.session.id_token.given_name
|
||||||
|
birthdate:
|
||||||
|
- consent.session.id_token.birthdate
|
||||||
|
gender:
|
||||||
|
- consent.session.id_token.gender
|
||||||
|
birthplace:
|
||||||
|
- consent.session.id_token.birthplace
|
||||||
|
birthcountry:
|
||||||
|
- consent.session.id_token.birthcountry
|
|
@ -35,6 +35,12 @@
|
||||||
state: restarted
|
state: restarted
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
|
- name: Restart cadoles-pod-hydra-oidc-v1
|
||||||
|
service:
|
||||||
|
name: cadoles-pod-hydra-oidc-v1
|
||||||
|
state: restarted
|
||||||
|
become: true
|
||||||
|
|
||||||
- name: Reload hydra clients
|
- name: Reload hydra clients
|
||||||
ansible.builtin.include_tasks:
|
ansible.builtin.include_tasks:
|
||||||
file: hydra-reload-clients.yml
|
file: hydra-reload-clients.yml
|
|
@ -0,0 +1,20 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
- name: Install cadoles-pod-hydra-oidc-v1 package
|
||||||
|
ansible.builtin.apt:
|
||||||
|
name:
|
||||||
|
- "cadoles-pod-hydra-oidc-v1={{ cadoles_pod_hydra_oidc_v1_package_version }}"
|
||||||
|
update_cache: yes
|
||||||
|
state: present
|
||||||
|
become: true
|
||||||
|
|
||||||
|
- name: Configure cadoles-pod-hydra-oidc-v1
|
||||||
|
template:
|
||||||
|
src: "{{ item.src }}"
|
||||||
|
dest: "{{ item.dest }}"
|
||||||
|
with_items:
|
||||||
|
- src: cadoles-pod-hydra-oidc-v1.conf.j2
|
||||||
|
dest: /etc/cadoles-pod-hydra-oidc-v1.conf
|
||||||
|
notify:
|
||||||
|
- Restart cadoles-pod-hydra-oidc-v1
|
||||||
|
become: true
|
|
@ -95,6 +95,10 @@
|
||||||
ansible.builtin.include_tasks: hydra-saml.yml
|
ansible.builtin.include_tasks: hydra-saml.yml
|
||||||
when: enable_hydra_saml
|
when: enable_hydra_saml
|
||||||
|
|
||||||
|
- name: Configure OIDC authentification if enabled
|
||||||
|
ansible.builtin.include_tasks: hydra-oidc.yml
|
||||||
|
when: enable_hydra_oidc
|
||||||
|
|
||||||
- name: Start OIDC Test app if enabled
|
- name: Start OIDC Test app if enabled
|
||||||
ansible.builtin.include_tasks: start-oidc-test.yml
|
ansible.builtin.include_tasks: start-oidc-test.yml
|
||||||
when: enable_oidc_test_app
|
when: enable_oidc_test_app
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
- name: Start oidc-test app
|
- name: Start oidc-test app
|
||||||
containers.podman.podman_container:
|
containers.podman.podman_container:
|
||||||
name: oidc-test
|
name: oidc-test
|
||||||
image: docker.io/bornholm/oidc-test:v0.0.0-4-gd786d3a
|
image: docker.io/bornholm/oidc-test:v0.0.0-6-g96f1f8f
|
||||||
state: started
|
state: started
|
||||||
network: host
|
network: host
|
||||||
restart_policy: on-failure
|
restart_policy: on-failure
|
||||||
|
|
|
@ -12,6 +12,9 @@ PODMAN_ARGS="\
|
||||||
-e HYDRA_REWRITE_ISSUER=no \
|
-e HYDRA_REWRITE_ISSUER=no \
|
||||||
-e 'HYDRA_ORIGINAL_ISSUER={{ haproxy_public_base_url }}' \
|
-e 'HYDRA_ORIGINAL_ISSUER={{ haproxy_public_base_url }}' \
|
||||||
-e 'HYDRA_NEW_ISSUER={{ haproxy_public_base_url }}' \
|
-e 'HYDRA_NEW_ISSUER={{ haproxy_public_base_url }}' \
|
||||||
-e 'ASSETS_BASE_URL={{ haproxy_public_base_url }}{{ haproxy_hydra_dispatcher_base_path }}' \
|
-e 'BASE_URL={{ haproxy_public_base_url }}{{ haproxy_hydra_dispatcher_base_path }}' \
|
||||||
-e 'COOKIE_PATH={{ hydra_dispatcher_cookie_path }}' \
|
-e 'COOKIE_PATH={{ hydra_dispatcher_cookie_path }}' \
|
||||||
|
-e 'DEFAULT_LOCALE={{ hydra_dispatcher_default_locale }}' \
|
||||||
|
-e 'APP_LOCALES={{ hydra_dispatcher_available_locales | join(',') }}' \
|
||||||
|
-e 'HYDRA_ADMIN_AUTHORIZED_HOSTS={{ hydra_dispatcher_admin_authorized_hosts | join(',') }}' \
|
||||||
"
|
"
|
|
@ -0,0 +1,20 @@
|
||||||
|
PODMAN_ARGS="\
|
||||||
|
--name 'cadoles-pod-hydra-oidc-v1' \
|
||||||
|
--replace \
|
||||||
|
--network=slirp4netns:allow_host_loopback=true \
|
||||||
|
--tz=local \
|
||||||
|
-p 127.0.0.1:3004:80 \
|
||||||
|
-e APP_ENV=prod \
|
||||||
|
-e 'APP_DEBUG={{ hydra_oidc_debug }}' \
|
||||||
|
-e 'HYDRA_ADMIN_BASE_URL=http://10.0.2.2:4445' \
|
||||||
|
-e 'COOKIE_PATH={{ hydra_oidc_cookie_path }}' \
|
||||||
|
-e 'URL_FRANCE_CONNECT_AUTHORIZE={{ hydra_oidc_authorize_endpoint }}' \
|
||||||
|
-e 'URL_FRANCE_CONNECT_TOKEN={{ hydra_oidc_token_endpoint }}' \
|
||||||
|
-e 'URL_FRANCE_CONNECT_USERINFO={{ hydra_oidc_userinfo_endpoint }}' \
|
||||||
|
-e 'LOGOUT_REDIRECT_URL_PATTERN={{ hydra_oidc_logout_url_pattern }}' \
|
||||||
|
-e 'POST_LOGOUT_REDIRECT_URL={{ hydra_oidc_post_logout_redirect_url }}' \
|
||||||
|
-e 'BASE_URL={{ haproxy_public_base_url }}{{ haproxy_hydra_oidc_base_path }}' \
|
||||||
|
-e 'SCOPE_FRANCE_CONNECT={{ hydra_oidc_scope }}' \
|
||||||
|
-e 'CLIENT_ID_FC={{ hydra_oidc_client_id }}' \
|
||||||
|
-e 'CLIENT_SECRET_FC={{ hydra_oidc_client_secret }}' \
|
||||||
|
"
|
|
@ -46,6 +46,9 @@ frontend http-in
|
||||||
{% if enable_hydra_saml %}
|
{% if enable_hydra_saml %}
|
||||||
acl login_saml path_beg -i {{ haproxy_hydra_saml_base_path }}
|
acl login_saml path_beg -i {{ haproxy_hydra_saml_base_path }}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
{% if enable_hydra_oidc %}
|
||||||
|
acl login_oidc path_beg -i {{ haproxy_hydra_oidc_base_path }}
|
||||||
|
{% endif %}
|
||||||
{% if enable_oidc_test_app %}
|
{% if enable_oidc_test_app %}
|
||||||
acl oidc_test path_beg -i {{ haproxy_oidc_test_base_path }}
|
acl oidc_test path_beg -i {{ haproxy_oidc_test_base_path }}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -57,6 +60,9 @@ frontend http-in
|
||||||
{% if enable_hydra_saml %}
|
{% if enable_hydra_saml %}
|
||||||
use_backend hydra_saml if login_saml
|
use_backend hydra_saml if login_saml
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
{% if enable_hydra_oidc %}
|
||||||
|
use_backend hydra_oidc if login_oidc
|
||||||
|
{% endif %}
|
||||||
{% if enable_oidc_test_app %}
|
{% if enable_oidc_test_app %}
|
||||||
use_backend oidc_test if oidc_test
|
use_backend oidc_test if oidc_test
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -90,6 +96,15 @@ backend hydra_passwordless
|
||||||
server hydra-login-passwordless 127.0.0.1:3001 check
|
server hydra-login-passwordless 127.0.0.1:3001 check
|
||||||
{%- endif %}
|
{%- endif %}
|
||||||
|
|
||||||
|
{% if enable_hydra_oidc %}
|
||||||
|
# Backend Hydra OIDC
|
||||||
|
backend hydra_oidc
|
||||||
|
balance roundrobin
|
||||||
|
# Suppression du préfixe /auth/oidc dans l'URL
|
||||||
|
http-request set-path %[path,regsub(^{{ haproxy_hydra_oidc_base_path }},)]
|
||||||
|
server hydra-login-oidc 127.0.0.1:3004 check
|
||||||
|
{%- endif %}
|
||||||
|
|
||||||
{% if enable_hydra_saml %}
|
{% if enable_hydra_saml %}
|
||||||
# Backend Hydra SAML
|
# Backend Hydra SAML
|
||||||
backend hydra_saml
|
backend hydra_saml
|
||||||
|
@ -100,7 +115,7 @@ backend hydra_saml
|
||||||
{% if enable_oidc_test_app %}
|
{% if enable_oidc_test_app %}
|
||||||
backend oidc_test
|
backend oidc_test
|
||||||
balance roundrobin
|
balance roundrobin
|
||||||
# Suppression du préfixe /auth/oidc-test dans l'URL
|
# Suppression du préfixe /auth/test dans l'URL
|
||||||
http-request set-path %[path,regsub(^{{ haproxy_oidc_test_base_path }},)]
|
http-request set-path %[path,regsub(^{{ haproxy_oidc_test_base_path }},/)]
|
||||||
server oidc-test 127.0.0.1:8080 check
|
server oidc-test 127.0.0.1:8080 check
|
||||||
{% endif %}
|
{% endif %}
|
|
@ -2,8 +2,10 @@ hydra:
|
||||||
apps:
|
apps:
|
||||||
{% if enable_hydra_passwordless %}
|
{% if enable_hydra_passwordless %}
|
||||||
- id: passwordless
|
- id: passwordless
|
||||||
title: "{{ hydra_passwordless_app_title }}"
|
title:
|
||||||
description: "{{ hydra_passwordless_app_description }}"
|
fr: "{{ hydra_passwordless_app_title }}"
|
||||||
|
description:
|
||||||
|
fr: "{{ hydra_passwordless_app_description }}"
|
||||||
login_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_passwordless_base_path }}/login"
|
login_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_passwordless_base_path }}/login"
|
||||||
consent_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_passwordless_base_path }}/consent"
|
consent_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_passwordless_base_path }}/consent"
|
||||||
logout_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_passwordless_base_path }}/logout"
|
logout_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_passwordless_base_path }}/logout"
|
||||||
|
@ -12,11 +14,25 @@ hydra:
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if enable_hydra_saml %}
|
{% if enable_hydra_saml %}
|
||||||
- id: saml
|
- id: saml
|
||||||
title: "{{ hydra_saml_app_title }}"
|
title:
|
||||||
description: "{{ hydra_saml_app_description }}"
|
fr: "{{ hydra_saml_app_title }}"
|
||||||
|
description:
|
||||||
|
fr: "{{ hydra_saml_app_description }}"
|
||||||
login_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_saml_base_path }}/login"
|
login_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_saml_base_path }}/login"
|
||||||
consent_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_saml_base_path }}/consent"
|
consent_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_saml_base_path }}/consent"
|
||||||
logout_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_saml_base_path }}/logout"
|
logout_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_saml_base_path }}/logout"
|
||||||
attributes_rewrite_rules: {{ hydra_saml_attributes_rewrite_rules | to_json }}
|
attributes_rewrite_rules: {{ hydra_saml_attributes_rewrite_rules | to_json }}
|
||||||
icon_url: "{{ hydra_saml_app_icon_url }}"
|
icon_url: "{{ hydra_saml_app_icon_url }}"
|
||||||
|
{% endif %}
|
||||||
|
{% if enable_hydra_oidc %}
|
||||||
|
- id: oidc
|
||||||
|
title:
|
||||||
|
fr: "{{ hydra_oidc_app_title }}"
|
||||||
|
description:
|
||||||
|
fr: "{{ hydra_oidc_app_description }}"
|
||||||
|
login_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_oidc_base_path }}/login"
|
||||||
|
consent_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_oidc_base_path }}/consent"
|
||||||
|
logout_url: "{{ haproxy_public_base_url }}{{ haproxy_hydra_oidc_base_path }}/logout"
|
||||||
|
attributes_rewrite_rules: {{ hydra_oidc_attributes_rewrite_rules | to_json }}
|
||||||
|
icon_url: "{{ hydra_oidc_app_icon_url }}"
|
||||||
{% endif %}
|
{% endif %}
|
Loading…
Reference in New Issue