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>pull/5063/head
| @@ -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 | |||||
| dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-dendrite.service" | |||||
| mode: "0644" | |||||
| register: matrix_dendrite_support_files_result | |||||
| - 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) | |||||
| }} | |||||