ansible/playbooks/mailu_switch_to_second.yaml

83 lines
2.4 KiB
YAML
Raw Normal View History

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