feat(unifi_controller): add ansible role and playbook

This commit is contained in:
2025-09-02 18:16:34 +02:00
parent 6b004e3477
commit 2342d6ee96
10 changed files with 151 additions and 0 deletions

View File

@@ -0,0 +1,17 @@
---
- name: Ensure container image '{{ unifi_controller_container_image }}' is {{ unifi_controller_state }}
community.docker.docker_image:
name: "{{ unifi_controller_container_image }}"
state: "{{ unifi_controller_state }}"
source: "{{ unifi_controller_container_image_source }}"
force_source: "{{ unifi_controller_container_image_force_source }}"
- name: Ensure container '{{ unifi_controller_container_name }}' is {{ unifi_controller_container_state }}
community.docker.docker_container:
name: "{{ unifi_controller_container_name }}"
image: "{{ unifi_controller_container_image }}"
user: "{{ unifi_controller_container_user }}"
ports: "{{ unifi_controller_container_ports }}"
volumes: "{{ unifi_controller_container_merged_volumes }}"
restart_policy: "{{ unifi_controller_container_restart_policy }}"
state: "{{ unifi_controller_container_state }}"

View File

@@ -0,0 +1,17 @@
---
- name: Ensure container image '{{ unifi_controller_container_image }}' is {{ unifi_controller_state }}
containers.podman.podman_image:
name: "{{ unifi_controller_container_image }}"
state: "{{ unifi_controller_state }}"
pull: "{{ unifi_controller_container_image_pull }}"
force: "{{ unifi_controller_container_image_force_pull }}"
- name: Ensure container '{{ unifi_controller_container_name }}' is {{ unifi_controller_container_state }}
containers.podman.podman_container:
name: "{{ unifi_controller_container_name }}"
image: "{{ unifi_controller_container_image }}"
user: "{{ unifi_controller_container_user }}"
ports: "{{ unifi_controller_container_ports }}"
volumes: "{{ unifi_controller_container_merged_volumes }}"
restart_policy: "{{ unifi_controller_container_restart_policy }}"
state: "{{ unifi_controller_container_state }}"

View File

@@ -0,0 +1,18 @@
---
- name: Ensure unifi controller run user '{{ unifi_controller_user }}' is {{ unifi_controller_state }}
ansible.builtin.user:
name: "{{ unifi_controller_user }}"
state: "{{ unifi_controller_state }}"
register: unifi_controller_user_info
- name: Ensure unifi controller base path '{{ unifi_controller_base_path }}' is {{ unifi_controller_state }}
ansible.builtin.file:
path: "{{ unifi_controller_base_path }}"
state: "{{ (unifi_controller_state == 'present') | ternary('directory', 'absent') }}"
owner: "{{ unifi_controller_run_uid }}"
group: "{{ unifi_controller_run_gid }}"
mode: "0755"
- name: Deploy unifi controller with {{ unifi_controller_deployment_method }}
ansible.builtin.include_tasks:
file: "deploy-{{ unifi_controller_deployment_method }}.yml"