2024-12-07 17:34:44 +01:00
# SPDX-FileCopyrightText: 2024 MDAD Team and contributors
#
# SPDX-License-Identifier: AGPL-3.0-or-later
2022-02-05 21:32:54 +01:00
---
2020-12-22 18:56:52 +01:00
- name : Fail if Postgres not enabled
2022-07-18 09:39:08 +02:00
ansible.builtin.fail :
2024-10-07 07:46:05 +02:00
msg : "Postgres via ansible-role-postgres role is not enabled (`postgres_enabled`). Cannot migrate."
2024-09-27 08:37:24 +02:00
when : "not postgres_enabled | bool"
2020-12-22 18:56:52 +01:00
# Defaults
- name : Set postgres_start_wait_time, if not provided
2022-07-18 09:39:08 +02:00
ansible.builtin.set_fact :
2020-12-22 18:56:52 +01:00
postgres_start_wait_time : 15
2022-07-18 10:22:05 +02:00
when : "postgres_start_wait_time | default('') == ''"
2020-12-22 18:56:52 +01:00
# Actual import work
2022-11-27 06:23:41 +01:00
- name : Ensure Postgres is started
2022-07-18 09:39:08 +02:00
ansible.builtin.service :
2024-09-27 08:37:24 +02:00
name : "{{ postgres_identifier }}"
2020-12-22 18:56:52 +01:00
state : started
2022-02-05 21:32:54 +01:00
daemon_reload : true
2022-11-27 06:23:41 +01:00
register : postgres_service_start_result
2020-12-22 18:56:52 +01:00
- name : Wait a bit, so that Postgres can start
2022-07-18 10:22:05 +02:00
ansible.builtin.wait_for :
2020-12-22 18:56:52 +01:00
timeout : "{{ postgres_start_wait_time }}"
delegate_to : 127.0 .0 .1
become : false
2022-11-27 06:23:41 +01:00
when : "postgres_service_start_result.changed | bool"
2020-12-22 18:56:52 +01:00
- name : Ensure matrix-appservice-slack is stopped
2022-07-18 09:39:08 +02:00
ansible.builtin.service :
2020-12-22 18:56:52 +01:00
name : matrix-appservice-slack
state : stopped
- name : Import appservice-slack NeDB database into Postgres
2022-07-18 09:39:08 +02:00
ansible.builtin.command :
2020-12-22 18:56:52 +01:00
cmd : >-
2022-11-04 15:39:35 +01:00
{{ devture_systemd_docker_base_host_command_docker }} run
2020-12-22 18:56:52 +01:00
--rm
--user={{ matrix_user_uid }}:{{ matrix_user_gid }}
--cap-drop=ALL
2024-01-13 16:11:57 +01:00
{% if matrix_appservice_slack_database_container_network %}
--network={{ matrix_appservice_irc_database_container_network }}
{% endif %}
2020-12-22 18:56:52 +01:00
--mount type=bind,src={{ matrix_appservice_slack_data_path }},dst=/data
--entrypoint=/bin/sh
{{ matrix_appservice_slack_docker_image }}
-c
'/usr/local/bin/node /usr/src/app/lib/scripts/migrateToPostgres.js --dbdir /data --connectionString {{ matrix_appservice_slack_database_connection_string }}'
2022-07-18 14:08:10 +02:00
register : matrix_appservice_slack_import_nedb_to_postgres_result
changed_when : matrix_appservice_slack_import_nedb_to_postgres_result.rc == 0
2020-12-22 18:56:52 +01:00
- name : Archive NeDB database files
2022-07-18 09:39:08 +02:00
ansible.builtin.command :
2020-12-22 18:56:52 +01:00
cmd : "mv {{ matrix_appservice_slack_data_path }}/{{ item }} {{ matrix_appservice_slack_data_path }}/{{ item }}.backup"
2022-07-18 14:08:10 +02:00
register : matrix_appservice_slack_import_nedb_to_postgres_move_result
changed_when : matrix_appservice_slack_import_nedb_to_postgres_move_result.rc == 0
2020-12-22 18:56:52 +01:00
with_items :
- teams.db
- room-store.db
- user-store.db
- event-store.db
- name : Inject result
2022-07-18 09:39:08 +02:00
ansible.builtin.set_fact :
2022-11-04 15:19:17 +01:00
devture_playbook_runtime_messages_list : |
2020-12-22 18:56:52 +01:00
{{
2022-11-04 15:19:17 +01:00
devture_playbook_runtime_messages_list | default([])
2020-12-22 18:56:52 +01:00
+
[
2024-10-14 19:47:38 +02:00
"Note: Your appservice-slack database files have been imported into Postgres. The original database files have been moved from `{{ matrix_appservice_slack_data_path }}/*.db` to `{{ matrix_appservice_slack_data_path }}/*.db.backup`. When you've confirmed that the import went well and everything works, you should be able to safely delete these files."
2020-12-22 18:56:52 +01:00
]
}}