feat(fediwall): add ansible role
This commit is contained in:
26
roles/fediwall/tasks/deploy-docker.yml
Normal file
26
roles/fediwall/tasks/deploy-docker.yml
Normal file
@ -0,0 +1,26 @@
|
||||
---
|
||||
- name: Ensure container image '{{ fediwall_container_image }}' is {{ fediwall_state }}
|
||||
community.docker.docker_image:
|
||||
name: "{{ fediwall_container_image }}"
|
||||
state: "{{ fediwall_state }}"
|
||||
source: "{{ fediwall_container_image_source }}"
|
||||
force_source: "{{ fediwall_container_image_force_source }}"
|
||||
|
||||
- name: Ensure container '{{ fediwall_container_name }}' is {{ fediwall_container_state }}
|
||||
community.docker.docker_container:
|
||||
name: "{{ fediwall_container_name }}"
|
||||
image: "{{ fediwall_container_image }}"
|
||||
env: "{{ fediwall_container_env | default(omit, true) }}"
|
||||
user: "{{ fediwall_container_user | default(omit, true) }}"
|
||||
ports: "{{ fediwall_container_ports | default(omit, true) }}"
|
||||
labels: "{{ fediwall_container_labels | default(omit, true) }}"
|
||||
volumes: "{{ fediwall_container_final_volumes | default(omit, true) }}"
|
||||
networks: "{{ fediwall_container_networks | default(omit, true) }}"
|
||||
network_mode: "{{ fediwall_container_network_mode | default(omit, true) }}"
|
||||
dns_servers: "{{ fediwall_container_dns_servers | default(omit, true) }}"
|
||||
etc_hosts: "{{ fediwall_container_etc_hosts | default(omit, true) }}"
|
||||
memory: "{{ fediwall_container_memory | default(omit, true) }}"
|
||||
memory_swap: "{{ fediwall_container_memory_swap | default(omit, true) }}"
|
||||
memory_reservation: "{{ fediwall_container_memory_reservation | default(omit, true) }}"
|
||||
restart_policy: "{{ fediwall_container_restart_policy }}"
|
||||
state: "{{ fediwall_container_state }}"
|
43
roles/fediwall/tasks/main.yml
Normal file
43
roles/fediwall/tasks/main.yml
Normal file
@ -0,0 +1,43 @@
|
||||
---
|
||||
- name: Ensure 'fediwall_state' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported state '{{ fediwall_state }}'. Supported
|
||||
states are {{ fediwall_states | map(quote) | join(', ') }}
|
||||
when: fediwall_state not in fediwall_states
|
||||
|
||||
- name: Ensure 'fediwall_deployment_method' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported deployment method '{{ fediwall_deployment_method }}'.
|
||||
upported deployment methods are {{ fediwall_deployment_methods | join(', ') }}
|
||||
when: fediwall_deployment_method not in fediwall_deployment_methods
|
||||
|
||||
- name: Ensure user '{{ fediwall_user }}' is {{ fediwall_state }}
|
||||
ansible.builtin.user:
|
||||
name: "{{ fediwall_user }}"
|
||||
state: "{{ fediwall_state }}"
|
||||
system: "{{ fediwall_user_system | default(true, true) }}"
|
||||
create_home: "{{ fediwall_user_system | default(false, true) }}"
|
||||
|
||||
- name: Ensure configuration folder '{{ fediwall_config_file_path }}' is {{ fediwall_state }}
|
||||
ansible.builtin.file:
|
||||
path: "{{ fediwall_config_file_path }}"
|
||||
state: directory
|
||||
when: fediwall_state == 'present'
|
||||
|
||||
- name: Ensure configuration in '{{ fediwall_config_file }}' is {{ fediwall_state }}
|
||||
ansible.builtin.copy:
|
||||
content: "{{ fediwall_final_config | to_nice_json(indent=2) }}"
|
||||
dest: "{{ fediwall_config_file }}"
|
||||
state: "{{ fediwall_state }}"
|
||||
|
||||
- name: Ensure configuration folder is {{ fediwall_state }}
|
||||
ansible.builtin.file:
|
||||
path: "{{ fediwall_config_file_path }}"
|
||||
state: absent
|
||||
when: fediwall_state == 'absent'
|
||||
|
||||
- name: Deploy using {{ fediwall_deployment_method }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "deploy-{{ fediwall_deployment_method }}.yml"
|
Reference in New Issue
Block a user