2023-09-15 14:04:30 +02:00
|
|
|
- hosts: containers
|
2023-11-01 01:51:24 +01:00
|
|
|
name: Switch mailu to second
|
2023-11-01 01:30:32 +01:00
|
|
|
|
2023-09-15 14:04:30 +02:00
|
|
|
ignore_unreachable: false
|
|
|
|
vars:
|
2024-05-28 00:41:00 +02:00
|
|
|
NEW_IP: 192.168.77.238
|
2023-09-15 14:04:30 +02:00
|
|
|
arch_name: docker_mailu2_data
|
2023-11-01 01:59:49 +01:00
|
|
|
containers:
|
|
|
|
- nginx-app-1
|
|
|
|
- heimdall
|
|
|
|
- mailu2-admin-1
|
|
|
|
- mailu2-antispam-1
|
|
|
|
- mailu2-antivirus-1
|
|
|
|
- mailu2-fetchmail-1
|
|
|
|
- mailu2-front-1
|
|
|
|
- mailu2-imap-1
|
|
|
|
- mailu2-oletools-1
|
|
|
|
- mailu2-redis-1
|
|
|
|
- mailu2-resolver-1
|
|
|
|
- mailu2-smtp-1
|
2023-11-01 02:02:07 +01:00
|
|
|
- mailu2-webdav-1
|
|
|
|
- mailu2-webmail-1
|
|
|
|
- HomeAssistant
|
|
|
|
- mosquitto-mosquitto-1
|
2023-09-15 14:04:30 +02:00
|
|
|
tasks:
|
2023-11-01 01:04:47 +01:00
|
|
|
# - name: Start mailu rasp
|
|
|
|
# uri:
|
|
|
|
# url: "http://192.168.77.106:9000/api/stacks/{{ item }}/start?endpointId=13"
|
|
|
|
# method: POST
|
|
|
|
# body_format: form-urlencoded
|
|
|
|
# return_content: yes
|
|
|
|
# headers:
|
|
|
|
# Content-Type: "application/json"
|
|
|
|
# X-API-Key: "ptr_DfS2M6Fj2P3fVvYpkhE0KJh2UGCzY47ePaFaLqadsjg="
|
|
|
|
# timeout: 60
|
|
|
|
# ignore_errors: yes
|
|
|
|
# when: inventory_hostname in groups['nas']
|
|
|
|
# loop:
|
|
|
|
# - 130
|
|
|
|
# - 149
|
|
|
|
# #- 140
|
|
|
|
# - 180
|
|
|
|
- name: Start mailu containers
|
2023-11-01 01:59:49 +01:00
|
|
|
command: "docker restart {{ containers | join(' ') }}"
|
2023-11-01 01:46:26 +01:00
|
|
|
become: true
|
2023-11-01 01:56:50 +01:00
|
|
|
ignore_errors: true
|
2024-05-28 00:43:07 +02:00
|
|
|
when: inventory_hostname in groups['raspberrypi5']
|
2023-11-01 01:30:32 +01:00
|
|
|
|
2023-09-15 14:04:30 +02:00
|
|
|
- name: Get ruleset
|
|
|
|
command: nvram get vts_rulelist
|
|
|
|
when: inventory_hostname in groups['router']
|
|
|
|
register: ruleset
|
2024-05-28 00:41:00 +02:00
|
|
|
|
|
|
|
- name: Print the gateway for each host when defined
|
|
|
|
ansible.builtin.debug:
|
2024-05-28 00:58:03 +02:00
|
|
|
msg: "var is {{ ruleset }}"
|
2024-05-28 00:41:00 +02:00
|
|
|
- set_fact:
|
|
|
|
app_path: "{{ ruleset.stdout | regex_replace('(\\<MAIL_SERVER\\>[0-9,]{1,}\\>)([0-9.]{1,})(\\>[0-9a-zA-Z\\s-]{0,}\\>TCP\\>)', '\\1{{ NEW_IP }}\\3') | regex_replace('(\\<WEB_SERVER\\>[0-9,]{1,}\\>)([0-9.]{1,})(\\>[0-9a-zA-Z\\s-]{0,}\\>TCP\\>)', '\\1{{ NEW_IP }}\\3') }}"
|
|
|
|
- name: Print the gateway for each host when defined
|
|
|
|
ansible.builtin.debug:
|
|
|
|
msg: "var is {{ app_path }}"
|
|
|
|
|
|
|
|
|
2023-09-15 14:04:30 +02:00
|
|
|
- name: Pause for 60 seconds
|
|
|
|
ansible.builtin.pause:
|
|
|
|
seconds: 60
|
|
|
|
|
|
|
|
- name: Set new ruleset
|
2024-05-28 00:41:00 +02:00
|
|
|
command: nvram set vts_rulelist="{{ app_path }}"
|
2023-09-15 14:04:30 +02:00
|
|
|
when: inventory_hostname in groups['router']
|
|
|
|
|
|
|
|
- name: Nvram commit
|
|
|
|
command: nvram commit
|
|
|
|
when: inventory_hostname in groups['router']
|
|
|
|
|
|
|
|
- name: Restart firewall
|
|
|
|
command: service restart_firewall
|
|
|
|
when: inventory_hostname in groups['router']
|
2023-11-01 00:55:11 +01:00
|
|
|
|
2023-09-15 14:04:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|