Add support for using an external PostgreSQL server
This commit is contained in:
		@@ -72,7 +72,7 @@
 | 
			
		||||
      - "{{ matrix_scratchpad_dir }}:/scratchpad"
 | 
			
		||||
      - "{{ matrix_scratchpad_dir }}/synapse_port_db_with_patch:/usr/local/bin/synapse_port_db_with_patch"
 | 
			
		||||
    links:
 | 
			
		||||
      - "matrix-postgres:postgres"
 | 
			
		||||
      - "matrix-postgres:{{ matrix_postgres_connection_hostname }}"
 | 
			
		||||
 | 
			
		||||
- name: Ensure scratchpad directory is deleted
 | 
			
		||||
  file:
 | 
			
		||||
 
 | 
			
		||||
@@ -1,13 +1,10 @@
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
- name: Ensure postgres data path exists
 | 
			
		||||
  file:
 | 
			
		||||
    path: "{{ matrix_postgres_data_path }}"
 | 
			
		||||
    state: directory
 | 
			
		||||
    mode: 0700
 | 
			
		||||
    owner: "{{ matrix_user_username }}"
 | 
			
		||||
    group: "{{ matrix_user_username }}"
 | 
			
		||||
#
 | 
			
		||||
# Generic tasks, no matter what kind of server we're using (internal/external)
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
# Even if we don't run the internal server, we still need this for running the CLI
 | 
			
		||||
- name: Ensure postgres Docker image is pulled
 | 
			
		||||
  docker_image:
 | 
			
		||||
    name: "{{ docker_postgres_image }}"
 | 
			
		||||
@@ -27,8 +24,52 @@
 | 
			
		||||
    dest: "/usr/local/bin/matrix-postgres-cli"
 | 
			
		||||
    mode: 0750
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
# Tasks related to setting up an internal postgres server
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
- name: Ensure postgres data path exists
 | 
			
		||||
  file:
 | 
			
		||||
    path: "{{ matrix_postgres_data_path }}"
 | 
			
		||||
    state: directory
 | 
			
		||||
    mode: 0700
 | 
			
		||||
    owner: "{{ matrix_user_username }}"
 | 
			
		||||
    group: "{{ matrix_user_username }}"
 | 
			
		||||
  when: "not matrix_postgres_use_external"
 | 
			
		||||
 | 
			
		||||
- name: Ensure matrix-postgres.service installed
 | 
			
		||||
  template:
 | 
			
		||||
    src: "{{ role_path }}/templates/systemd/matrix-postgres.service.j2"
 | 
			
		||||
    dest: "/etc/systemd/system/matrix-postgres.service"
 | 
			
		||||
    mode: 0644
 | 
			
		||||
    mode: 0644
 | 
			
		||||
  when: "not matrix_postgres_use_external"
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
# Tasks related to getting rid of the internal postgres server (if it was previously enabled)
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
- name: Check existance of matrix-postgres service
 | 
			
		||||
  stat: path="/etc/systemd/system/matrix-postgres.service"
 | 
			
		||||
  register: matrix_postgres_service_stat
 | 
			
		||||
  when: matrix_postgres_use_external
 | 
			
		||||
 | 
			
		||||
- name: Ensure matrix-postgres is stopped
 | 
			
		||||
  service: name=matrix-postgres state=stopped daemon_reload=yes
 | 
			
		||||
  when: "matrix_postgres_use_external and matrix_postgres_service_stat.stat.exists"
 | 
			
		||||
 | 
			
		||||
- name: Ensure matrix-postgres.service doesn't exist
 | 
			
		||||
  file:
 | 
			
		||||
    path: "/etc/systemd/system/matrix-postgres.service"
 | 
			
		||||
    state: absent
 | 
			
		||||
  when: "matrix_postgres_use_external and matrix_postgres_service_stat.stat.exists"
 | 
			
		||||
 | 
			
		||||
- name: Check existance of matrix-postgres local data path
 | 
			
		||||
  stat: path="{{ matrix_postgres_data_path }}"
 | 
			
		||||
  register: matrix_postgres_data_path_stat
 | 
			
		||||
  when: matrix_postgres_use_external
 | 
			
		||||
 | 
			
		||||
# We just want to notify the user. Deleting data is too destructive.
 | 
			
		||||
- name: Notify if matrix-postgres local data remains
 | 
			
		||||
  debug:
 | 
			
		||||
    msg: "Note: You are not using a local PostgreSQL database, but some old data remains from before in {{ matrix_postgres_data_path }}. Feel free to delete that."
 | 
			
		||||
  when: "matrix_postgres_use_external and matrix_postgres_data_path_stat.stat.exists"
 | 
			
		||||
@@ -109,12 +109,11 @@
 | 
			
		||||
    line: '\1name: "psycopg2"'
 | 
			
		||||
    backrefs: yes
 | 
			
		||||
 | 
			
		||||
- name: Augment Matrix config (add the Postgres connection parameters)
 | 
			
		||||
  lineinfile:
 | 
			
		||||
- name: Augment Matrix config (set the Postgres connection parameters)
 | 
			
		||||
  replace:
 | 
			
		||||
    dest: "{{ matrix_synapse_config_dir_path }}/homeserver.yaml"
 | 
			
		||||
    regexp: '(.*)database: "(.*)homeserver.db"'
 | 
			
		||||
    line: '\1user: "{{ matrix_postgres_connection_username }}"\n\1password: "{{ matrix_postgres_connection_password }}"\n\1database: "homeserver"\n\1host: "postgres"\n\1cp_min: 5\n\1cp_max: 10'
 | 
			
		||||
    backrefs: yes
 | 
			
		||||
    regexp: '(.*)name: "psycopg2"((?:.|\n)*?)\n\n'
 | 
			
		||||
    replace: '\1name: "psycopg2"\n\1args:\n\1\1user: "{{ matrix_postgres_connection_username }}"\n\1\1password: "{{ matrix_postgres_connection_password }}"\n\1\1database: "{{ matrix_postgres_db_name }}"\n\1\1host: "{{ matrix_postgres_connection_hostname }}"\n\1\1cp_min: 5\n\1\1cp_max: 10\n\n'
 | 
			
		||||
 | 
			
		||||
- name: Augment Matrix config (configure Coturn)
 | 
			
		||||
  lineinfile: "dest={{ matrix_synapse_config_dir_path }}/turnserver.conf"
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user