mirror of
https://gitea.0xace.cc/ansible-galaxy/ddclient.git
synced 2025-07-12 18:13:07 +00:00
first commit
This commit is contained in:
40
tasks/configure.yml
Normal file
40
tasks/configure.yml
Normal file
@ -0,0 +1,40 @@
|
||||
---
|
||||
- block:
|
||||
- name: Create public key for ddclient from file
|
||||
copy:
|
||||
src: "{{ ddclient_tsig_public_key }}"
|
||||
dest: /etc/Kvps.key
|
||||
when: ddclient_tsig_public_key_file | length > 0
|
||||
|
||||
- name: Create private key for ddclient from file
|
||||
copy:
|
||||
src: "{{ ddclient_tsig_private_key }}"
|
||||
dest: /etc/Kvps.private
|
||||
when: ddclient_tsig_private_key_file | length > 0
|
||||
|
||||
- name: Create public key for ddclient from var
|
||||
copy:
|
||||
content: "{{ ddclient_tsig_public_key_base64 | b64decode }}"
|
||||
dest: /etc/Kvps.key
|
||||
when: ddclient_tsig_public_key_base64 | length > 0
|
||||
|
||||
- name: Create private key for ddclient from var
|
||||
copy:
|
||||
content: "{{ ddclient_tsig_private_key_base64 | b64decode }}"
|
||||
dest: /etc/Kvps.private
|
||||
when: ddclient_tsig_private_key_base64 | length > 0
|
||||
|
||||
- name: Configure ddlient.conf with template
|
||||
template:
|
||||
src: "ddclient.conf.j2"
|
||||
dest: "/etc/ddclient.conf"
|
||||
when: ddclient_conf_override | length == 0
|
||||
notify: Restart ddclient
|
||||
|
||||
- name: Configure ddlient.conf with overriding from var
|
||||
copy:
|
||||
content: "{{ ddclient_conf_override }}"
|
||||
dest: "/etc/ddclient.conf"
|
||||
when: ddclient_conf_override | length > 0
|
||||
notify: Restart ddclient
|
||||
|
33
tasks/docker.yml
Normal file
33
tasks/docker.yml
Normal file
@ -0,0 +1,33 @@
|
||||
---
|
||||
- name: Create configuration dir for {{ ddclient_namespace }}
|
||||
file:
|
||||
name: "/opt/{{ ddclient_namespace }}"
|
||||
state: directory
|
||||
|
||||
- name: Copy ddclient configuration for {{ ddclient_namespace }}
|
||||
copy:
|
||||
dest: "/opt/{{ ddclient_namespace }}/ddclient.conf"
|
||||
content: "{{ ddclient_conf }}"
|
||||
notify: Restart docker ddclient
|
||||
|
||||
- name: Copy Kvps.key for {{ ddclient_namespace }}
|
||||
copy:
|
||||
dest: "/opt/{{ ddclient_namespace }}/Kvps.key"
|
||||
content: "{{ ddclient_tsig_public_key_base64 | b64decode }}"
|
||||
notify: Restart docker ddclient
|
||||
|
||||
- name: Copy Kvps.private for {{ ddclient_namespace }}
|
||||
copy:
|
||||
dest: "/opt/{{ ddclient_namespace }}/Kvps.private"
|
||||
content: "{{ ddclient_tsig_private_key_base64 | b64decode }}"
|
||||
notify: Restart docker ddclient
|
||||
|
||||
- name: Start ddclient in docker for {{ ddclient_namespace }}
|
||||
docker_container:
|
||||
name: "{{ ddclient_container_name }}"
|
||||
image: "{{ ddclient_container_registry }}/{{ ddclient_image_name }}:{{ ddclient_image_tag }}"
|
||||
network_mode: "{{ ddclient_network_mode }}"
|
||||
state: started
|
||||
container_default_behavior: no_defaults
|
||||
restart_policy: unless-stopped
|
||||
volumes: "{{ ddclient_volumes }}"
|
12
tasks/install.yml
Normal file
12
tasks/install.yml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
- block:
|
||||
- name: Install ddclient and bind-utils
|
||||
dnf:
|
||||
name:
|
||||
- ddclient
|
||||
- bind-utils
|
||||
state: present
|
||||
notify: Start ddclient
|
||||
register: install_ddlient_result
|
||||
tags:
|
||||
- ddclient-install
|
22
tasks/main.yml
Normal file
22
tasks/main.yml
Normal file
@ -0,0 +1,22 @@
|
||||
---
|
||||
- name: Install ddclient (not containerized)
|
||||
when: not ddclient_containerized
|
||||
block:
|
||||
- import_tasks: install.yml
|
||||
- import_tasks: configure.yml
|
||||
become: true
|
||||
|
||||
- name: Install ddclient (containerized)
|
||||
when: ddclient_containerized
|
||||
block:
|
||||
- name: Merge volumes
|
||||
set_fact:
|
||||
ddclient_volumes: "{{ ddclient_volumes | default([]) + [item.key +':'+ item.value] }}"
|
||||
loop: "{{ ddclient_default_volumes | dict2items }}"
|
||||
|
||||
- import_tasks: docker.yml
|
||||
when: ddclient_container_engine == "docker"
|
||||
|
||||
- import_tasks: podman.yml
|
||||
when: ddclient_container_engine == "podman"
|
||||
become: true
|
49
tasks/podman.yml
Normal file
49
tasks/podman.yml
Normal file
@ -0,0 +1,49 @@
|
||||
---
|
||||
- name: Create configuration dir for {{ ddclient_namespace }}
|
||||
file:
|
||||
name: "/opt/{{ ddclient_namespace }}"
|
||||
state: directory
|
||||
|
||||
- name: Copy ddclient configuration for {{ ddclient_namespace }}
|
||||
copy:
|
||||
dest: "/opt/{{ ddclient_namespace }}/ddclient.conf"
|
||||
content: "{{ ddclient_conf }}"
|
||||
notify: Restart podman ddclient
|
||||
|
||||
- name: Copy Kvps.key for {{ ddclient_namespace }}
|
||||
copy:
|
||||
dest: "/opt/{{ ddclient_namespace }}/Kvps.key"
|
||||
content: "{{ ddclient_tsig_public_key_base64 | b64decode }}"
|
||||
notify: Restart podman ddclient
|
||||
|
||||
- name: Copy Kvps.private for {{ ddclient_namespace }}
|
||||
copy:
|
||||
dest: "/opt/{{ ddclient_namespace }}/Kvps.private"
|
||||
content: "{{ ddclient_tsig_private_key_base64 | b64decode }}"
|
||||
notify: Restart podman ddclient
|
||||
|
||||
- name: Start ddclient with podman for {{ ddclient_namespace }}
|
||||
containers.podman.podman_container:
|
||||
name: "{{ ddclient_container_name }}"
|
||||
hostname: "{{ ddclient_container_name }}"
|
||||
network: "{{ ddclient_network_mode }}"
|
||||
image: "{{ ddclient_container_registry }}/{{ ddclient_image_name }}:{{ ddclient_image_tag }}"
|
||||
state: present
|
||||
volumes: "{{ ddclient_volumes }}"
|
||||
|
||||
- name: Generate container systemd unit
|
||||
shell: "podman generate systemd {{ ddclient_container_name }}"
|
||||
register: ddclient_systemd_unit
|
||||
changed_when: False
|
||||
|
||||
- name: Create ddclient systemd unit
|
||||
copy:
|
||||
dest: "/etc/systemd/system/{{ ddclient_systemd_unit_name }}"
|
||||
content: "{{ ddclient_systemd_unit.stdout | regex_replace('^#.*', multiline=True) | trim }}"
|
||||
|
||||
- name: Enable ddclient systemd unit
|
||||
ansible.builtin.systemd:
|
||||
name: "{{ ddclient_systemd_unit_name }}"
|
||||
enabled: yes
|
||||
state: started
|
||||
daemon_reload: yes
|
Reference in New Issue
Block a user