feat(fediwall): add ansible role

This commit is contained in:
2025-05-30 18:39:10 +02:00
parent b6365008ad
commit a206695e69
10 changed files with 194 additions and 0 deletions

View 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 }}"

View 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"