feat: modularize playbook with tags
This commit is contained in:
parent
2b4e669cc3
commit
b8bcad874f
@ -15,7 +15,7 @@ cadoles_pod_hydra_oidc_v1_package_version: '*'
|
|||||||
cadoles_pod_hydra_ldap_v1_package_version: '*'
|
cadoles_pod_hydra_ldap_v1_package_version: '*'
|
||||||
|
|
||||||
# Hydra database configuration
|
# Hydra database configuration
|
||||||
hydra_use_external_database: no
|
hydra_use_external_database: false
|
||||||
hydra_database_name: hydra
|
hydra_database_name: hydra
|
||||||
hydra_database_user: hydra
|
hydra_database_user: hydra
|
||||||
hydra_database_password: hydra
|
hydra_database_password: hydra
|
||||||
|
34
tasks/install-hydra.yml
Normal file
34
tasks/install-hydra.yml
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
---
|
||||||
|
|
||||||
|
- name: Install Hydra
|
||||||
|
ansible.builtin.apt:
|
||||||
|
name:
|
||||||
|
- cadoles-pod-hydra-v1={{ cadoles_pod_hydra_v1_package_version }}
|
||||||
|
update_cache: yes
|
||||||
|
state: present
|
||||||
|
become: true
|
||||||
|
|
||||||
|
- name: Configure Hydra local database
|
||||||
|
ansible.builtin.include_tasks: hydra-database.yml
|
||||||
|
when: not hydra_use_external_database
|
||||||
|
|
||||||
|
- name: Configure cadoles-pod-hydra-v1
|
||||||
|
template:
|
||||||
|
src: "{{ item.src }}"
|
||||||
|
dest: "{{ item.dest }}"
|
||||||
|
with_items:
|
||||||
|
- src: cadoles-pod-hydra-v1.conf.j2
|
||||||
|
dest: /etc/cadoles-pod-hydra-v1.conf
|
||||||
|
notify:
|
||||||
|
- Restart cadoles-pod-hydra-v1
|
||||||
|
become: true
|
||||||
|
|
||||||
|
- name: Create hydra-clients
|
||||||
|
template:
|
||||||
|
src: hydra-client.json.j2
|
||||||
|
dest: "/etc/hydra/clients.d/{{ item.client_id }}.json"
|
||||||
|
with_items: "{{ hydra_clients }}"
|
||||||
|
notify:
|
||||||
|
- Reload hydra clients
|
||||||
|
become: true
|
||||||
|
|
@ -9,24 +9,28 @@
|
|||||||
update_cache: yes
|
update_cache: yes
|
||||||
state: present
|
state: present
|
||||||
become: true
|
become: true
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
|
||||||
- name: Add LetsEncrypt missing intermediate certificates
|
- name: Add LetsEncrypt missing intermediate certificates
|
||||||
command: "bash -c 'wget -O- --no-check-certificate https://forge.cadoles.com/Cadoles/Jenkins/raw/branch/master/resources/com/cadoles/common/add-letsencrypt-ca.sh | bash'"
|
command: "bash -c 'wget -O- --no-check-certificate https://forge.cadoles.com/Cadoles/Jenkins/raw/branch/master/resources/com/cadoles/common/add-letsencrypt-ca.sh | bash'"
|
||||||
args:
|
args:
|
||||||
creates: /etc/ssl/certs/lets-encrypt-e1.pem.pem
|
creates: /etc/ssl/certs/lets-encrypt-e1.pem.pem
|
||||||
become: true
|
become: true
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
|
||||||
- name: Add cadoles-pod debian repository key
|
- name: Add cadoles-pod debian repository key
|
||||||
ansible.builtin.apt_key:
|
ansible.builtin.apt_key:
|
||||||
url: "{{ cadoles_pod_debian_repository_key_url }}"
|
url: "{{ cadoles_pod_debian_repository_key_url }}"
|
||||||
state: present
|
state: present
|
||||||
become: true
|
become: true
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
|
||||||
- name: Configure cadoles-pod debian repository
|
- name: Configure cadoles-pod debian repository
|
||||||
ansible.builtin.apt_repository:
|
ansible.builtin.apt_repository:
|
||||||
repo: "deb {{ cadoles_pod_debian_repository_url }} {{ cadoles_pod_debian_repository }} main"
|
repo: "deb {{ cadoles_pod_debian_repository_url }} {{ cadoles_pod_debian_repository }} main"
|
||||||
state: present
|
state: present
|
||||||
become: true
|
become: true
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
|
||||||
- name: Ensure sysctl configuration
|
- name: Ensure sysctl configuration
|
||||||
ansible.posix.sysctl:
|
ansible.posix.sysctl:
|
||||||
@ -39,39 +43,30 @@
|
|||||||
- name: fs.inotify.max_user_watches
|
- name: fs.inotify.max_user_watches
|
||||||
value: 204800
|
value: 204800
|
||||||
become: true
|
become: true
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
|
||||||
- name: Install core packages
|
- name: Install HAProxy
|
||||||
ansible.builtin.apt:
|
ansible.builtin.apt:
|
||||||
name:
|
name:
|
||||||
- haproxy={{ haproxy_package_version }}
|
- haproxy={{ haproxy_package_version }}
|
||||||
- cadoles-pod-hydra-v1={{ cadoles_pod_hydra_v1_package_version }}
|
|
||||||
- cadoles-pod-hydra-dispatcher-v1={{ cadoles_pod_hydra_dispatcher_v1_package_version }}
|
|
||||||
update_cache: yes
|
update_cache: yes
|
||||||
state: present
|
state: present
|
||||||
become: true
|
become: true
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
|
||||||
- name: Configure Hydra local database
|
- name: Install Hydra
|
||||||
ansible.builtin.include_tasks: hydra-database.yml
|
include_tasks:
|
||||||
when: not hydra_use_external_database
|
file: ./install-hydra.yml
|
||||||
|
apply:
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
|
||||||
- name: Create hydra-clients
|
- name: Install hydra-dispatcher
|
||||||
template:
|
ansible.builtin.apt:
|
||||||
src: hydra-client.json.j2
|
name:
|
||||||
dest: "/etc/hydra/clients.d/{{ item.client_id }}.json"
|
- cadoles-pod-hydra-dispatcher-v1={{ cadoles_pod_hydra_dispatcher_v1_package_version }}
|
||||||
with_items: "{{ hydra_clients }}"
|
update_cache: yes
|
||||||
notify:
|
state: present
|
||||||
- Reload hydra clients
|
|
||||||
become: true
|
|
||||||
|
|
||||||
- name: Configure cadoles-pod-hydra-v1
|
|
||||||
template:
|
|
||||||
src: "{{ item.src }}"
|
|
||||||
dest: "{{ item.dest }}"
|
|
||||||
with_items:
|
|
||||||
- src: cadoles-pod-hydra-v1.conf.j2
|
|
||||||
dest: /etc/cadoles-pod-hydra-v1.conf
|
|
||||||
notify:
|
|
||||||
- Restart cadoles-pod-hydra-v1
|
|
||||||
become: true
|
become: true
|
||||||
|
|
||||||
- name: Configure cadoles-pod-hydra-dispatcher-v1
|
- name: Configure cadoles-pod-hydra-dispatcher-v1
|
||||||
@ -122,3 +117,4 @@
|
|||||||
notify:
|
notify:
|
||||||
- Restart HAProxy
|
- Restart HAProxy
|
||||||
become: true
|
become: true
|
||||||
|
tags: [ hydra-only ]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user