mirror of
https://github.com/spantaleev/matrix-docker-ansible-deploy.git
synced 2026-03-26 06:27:23 +00:00
Add conditional restart support to 7 roles that previously always restarted
Replace hardcoded restart_necessary: true with computed values for: conduit, continuwuity, dendrite, element-call, media-repo, appservice-kakaotalk, and wechat. Each role now registers results from config, support files, systemd service, and docker image pull tasks, then computes a restart_necessary variable from their combined .changed state. group_vars/matrix_servers is updated to reference these variables instead of hardcoding true. For dendrite, the systemd service template was also separated out of the combined support-files with_items loop so it can be independently tracked. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -383,14 +383,14 @@ devture_systemd_service_manager_services_list_auto: |
|
|||||||
([{
|
([{
|
||||||
'name': 'matrix-appservice-kakaotalk.service',
|
'name': 'matrix-appservice-kakaotalk.service',
|
||||||
'priority': 2000,
|
'priority': 2000,
|
||||||
'restart_necessary': true,
|
'restart_necessary': (matrix_appservice_kakaotalk_restart_necessary | bool),
|
||||||
'groups': ['matrix', 'bridges', 'appservice-kakaotalk'],
|
'groups': ['matrix', 'bridges', 'appservice-kakaotalk'],
|
||||||
}] if matrix_appservice_kakaotalk_enabled else [])
|
}] if matrix_appservice_kakaotalk_enabled else [])
|
||||||
+
|
+
|
||||||
([{
|
([{
|
||||||
'name': 'matrix-appservice-kakaotalk-node.service',
|
'name': 'matrix-appservice-kakaotalk-node.service',
|
||||||
'priority': 1900,
|
'priority': 1900,
|
||||||
'restart_necessary': true,
|
'restart_necessary': (matrix_appservice_kakaotalk_restart_necessary | bool),
|
||||||
'groups': ['matrix', 'bridges', 'appservice-kakaotalk', 'appservice-kakaotalk-node'],
|
'groups': ['matrix', 'bridges', 'appservice-kakaotalk', 'appservice-kakaotalk-node'],
|
||||||
}] if matrix_appservice_kakaotalk_enabled else [])
|
}] if matrix_appservice_kakaotalk_enabled else [])
|
||||||
+
|
+
|
||||||
@@ -404,14 +404,14 @@ devture_systemd_service_manager_services_list_auto: |
|
|||||||
([{
|
([{
|
||||||
'name': 'matrix-wechat.service',
|
'name': 'matrix-wechat.service',
|
||||||
'priority': 2000,
|
'priority': 2000,
|
||||||
'restart_necessary': true,
|
'restart_necessary': (matrix_wechat_restart_necessary | bool),
|
||||||
'groups': ['matrix', 'bridges', 'wechat'],
|
'groups': ['matrix', 'bridges', 'wechat'],
|
||||||
}] if matrix_wechat_enabled else [])
|
}] if matrix_wechat_enabled else [])
|
||||||
+
|
+
|
||||||
([{
|
([{
|
||||||
'name': 'matrix-wechat-agent.service',
|
'name': 'matrix-wechat-agent.service',
|
||||||
'priority': 2000,
|
'priority': 2000,
|
||||||
'restart_necessary': true,
|
'restart_necessary': (matrix_wechat_restart_necessary | bool),
|
||||||
'groups': ['matrix', 'bridges', 'wechat'],
|
'groups': ['matrix', 'bridges', 'wechat'],
|
||||||
}] if matrix_wechat_enabled else [])
|
}] if matrix_wechat_enabled else [])
|
||||||
+
|
+
|
||||||
@@ -621,7 +621,12 @@ devture_systemd_service_manager_services_list_auto: |
|
|||||||
([{
|
([{
|
||||||
'name': ('matrix-' + matrix_homeserver_implementation + '.service'),
|
'name': ('matrix-' + matrix_homeserver_implementation + '.service'),
|
||||||
'priority': matrix_homeserver_systemd_service_manager_priority,
|
'priority': matrix_homeserver_systemd_service_manager_priority,
|
||||||
'restart_necessary': true,
|
'restart_necessary': (
|
||||||
|
(matrix_conduit_restart_necessary | bool) if matrix_homeserver_implementation == 'conduit'
|
||||||
|
else (matrix_continuwuity_restart_necessary | bool) if matrix_homeserver_implementation == 'continuwuity'
|
||||||
|
else (matrix_dendrite_restart_necessary | bool) if matrix_homeserver_implementation == 'dendrite'
|
||||||
|
else true
|
||||||
|
),
|
||||||
'groups': ['matrix', 'homeservers', matrix_homeserver_implementation],
|
'groups': ['matrix', 'homeservers', matrix_homeserver_implementation],
|
||||||
}] if matrix_homeserver_enabled else [])
|
}] if matrix_homeserver_enabled else [])
|
||||||
+
|
+
|
||||||
@@ -719,7 +724,7 @@ devture_systemd_service_manager_services_list_auto: |
|
|||||||
([{
|
([{
|
||||||
'name': (matrix_media_repo_identifier + '.service'),
|
'name': (matrix_media_repo_identifier + '.service'),
|
||||||
'priority': 4000,
|
'priority': 4000,
|
||||||
'restart_necessary': true,
|
'restart_necessary': (matrix_media_repo_restart_necessary | bool),
|
||||||
'groups': ['matrix', 'matrix-media-repo'],
|
'groups': ['matrix', 'matrix-media-repo'],
|
||||||
}] if matrix_media_repo_enabled else [])
|
}] if matrix_media_repo_enabled else [])
|
||||||
+
|
+
|
||||||
@@ -803,7 +808,7 @@ devture_systemd_service_manager_services_list_auto: |
|
|||||||
([{
|
([{
|
||||||
'name': 'matrix-element-call.service',
|
'name': 'matrix-element-call.service',
|
||||||
'priority': 4000,
|
'priority': 4000,
|
||||||
'restart_necessary': true,
|
'restart_necessary': (matrix_element_call_restart_necessary | bool),
|
||||||
'groups': ['matrix', 'element-call'],
|
'groups': ['matrix', 'element-call'],
|
||||||
}] if matrix_element_call_enabled else [])
|
}] if matrix_element_call_enabled else [])
|
||||||
+
|
+
|
||||||
|
|||||||
@@ -225,3 +225,13 @@ matrix_appservice_kakaotalk_registration_yaml: |
|
|||||||
rate_limited: false
|
rate_limited: false
|
||||||
|
|
||||||
matrix_appservice_kakaotalk_registration: "{{ matrix_appservice_kakaotalk_registration_yaml | from_yaml }}"
|
matrix_appservice_kakaotalk_registration: "{{ matrix_appservice_kakaotalk_registration_yaml | from_yaml }}"
|
||||||
|
|
||||||
|
# matrix_appservice_kakaotalk_restart_necessary controls whether the service
|
||||||
|
# will be restarted (when true) or merely started (when false) by the
|
||||||
|
# systemd service manager role (when conditional restart is enabled).
|
||||||
|
#
|
||||||
|
# This value is automatically computed during installation based on whether
|
||||||
|
# any configuration files, the systemd service file, or the container image changed.
|
||||||
|
# The default of `false` means "no restart needed" — appropriate when the role's
|
||||||
|
# installation tasks haven't run (e.g., due to --tags skipping them).
|
||||||
|
matrix_appservice_kakaotalk_restart_necessary: false
|
||||||
|
|||||||
@@ -13,10 +13,10 @@
|
|||||||
force_source: "{{ matrix_appservice_kakaotalk_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_appservice_kakaotalk_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_appservice_kakaotalk_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_appservice_kakaotalk_container_image_force_pull }}"
|
||||||
when: not matrix_appservice_kakaotalk_container_image_self_build
|
when: not matrix_appservice_kakaotalk_container_image_self_build
|
||||||
register: result
|
register: matrix_appservice_kakaotalk_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_appservice_kakaotalk_container_image_pull_result is not failed
|
||||||
|
|
||||||
- name: Ensure matrix-appservice-kakaotalk-node image is pulled
|
- name: Ensure matrix-appservice-kakaotalk-node image is pulled
|
||||||
community.docker.docker_image:
|
community.docker.docker_image:
|
||||||
@@ -25,10 +25,10 @@
|
|||||||
force_source: "{{ matrix_appservice_kakaotalk_node_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_appservice_kakaotalk_node_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_appservice_kakaotalk_node_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_appservice_kakaotalk_node_container_image_force_pull }}"
|
||||||
when: not matrix_appservice_kakaotalk_container_image_self_build
|
when: not matrix_appservice_kakaotalk_container_image_self_build
|
||||||
register: result
|
register: matrix_appservice_kakaotalk_node_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_appservice_kakaotalk_node_container_image_pull_result is not failed
|
||||||
|
|
||||||
- name: Ensure matrix-appservice-kakaotalk paths exist
|
- name: Ensure matrix-appservice-kakaotalk paths exist
|
||||||
ansible.builtin.file:
|
ansible.builtin.file:
|
||||||
@@ -86,6 +86,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_appservice_kakaotalk_node_config_result
|
||||||
|
|
||||||
- name: Ensure matrix-appservice-kakaotalk config.yaml installed
|
- name: Ensure matrix-appservice-kakaotalk config.yaml installed
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
@@ -94,6 +95,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_appservice_kakaotalk_config_result
|
||||||
|
|
||||||
- name: Ensure matrix-appservice-kakaotalk registration.yaml installed
|
- name: Ensure matrix-appservice-kakaotalk registration.yaml installed
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
@@ -102,6 +104,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_appservice_kakaotalk_registration_result
|
||||||
|
|
||||||
- name: Ensure matrix-appservice-kakaotalk container network is created
|
- name: Ensure matrix-appservice-kakaotalk container network is created
|
||||||
community.general.docker_network:
|
community.general.docker_network:
|
||||||
@@ -122,3 +125,17 @@
|
|||||||
src: "{{ role_path }}/templates/systemd/matrix-appservice-kakaotalk.service.j2"
|
src: "{{ role_path }}/templates/systemd/matrix-appservice-kakaotalk.service.j2"
|
||||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-appservice-kakaotalk.service"
|
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-appservice-kakaotalk.service"
|
||||||
mode: '0644'
|
mode: '0644'
|
||||||
|
register: matrix_appservice_kakaotalk_systemd_service_result
|
||||||
|
|
||||||
|
- name: Determine whether matrix-appservice-kakaotalk needs a restart
|
||||||
|
ansible.builtin.set_fact:
|
||||||
|
matrix_appservice_kakaotalk_restart_necessary: >-
|
||||||
|
{{
|
||||||
|
matrix_appservice_kakaotalk_node_config_result.changed | default(false)
|
||||||
|
or matrix_appservice_kakaotalk_config_result.changed | default(false)
|
||||||
|
or matrix_appservice_kakaotalk_registration_result.changed | default(false)
|
||||||
|
or matrix_appservice_kakaotalk_node_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_appservice_kakaotalk_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_appservice_kakaotalk_container_image_pull_result.changed | default(false)
|
||||||
|
or matrix_appservice_kakaotalk_node_container_image_pull_result.changed | default(false)
|
||||||
|
}}
|
||||||
|
|||||||
@@ -163,3 +163,13 @@ matrix_wechat_agent_service_secret: "{{ matrix_wechat_bridge_listen_secret }}"
|
|||||||
matrix_wechat_agent_configuration_yaml: "{{ lookup('template', 'templates/agent-config.yaml.j2') }}"
|
matrix_wechat_agent_configuration_yaml: "{{ lookup('template', 'templates/agent-config.yaml.j2') }}"
|
||||||
|
|
||||||
matrix_wechat_agent_configuration: "{{ matrix_wechat_agent_configuration_yaml | from_yaml }}"
|
matrix_wechat_agent_configuration: "{{ matrix_wechat_agent_configuration_yaml | from_yaml }}"
|
||||||
|
|
||||||
|
# matrix_wechat_restart_necessary controls whether the service
|
||||||
|
# will be restarted (when true) or merely started (when false) by the
|
||||||
|
# systemd service manager role (when conditional restart is enabled).
|
||||||
|
#
|
||||||
|
# This value is automatically computed during installation based on whether
|
||||||
|
# any configuration files, the systemd service file, or the container image changed.
|
||||||
|
# The default of `false` means "no restart needed" — appropriate when the role's
|
||||||
|
# installation tasks haven't run (e.g., due to --tags skipping them).
|
||||||
|
matrix_wechat_restart_necessary: false
|
||||||
|
|||||||
@@ -27,10 +27,10 @@
|
|||||||
force_source: "{{ matrix_wechat_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_wechat_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_wechat_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_wechat_container_image_force_pull }}"
|
||||||
when: not matrix_wechat_container_image_self_build
|
when: not matrix_wechat_container_image_self_build
|
||||||
register: result
|
register: matrix_wechat_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_wechat_container_image_pull_result is not failed
|
||||||
|
|
||||||
- when: matrix_wechat_container_image_self_build | bool
|
- when: matrix_wechat_container_image_self_build | bool
|
||||||
block:
|
block:
|
||||||
@@ -62,10 +62,10 @@
|
|||||||
force_source: "{{ matrix_wechat_agent_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_wechat_agent_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_wechat_agent_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_wechat_agent_container_image_force_pull }}"
|
||||||
when: not matrix_wechat_agent_container_image_self_build
|
when: not matrix_wechat_agent_container_image_self_build
|
||||||
register: result
|
register: matrix_wechat_agent_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_wechat_agent_container_image_pull_result is not failed
|
||||||
|
|
||||||
- when: matrix_wechat_agent_container_image_self_build | bool
|
- when: matrix_wechat_agent_container_image_self_build | bool
|
||||||
block:
|
block:
|
||||||
@@ -97,6 +97,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_wechat_config_result
|
||||||
|
|
||||||
- name: Ensure WeChat registration.yaml installed
|
- name: Ensure WeChat registration.yaml installed
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
@@ -105,6 +106,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_wechat_registration_result
|
||||||
|
|
||||||
- name: Ensure Wechat Agent configuration installed
|
- name: Ensure Wechat Agent configuration installed
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
@@ -113,6 +115,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_wechat_agent_config_result
|
||||||
|
|
||||||
- name: Ensure matrix-wechat container network is created
|
- name: Ensure matrix-wechat container network is created
|
||||||
community.general.docker_network:
|
community.general.docker_network:
|
||||||
@@ -134,3 +137,16 @@
|
|||||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-wechat-agent.service"
|
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-wechat-agent.service"
|
||||||
mode: '0644'
|
mode: '0644'
|
||||||
register: matrix_wechat_agent_systemd_service_result
|
register: matrix_wechat_agent_systemd_service_result
|
||||||
|
|
||||||
|
- name: Determine whether WeChat Bridge needs a restart
|
||||||
|
ansible.builtin.set_fact:
|
||||||
|
matrix_wechat_restart_necessary: >-
|
||||||
|
{{
|
||||||
|
matrix_wechat_config_result.changed | default(false)
|
||||||
|
or matrix_wechat_registration_result.changed | default(false)
|
||||||
|
or matrix_wechat_agent_config_result.changed | default(false)
|
||||||
|
or matrix_wechat_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_wechat_agent_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_wechat_container_image_pull_result.changed | default(false)
|
||||||
|
or matrix_wechat_agent_container_image_pull_result.changed | default(false)
|
||||||
|
}}
|
||||||
|
|||||||
@@ -154,3 +154,13 @@ matrix_conduit_turn_uris: []
|
|||||||
matrix_conduit_turn_secret: ''
|
matrix_conduit_turn_secret: ''
|
||||||
matrix_conduit_turn_username: ''
|
matrix_conduit_turn_username: ''
|
||||||
matrix_conduit_turn_password: ''
|
matrix_conduit_turn_password: ''
|
||||||
|
|
||||||
|
# matrix_conduit_restart_necessary controls whether the service
|
||||||
|
# will be restarted (when true) or merely started (when false) by the
|
||||||
|
# systemd service manager role (when conditional restart is enabled).
|
||||||
|
#
|
||||||
|
# This value is automatically computed during installation based on whether
|
||||||
|
# any configuration files, the systemd service file, or the container image changed.
|
||||||
|
# The default of `false` means "no restart needed" — appropriate when the role's
|
||||||
|
# installation tasks haven't run (e.g., due to --tags skipping them).
|
||||||
|
matrix_conduit_restart_necessary: false
|
||||||
|
|||||||
@@ -31,6 +31,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_conduit_config_result
|
||||||
|
|
||||||
- name: Ensure Conduit support files installed
|
- name: Ensure Conduit support files installed
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
@@ -41,6 +42,7 @@
|
|||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
with_items:
|
with_items:
|
||||||
- labels
|
- labels
|
||||||
|
register: matrix_conduit_support_files_result
|
||||||
|
|
||||||
- name: Ensure Conduit container network is created
|
- name: Ensure Conduit container network is created
|
||||||
community.general.docker_network:
|
community.general.docker_network:
|
||||||
@@ -55,13 +57,24 @@
|
|||||||
source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}"
|
source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}"
|
||||||
force_source: "{{ matrix_conduit_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_conduit_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_conduit_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_conduit_container_image_force_pull }}"
|
||||||
register: result
|
register: matrix_conduit_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_conduit_container_image_pull_result is not failed
|
||||||
|
|
||||||
- name: Ensure matrix-conduit.service installed
|
- name: Ensure matrix-conduit.service installed
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
src: "{{ role_path }}/templates/systemd/matrix-conduit.service.j2"
|
src: "{{ role_path }}/templates/systemd/matrix-conduit.service.j2"
|
||||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-conduit.service"
|
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-conduit.service"
|
||||||
mode: '0644'
|
mode: '0644'
|
||||||
|
register: matrix_conduit_systemd_service_result
|
||||||
|
|
||||||
|
- name: Determine whether Conduit needs a restart
|
||||||
|
ansible.builtin.set_fact:
|
||||||
|
matrix_conduit_restart_necessary: >-
|
||||||
|
{{
|
||||||
|
matrix_conduit_config_result.changed | default(false)
|
||||||
|
or matrix_conduit_support_files_result.changed | default(false)
|
||||||
|
or matrix_conduit_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_conduit_container_image_pull_result.changed | default(false)
|
||||||
|
}}
|
||||||
|
|||||||
@@ -208,3 +208,13 @@ matrix_continuwuity_config_url_preview_domain_contains_allowlist: []
|
|||||||
# CONTINUWUITY_MAX_REQUEST_SIZE=50000000
|
# CONTINUWUITY_MAX_REQUEST_SIZE=50000000
|
||||||
# CONTINUWUITY_REQUEST_TIMEOUT=60
|
# CONTINUWUITY_REQUEST_TIMEOUT=60
|
||||||
matrix_continuwuity_environment_variables_extension: ''
|
matrix_continuwuity_environment_variables_extension: ''
|
||||||
|
|
||||||
|
# matrix_continuwuity_restart_necessary controls whether the service
|
||||||
|
# will be restarted (when true) or merely started (when false) by the
|
||||||
|
# systemd service manager role (when conditional restart is enabled).
|
||||||
|
#
|
||||||
|
# This value is automatically computed during installation based on whether
|
||||||
|
# any configuration files, the systemd service file, or the container image changed.
|
||||||
|
# The default of `false` means "no restart needed" — appropriate when the role's
|
||||||
|
# installation tasks haven't run (e.g., due to --tags skipping them).
|
||||||
|
matrix_continuwuity_restart_necessary: false
|
||||||
|
|||||||
@@ -27,6 +27,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_continuwuity_config_result
|
||||||
|
|
||||||
- name: Ensure continuwuity support files installed
|
- name: Ensure continuwuity support files installed
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
@@ -38,6 +39,7 @@
|
|||||||
with_items:
|
with_items:
|
||||||
- labels
|
- labels
|
||||||
- env
|
- env
|
||||||
|
register: matrix_continuwuity_support_files_result
|
||||||
|
|
||||||
- name: Ensure continuwuity container network is created
|
- name: Ensure continuwuity container network is created
|
||||||
community.general.docker_network:
|
community.general.docker_network:
|
||||||
@@ -52,13 +54,24 @@
|
|||||||
source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}"
|
source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}"
|
||||||
force_source: "{{ matrix_continuwuity_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_continuwuity_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_continuwuity_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_continuwuity_container_image_force_pull }}"
|
||||||
register: result
|
register: matrix_continuwuity_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_continuwuity_container_image_pull_result is not failed
|
||||||
|
|
||||||
- name: Ensure matrix-continuwuity.service installed
|
- name: Ensure matrix-continuwuity.service installed
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
src: "{{ role_path }}/templates/systemd/matrix-continuwuity.service.j2"
|
src: "{{ role_path }}/templates/systemd/matrix-continuwuity.service.j2"
|
||||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-continuwuity.service"
|
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-continuwuity.service"
|
||||||
mode: '0644'
|
mode: '0644'
|
||||||
|
register: matrix_continuwuity_systemd_service_result
|
||||||
|
|
||||||
|
- name: Determine whether continuwuity needs a restart
|
||||||
|
ansible.builtin.set_fact:
|
||||||
|
matrix_continuwuity_restart_necessary: >-
|
||||||
|
{{
|
||||||
|
matrix_continuwuity_config_result.changed | default(false)
|
||||||
|
or matrix_continuwuity_support_files_result.changed | default(false)
|
||||||
|
or matrix_continuwuity_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_continuwuity_container_image_pull_result.changed | default(false)
|
||||||
|
}}
|
||||||
|
|||||||
@@ -361,3 +361,13 @@ matrix_dendrite_media_api_max_thumbnail_generators: 10
|
|||||||
|
|
||||||
# Controls whether the full-text search engine is enabled
|
# Controls whether the full-text search engine is enabled
|
||||||
matrix_dendrite_sync_api_search_enabled: false
|
matrix_dendrite_sync_api_search_enabled: false
|
||||||
|
|
||||||
|
# matrix_dendrite_restart_necessary controls whether the service
|
||||||
|
# will be restarted (when true) or merely started (when false) by the
|
||||||
|
# systemd service manager role (when conditional restart is enabled).
|
||||||
|
#
|
||||||
|
# This value is automatically computed during installation based on whether
|
||||||
|
# any configuration files, the systemd service file, or the container image changed.
|
||||||
|
# The default of `false` means "no restart needed" — appropriate when the role's
|
||||||
|
# installation tasks haven't run (e.g., due to --tags skipping them).
|
||||||
|
matrix_dendrite_restart_necessary: false
|
||||||
|
|||||||
@@ -55,10 +55,10 @@
|
|||||||
force_source: "{{ matrix_dendrite_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_dendrite_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_dendrite_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_dendrite_container_image_force_pull }}"
|
||||||
when: "not matrix_dendrite_container_image_self_build | bool"
|
when: "not matrix_dendrite_container_image_self_build | bool"
|
||||||
register: result
|
register: matrix_dendrite_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_dendrite_container_image_pull_result is not failed
|
||||||
|
|
||||||
# We do this so that the signing key would get generated.
|
# We do this so that the signing key would get generated.
|
||||||
# We don't use the `docker_container` module, because using it with `cap_drop` requires
|
# We don't use the `docker_container` module, because using it with `cap_drop` requires
|
||||||
@@ -89,6 +89,7 @@
|
|||||||
mode: '0644'
|
mode: '0644'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_dendrite_config_result
|
||||||
|
|
||||||
- when: "matrix_dendrite_container_image_self_build | bool"
|
- when: "matrix_dendrite_container_image_self_build | bool"
|
||||||
block:
|
block:
|
||||||
@@ -139,6 +140,21 @@
|
|||||||
- src: bin/create-account.j2
|
- src: bin/create-account.j2
|
||||||
dest: "{{ matrix_dendrite_bin_path }}/create-account"
|
dest: "{{ matrix_dendrite_bin_path }}/create-account"
|
||||||
mode: "0750"
|
mode: "0750"
|
||||||
- src: systemd/matrix-dendrite.service.j2
|
register: matrix_dendrite_support_files_result
|
||||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-dendrite.service"
|
|
||||||
mode: "0644"
|
- name: Ensure matrix-dendrite.service installed
|
||||||
|
ansible.builtin.template:
|
||||||
|
src: "{{ role_path }}/templates/systemd/matrix-dendrite.service.j2"
|
||||||
|
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-dendrite.service"
|
||||||
|
mode: '0644'
|
||||||
|
register: matrix_dendrite_systemd_service_result
|
||||||
|
|
||||||
|
- name: Determine whether Dendrite needs a restart
|
||||||
|
ansible.builtin.set_fact:
|
||||||
|
matrix_dendrite_restart_necessary: >-
|
||||||
|
{{
|
||||||
|
matrix_dendrite_config_result.changed | default(false)
|
||||||
|
or matrix_dendrite_support_files_result.changed | default(false)
|
||||||
|
or matrix_dendrite_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_dendrite_container_image_pull_result.changed | default(false)
|
||||||
|
}}
|
||||||
|
|||||||
@@ -153,3 +153,13 @@ matrix_element_call_config_default_server_config_m_homeserver_server_name: "{{ m
|
|||||||
|
|
||||||
# Controls the livekit/livekit_service_url property in the config.json file.
|
# Controls the livekit/livekit_service_url property in the config.json file.
|
||||||
matrix_element_call_config_livekit_livekit_service_url: ""
|
matrix_element_call_config_livekit_livekit_service_url: ""
|
||||||
|
|
||||||
|
# matrix_element_call_restart_necessary controls whether the service
|
||||||
|
# will be restarted (when true) or merely started (when false) by the
|
||||||
|
# systemd service manager role (when conditional restart is enabled).
|
||||||
|
#
|
||||||
|
# This value is automatically computed during installation based on whether
|
||||||
|
# any configuration files, the systemd service file, or the container image changed.
|
||||||
|
# The default of `false` means "no restart needed" — appropriate when the role's
|
||||||
|
# installation tasks haven't run (e.g., due to --tags skipping them).
|
||||||
|
matrix_element_call_restart_necessary: false
|
||||||
|
|||||||
@@ -23,6 +23,7 @@
|
|||||||
mode: '0640'
|
mode: '0640'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_element_call_config_result
|
||||||
|
|
||||||
- name: Ensure Element Call container labels file is in place
|
- name: Ensure Element Call container labels file is in place
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
@@ -31,16 +32,17 @@
|
|||||||
mode: '0640'
|
mode: '0640'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_element_call_support_files_result
|
||||||
|
|
||||||
- name: Ensure Element Call container image is pulled
|
- name: Ensure Element Call container image is pulled
|
||||||
community.docker.docker_image:
|
community.docker.docker_image:
|
||||||
name: "{{ matrix_element_call_container_image }}"
|
name: "{{ matrix_element_call_container_image }}"
|
||||||
source: pull
|
source: pull
|
||||||
force_source: "{{ matrix_element_call_container_image_force_pull }}"
|
force_source: "{{ matrix_element_call_container_image_force_pull }}"
|
||||||
register: element_call_image_result
|
register: matrix_element_call_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: element_call_image_result is not failed
|
until: matrix_element_call_container_image_pull_result is not failed
|
||||||
|
|
||||||
- name: Ensure Element Call container network is created
|
- name: Ensure Element Call container network is created
|
||||||
community.general.docker_network:
|
community.general.docker_network:
|
||||||
@@ -54,3 +56,14 @@
|
|||||||
src: "{{ role_path }}/templates/systemd/matrix-element-call.service.j2"
|
src: "{{ role_path }}/templates/systemd/matrix-element-call.service.j2"
|
||||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-element-call.service"
|
dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-element-call.service"
|
||||||
mode: '0644'
|
mode: '0644'
|
||||||
|
register: matrix_element_call_systemd_service_result
|
||||||
|
|
||||||
|
- name: Determine whether Element Call needs a restart
|
||||||
|
ansible.builtin.set_fact:
|
||||||
|
matrix_element_call_restart_necessary: >-
|
||||||
|
{{
|
||||||
|
matrix_element_call_config_result.changed | default(false)
|
||||||
|
or matrix_element_call_support_files_result.changed | default(false)
|
||||||
|
or matrix_element_call_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_element_call_container_image_pull_result.changed | default(false)
|
||||||
|
}}
|
||||||
|
|||||||
@@ -939,3 +939,13 @@ matrix_media_repo_pgo_submit_key: "INSERT_VALUE_HERE"
|
|||||||
|
|
||||||
# Specifies whether the homeserver supports federation
|
# Specifies whether the homeserver supports federation
|
||||||
matrix_media_repo_homeserver_federation_enabled: true
|
matrix_media_repo_homeserver_federation_enabled: true
|
||||||
|
|
||||||
|
# matrix_media_repo_restart_necessary controls whether the service
|
||||||
|
# will be restarted (when true) or merely started (when false) by the
|
||||||
|
# systemd service manager role (when conditional restart is enabled).
|
||||||
|
#
|
||||||
|
# This value is automatically computed during installation based on whether
|
||||||
|
# any configuration files, the systemd service file, or the container image changed.
|
||||||
|
# The default of `false` means "no restart needed" — appropriate when the role's
|
||||||
|
# installation tasks haven't run (e.g., due to --tags skipping them).
|
||||||
|
matrix_media_repo_restart_necessary: false
|
||||||
|
|||||||
@@ -35,6 +35,7 @@
|
|||||||
with_items:
|
with_items:
|
||||||
- env
|
- env
|
||||||
- labels
|
- labels
|
||||||
|
register: matrix_media_repo_support_files_result
|
||||||
|
|
||||||
- name: Ensure media-repo configuration installed
|
- name: Ensure media-repo configuration installed
|
||||||
ansible.builtin.template:
|
ansible.builtin.template:
|
||||||
@@ -43,6 +44,7 @@
|
|||||||
mode: '0640'
|
mode: '0640'
|
||||||
owner: "{{ matrix_user_name }}"
|
owner: "{{ matrix_user_name }}"
|
||||||
group: "{{ matrix_group_name }}"
|
group: "{{ matrix_group_name }}"
|
||||||
|
register: matrix_media_repo_config_result
|
||||||
|
|
||||||
- name: Ensure media-repo Docker image is pulled
|
- name: Ensure media-repo Docker image is pulled
|
||||||
community.docker.docker_image:
|
community.docker.docker_image:
|
||||||
@@ -51,10 +53,10 @@
|
|||||||
force_source: "{{ matrix_media_repo_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
force_source: "{{ matrix_media_repo_container_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
|
||||||
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_media_repo_container_image_force_pull }}"
|
force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_media_repo_container_image_force_pull }}"
|
||||||
when: "not matrix_media_repo_container_image_self_build | bool"
|
when: "not matrix_media_repo_container_image_self_build | bool"
|
||||||
register: result
|
register: matrix_media_repo_container_image_pull_result
|
||||||
retries: "{{ devture_playbook_help_container_retries_count }}"
|
retries: "{{ devture_playbook_help_container_retries_count }}"
|
||||||
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
delay: "{{ devture_playbook_help_container_retries_delay }}"
|
||||||
until: result is not failed
|
until: matrix_media_repo_container_image_pull_result is not failed
|
||||||
|
|
||||||
- when: "matrix_media_repo_container_image_self_build | bool"
|
- when: "matrix_media_repo_container_image_self_build | bool"
|
||||||
block:
|
block:
|
||||||
@@ -153,3 +155,14 @@
|
|||||||
src: "{{ role_path }}/templates/media-repo/systemd/matrix-media-repo.service.j2"
|
src: "{{ role_path }}/templates/media-repo/systemd/matrix-media-repo.service.j2"
|
||||||
dest: "{{ devture_systemd_docker_base_systemd_path }}/{{ matrix_media_repo_identifier }}.service"
|
dest: "{{ devture_systemd_docker_base_systemd_path }}/{{ matrix_media_repo_identifier }}.service"
|
||||||
mode: '0640'
|
mode: '0640'
|
||||||
|
register: matrix_media_repo_systemd_service_result
|
||||||
|
|
||||||
|
- name: Determine whether media-repo needs a restart
|
||||||
|
ansible.builtin.set_fact:
|
||||||
|
matrix_media_repo_restart_necessary: >-
|
||||||
|
{{
|
||||||
|
matrix_media_repo_config_result.changed | default(false)
|
||||||
|
or matrix_media_repo_support_files_result.changed | default(false)
|
||||||
|
or matrix_media_repo_systemd_service_result.changed | default(false)
|
||||||
|
or matrix_media_repo_container_image_pull_result.changed | default(false)
|
||||||
|
}}
|
||||||
|
|||||||
Reference in New Issue
Block a user