feat(element): add ansible role
This commit is contained in:
35
roles/element/tasks/configure.yml
Normal file
35
roles/element/tasks/configure.yml
Normal file
@ -0,0 +1,35 @@
|
||||
---
|
||||
- name: Ensure element user '{{ element_user }}' is {{ element_state }}
|
||||
ansible.builtin.user:
|
||||
name: "{{ element_user }}"
|
||||
system: "{{ element_user_system | default(true, true) }}"
|
||||
create_home: "{{ element_user_create_home | default(false, true) }}"
|
||||
state: "{{ element_state }}"
|
||||
register: element_user_info
|
||||
|
||||
- name: Ensure host paths are {{ element_state }}
|
||||
ansible.builtin.file:
|
||||
name: "{{ path.name }}"
|
||||
state: "{{ (element_state == 'present') | ternary('directory', 'absent') }}"
|
||||
owner: "{{ path.owner | default(element_host_uid) }}"
|
||||
group: "{{ path.group | default(element_host_gid) }}"
|
||||
mode: "{{ path.mode | default('0750') }}"
|
||||
loop_control:
|
||||
loop_var: path
|
||||
label: "{{ path.name }}"
|
||||
loop:
|
||||
- name: "{{ element_base_path }}"
|
||||
mode: '0755'
|
||||
- name: "{{ element_config_path }}"
|
||||
mode: '0755'
|
||||
- name: "{{ element_source_path }}"
|
||||
mode: '0750'
|
||||
|
||||
- name: Ensure config file is {{ element_state }}
|
||||
ansible.builtin.copy:
|
||||
content: "{{ element_config | to_nice_json }}"
|
||||
dest: "{{ element_config_file }}"
|
||||
owner: "{{ element_host_uid }}"
|
||||
group: "{{ element_host_gid }}"
|
||||
mode: "{{ element_config_file_mode | default('0664') }}"
|
||||
when: element_state == 'present'
|
33
roles/element/tasks/deploy-docker.yml
Normal file
33
roles/element/tasks/deploy-docker.yml
Normal file
@ -0,0 +1,33 @@
|
||||
---
|
||||
- name: Ensure docker client is logged {{ (element_state == 'present') | ternary('in', 'out') }}
|
||||
community.docker.docker_login:
|
||||
registry_url: "{{ element_container_image_registry }}"
|
||||
username: "{{ element_container_image_registry_username }}"
|
||||
password: "{{ element_container_image_registry_password }}"
|
||||
reauthorize: "{{ element_container_image_registry_reauthorize | default(omit, true) }}"
|
||||
state: "{{ element_state }}"
|
||||
when:
|
||||
- element_container_image_registry_username | default(false, true)
|
||||
- element_container_image_registry_password | default(false, true)
|
||||
|
||||
- name: Ensure container image '{{ element_container_image }}' is {{ element_state }} locally
|
||||
community.docker.docker_image:
|
||||
name: "{{ element_container_image }}"
|
||||
state: "{{ element_state }}"
|
||||
source: "{{ element_container_source }}"
|
||||
force_source: "{{ element_container_image_tag | default(false, true) }}"
|
||||
|
||||
- name: Ensure container '{{ element_container_name }}' is {{ element_state }}
|
||||
community.docker.docker_container:
|
||||
name: "{{ element_container_name }}"
|
||||
image: "{{ element_container_image }}"
|
||||
state: "{{ (element_state == 'present') | ternary('started', 'absent') }}"
|
||||
env: "{{ element_container_env | default(omit) }}"
|
||||
user: "{{ element_container_user }}"
|
||||
ports: "{{ element_container_ports | default(omit) }}"
|
||||
labels: "{{ element_container_labels | default(omit) }}"
|
||||
volumes: "{{ element_container_full_volumes }}"
|
||||
networks: "{{ element_container_networks | default(omit) }}"
|
||||
etc_hosts: "{{ element_container_etc_hosts | default(omit) }}"
|
||||
restart_policy: "{{ element_container_restart_policy }}"
|
||||
purge_networks: "{{ element_container_purge_networks | default(omit) }}"
|
20
roles/element/tasks/main.yml
Normal file
20
roles/element/tasks/main.yml
Normal file
@ -0,0 +1,20 @@
|
||||
---
|
||||
- name: Check if state is valid
|
||||
ansible.builtin.fail:
|
||||
msg: "Unknown state '{{ element_state }}'. Valid states are {{ element_states | join(', ') }}"
|
||||
when: element_state not in element_states
|
||||
|
||||
- name: Check if deployment method is supported
|
||||
ansible.builtin.fail:
|
||||
msg: >-
|
||||
Deployment method '{{ element_deployment_method }}' is not supported!
|
||||
Supported are: {{ element_deployment_methods | join(', ') }}
|
||||
when: element_deployment_method not in element_deployment_methods
|
||||
|
||||
- name: Include base configuration
|
||||
ansible.builtin.include_tasks:
|
||||
file: configure.yml
|
||||
|
||||
- name: Deploy using {{ element_deployment_method }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "deploy-{{ element_deployment_method }}.yml"
|
Reference in New Issue
Block a user