blob: 3da1246f3014c8f04e6bf75dced183e7e1dd2e23 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
# SPDX-FileCopyrightText: 2024 Matthew Fennell <matthew@fennell.dev>
#
# SPDX-License-Identifier: AGPL-3.0-only
---
- name: Ensure XMPP server is set up
hosts: xmpp_server
tasks:
- name: Ensure required packages are installed
ansible.builtin.package:
name:
- certbot
- prosody
- prosody-modules
- python3-certbot-apache
- ufw
state: present
- name: Ensure required ports are open
community.general.ufw:
rule: allow
name: "{{ item }}"
state: enabled
loop:
- OpenSSH
- WWW
- XMPP
become: true
- name: Ensure top-level prosody configuration is installed
ansible.builtin.copy:
src: "{{ playbook_dir }}/files/prosody.cfg.lua"
dest: /etc/prosody/prosody.cfg.lua
owner: root
group: root
mode: "0640"
become: true
- name: Ensure host-specific prosody configuration is available
ansible.builtin.template:
src: "{{ playbook_dir }}/files/virtual_host.cfg.lua.j2"
dest: "/etc/prosody/conf.avail/{{ virtual_host }}.cfg.lua"
owner: root
group: root
mode: "0644"
become: true
- name: Ensure host-specific prosody configuration is set
ansible.builtin.file:
src: "/etc/prosody/conf.avail/{{ virtual_host }}.cfg.lua"
dest: "/etc/prosody/conf.d/{{ virtual_host }}.cfg.lua"
owner: root
group: root
state: link
become: true
- name: Ensure prosody config is reloaded
ansible.builtin.service:
name: prosody
enabled: true
state: reloaded
become: true
|