Merge pull request #425 from christianlupus/dev/archlinux
Added support for arch linux
This commit is contained in:
commit
ac5b5681ae
@ -1,6 +1,6 @@
|
|||||||
# Prerequisites
|
# Prerequisites
|
||||||
|
|
||||||
- An x86 server running **CentOS** (7 only for now; [8 is not yet supported](https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/300)), **Debian** (9/Stretch+) or **Ubuntu** (16.04+). This playbook doesn't support running on ARM ([see](https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/299)), however a minimal subset of the tools can be built on the host, which may result in a working configuration, even on a Raspberry pi (see [Self-Building](self-building.md)). We only strive to support released stable versions of distributions, not betas or pre-releases. This playbook can take over your whole server or co-exist with other services that you have there.
|
- An x86 server running **CentOS** (7 only for now; [8 is not yet supported](https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/300)), **Debian** (9/Stretch+), **Ubuntu** (16.04+), or **Archlinux**. This playbook doesn't support running on ARM ([see](https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/299)), however a minimal subset of the tools can be built on the host, which may result in a working configuration, even on a Raspberry pi (see [Self-Building](self-building.md)). We only strive to support released stable versions of distributions, not betas or pre-releases. This playbook can take over your whole server or co-exist with other services that you have there.
|
||||||
|
|
||||||
- `root` access to your server (or a user capable of elevating to `root` via `sudo`).
|
- `root` access to your server (or a user capable of elevating to `root` via `sudo`).
|
||||||
|
|
||||||
|
@ -44,3 +44,10 @@
|
|||||||
- "{{ matrix_server_fqn_matrix }}"
|
- "{{ matrix_server_fqn_matrix }}"
|
||||||
- "{{ matrix_server_fqn_riot }}"
|
- "{{ matrix_server_fqn_riot }}"
|
||||||
when: "item != item|lower"
|
when: "item != item|lower"
|
||||||
|
|
||||||
|
- name: Fail if using python2 on Archlinux
|
||||||
|
fail:
|
||||||
|
msg: "Detected that you're using python2 when installing onto Archlinux. Archlinux by default only supports python3."
|
||||||
|
when:
|
||||||
|
- ansible_distribution == 'Archlinux'
|
||||||
|
- ansible_python.version.major != 3
|
||||||
|
@ -9,6 +9,9 @@
|
|||||||
- include_tasks: "{{ role_path }}/tasks/server_base/setup_raspbian.yml"
|
- include_tasks: "{{ role_path }}/tasks/server_base/setup_raspbian.yml"
|
||||||
when: (ansible_os_family == 'Debian') and (ansible_lsb.id == 'Raspbian')
|
when: (ansible_os_family == 'Debian') and (ansible_lsb.id == 'Raspbian')
|
||||||
|
|
||||||
|
- include_tasks: "{{ role_path }}/tasks/server_base/setup_archlinux.yml"
|
||||||
|
when: ansible_distribution == 'Archlinux'
|
||||||
|
|
||||||
- name: Ensure Docker is started and autoruns
|
- name: Ensure Docker is started and autoruns
|
||||||
service:
|
service:
|
||||||
name: docker
|
name: docker
|
||||||
@ -17,6 +20,6 @@
|
|||||||
|
|
||||||
- name: Ensure ntpd is started and autoruns
|
- name: Ensure ntpd is started and autoruns
|
||||||
service:
|
service:
|
||||||
name: "{{ 'ntpd' if ansible_os_family == 'RedHat' else 'ntp' }}"
|
name: "{{ 'ntpd' if ansible_os_family == 'RedHat' or ansible_distribution == 'Archlinux' else 'ntp' }}"
|
||||||
state: started
|
state: started
|
||||||
enabled: yes
|
enabled: yes
|
||||||
|
20
roles/matrix-base/tasks/server_base/setup_archlinux.yml
Normal file
20
roles/matrix-base/tasks/server_base/setup_archlinux.yml
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
---
|
||||||
|
|
||||||
|
- name: Install host dependencies
|
||||||
|
pacman:
|
||||||
|
name:
|
||||||
|
- bash-completion
|
||||||
|
- python-docker
|
||||||
|
- ntp
|
||||||
|
# TODO This needs to be verified. Which version do we need?
|
||||||
|
- fuse3
|
||||||
|
- python-dnspython
|
||||||
|
state: latest
|
||||||
|
update_cache: yes
|
||||||
|
|
||||||
|
- name: Ensure Docker is installed
|
||||||
|
pacman:
|
||||||
|
name:
|
||||||
|
- docker
|
||||||
|
state: latest
|
||||||
|
when: matrix_docker_installation_enabled|bool
|
@ -30,6 +30,7 @@
|
|||||||
|
|
||||||
- name: Populate service facts
|
- name: Populate service facts
|
||||||
service_facts:
|
service_facts:
|
||||||
|
when: ansible_distribution != 'Archlinux'
|
||||||
|
|
||||||
- name: Fail if service isn't detected to be running
|
- name: Fail if service isn't detected to be running
|
||||||
fail:
|
fail:
|
||||||
@ -38,4 +39,31 @@
|
|||||||
It's possible that there's a configuration problem or another service on your server interferes with it (uses the same ports, etc.).
|
It's possible that there's a configuration problem or another service on your server interferes with it (uses the same ports, etc.).
|
||||||
Try running `systemctl status {{ item }}` and `journalctl -fu {{ item }}` on the server to investigate.
|
Try running `systemctl status {{ item }}` and `journalctl -fu {{ item }}` on the server to investigate.
|
||||||
with_items: "{{ matrix_systemd_services_list }}"
|
with_items: "{{ matrix_systemd_services_list }}"
|
||||||
when: "ansible_facts.services[item + '.service']|default(none) is none or ansible_facts.services[item + '.service'].state != 'running'"
|
when:
|
||||||
|
- "ansible_facts.services[item + '.service']|default(none) is none or ansible_facts.services[item + '.service'].state != 'running'"
|
||||||
|
- ansible_distribution != 'Archlinux'
|
||||||
|
|
||||||
|
# Currently there is a bug in ansible that renders is incompatible with systemd.
|
||||||
|
# service_facts is not collecting the data successfully.
|
||||||
|
# Therefore iterating here manually
|
||||||
|
- name: Fetch systemd information
|
||||||
|
systemd:
|
||||||
|
name: "{{ item }}"
|
||||||
|
register: systemdstatus
|
||||||
|
with_items: "{{ matrix_systemd_services_list }}"
|
||||||
|
when:
|
||||||
|
- ansible_distribution == 'Archlinux'
|
||||||
|
|
||||||
|
- name: Fail if service isn't detected to be running
|
||||||
|
fail:
|
||||||
|
msg: >-
|
||||||
|
{{ item.item }} was not detected to be running.
|
||||||
|
It's possible that there's a configuration problem or another service on your server interferes with it (uses the same ports, etc.).
|
||||||
|
Try running `systemctl status {{ item.item }}` and `journalctl -fu {{ item.item }}` on the server to investigate.
|
||||||
|
with_items: "{{ systemdstatus.results }}"
|
||||||
|
loop_control:
|
||||||
|
label: "{{ item.name }}"
|
||||||
|
when:
|
||||||
|
#- "ansible_facts.services[item + '.service']|default(none) is none or ansible_facts.services[item + '.service'].state != 'running'"
|
||||||
|
- "item.status['ActiveState'] != 'active'"
|
||||||
|
- "ansible_distribution == 'Archlinux'"
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
when: matrix_mxisd_enabled|bool and not matrix_mxisd_container_image_self_build
|
when: matrix_mxisd_enabled|bool and not matrix_mxisd_container_image_self_build
|
||||||
|
|
||||||
- block:
|
- block:
|
||||||
- name: Ensure gradle is installed for self-building
|
- name: Ensure gradle is installed for self-building (Debian)
|
||||||
apt:
|
apt:
|
||||||
name:
|
name:
|
||||||
- gradle
|
- gradle
|
||||||
@ -34,11 +34,19 @@
|
|||||||
update_cache: yes
|
update_cache: yes
|
||||||
when: (ansible_os_family == 'Debian')
|
when: (ansible_os_family == 'Debian')
|
||||||
|
|
||||||
- name: Ensure gradle is installed for self-building
|
- name: Ensure gradle is installed for self-building (CentOS)
|
||||||
fail:
|
fail:
|
||||||
msg: "Installing gradle on CentOS is currently not supported, so self-building mxisd cannot happen at this time"
|
msg: "Installing gradle on CentOS is currently not supported, so self-building mxisd cannot happen at this time"
|
||||||
when: ansible_distribution == 'CentOS'
|
when: ansible_distribution == 'CentOS'
|
||||||
|
|
||||||
|
- name: Ensure gradle is installed for self-building (Archlinux)
|
||||||
|
pacman:
|
||||||
|
name:
|
||||||
|
- gradle
|
||||||
|
state: latest
|
||||||
|
update_cache: yes
|
||||||
|
when: ansible_distribution == 'Archlinux'
|
||||||
|
|
||||||
- name: Ensure mxisd repository is present on self-build
|
- name: Ensure mxisd repository is present on self-build
|
||||||
git:
|
git:
|
||||||
repo: https://github.com/kamax-matrix/mxisd.git
|
repo: https://github.com/kamax-matrix/mxisd.git
|
||||||
|
@ -16,6 +16,14 @@
|
|||||||
update_cache: no
|
update_cache: no
|
||||||
when: "matrix_ssl_retrieval_method == 'self-signed' and ansible_os_family == 'Debian'"
|
when: "matrix_ssl_retrieval_method == 'self-signed' and ansible_os_family == 'Debian'"
|
||||||
|
|
||||||
|
- name: Ensure OpenSSL installed (Archlinux)
|
||||||
|
pacman:
|
||||||
|
name:
|
||||||
|
- openssl
|
||||||
|
state: latest
|
||||||
|
update_cache: no
|
||||||
|
when: "matrix_ssl_retrieval_method == 'self-signed' and ansible_distribution == 'Archlinux'"
|
||||||
|
|
||||||
- name: Generate self-signed certificates
|
- name: Generate self-signed certificates
|
||||||
include_tasks: "{{ role_path }}/tasks/ssl/setup_ssl_self_signed_obtain_for_domain.yml"
|
include_tasks: "{{ role_path }}/tasks/ssl/setup_ssl_self_signed_obtain_for_domain.yml"
|
||||||
with_items: "{{ matrix_ssl_domains_to_obtain_certificates_for }}"
|
with_items: "{{ matrix_ssl_domains_to_obtain_certificates_for }}"
|
||||||
|
@ -21,6 +21,14 @@
|
|||||||
update_cache: no
|
update_cache: no
|
||||||
when: "ansible_os_family == 'Debian'"
|
when: "ansible_os_family == 'Debian'"
|
||||||
|
|
||||||
|
- name: Ensure git installed (Archlinux)
|
||||||
|
pacman:
|
||||||
|
name:
|
||||||
|
- git
|
||||||
|
state: present
|
||||||
|
update_cache: no
|
||||||
|
when: "ansible_distribution == 'Archlinux'"
|
||||||
|
|
||||||
- name: Clone synapse-simple-antispam git repository
|
- name: Clone synapse-simple-antispam git repository
|
||||||
git:
|
git:
|
||||||
repo: "{{ matrix_synapse_ext_spam_checker_synapse_simple_antispam_git_repository_url }}"
|
repo: "{{ matrix_synapse_ext_spam_checker_synapse_simple_antispam_git_repository_url }}"
|
||||||
|
@ -33,12 +33,7 @@
|
|||||||
- name: Wait a while, so that Matrix Synapse can manage to start
|
- name: Wait a while, so that Matrix Synapse can manage to start
|
||||||
pause:
|
pause:
|
||||||
seconds: 7
|
seconds: 7
|
||||||
when: "start_result.changed"
|
when: "start_result.changed or postgres_start_result.changed"
|
||||||
|
|
||||||
- name: Wait a while, so that Matrix Postgres can manage to start
|
|
||||||
pause:
|
|
||||||
seconds: 7
|
|
||||||
when: "postgres_start_result.changed"
|
|
||||||
|
|
||||||
- name: Generate password hash
|
- name: Generate password hash
|
||||||
shell: "/usr/bin/docker exec matrix-synapse /usr/local/bin/hash_password -c /data/homeserver.yaml -p {{ password }}"
|
shell: "/usr/bin/docker exec matrix-synapse /usr/local/bin/hash_password -c /data/homeserver.yaml -p {{ password }}"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user