5eed874199
Fixes https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/716 This patch makes us use more fully-qualified container image names (either prefixed with docker.io/ or with localhost/). The latter happens when self-building is enabled. We've recently had issues where if an image was removed manually and the service was restarted (making `docker run` fetch it from Docker Hub, etc.), we'd end up with a pulled image, even though we're aiming for a self-built one. Re-running the playbook would then not do a rebuild, because: - the image with that name already exists (even though it's something else) - we sometimes had conditional logic where we'd build only if the git repo changed By explicitly changing the name of the images (prefixing with localhost/), we avoid such confusion and the possibility that we'd automatically pul something which is not what we expect. Also, I've removed that condition where building would happen on git changes only. We now always build (unless an image with that name already exists). We just force-build when the git repo changes.
80 lines
3.1 KiB
YAML
80 lines
3.1 KiB
YAML
---
|
|
|
|
#
|
|
# Tasks related to setting up matrix-synapse-admin
|
|
#
|
|
|
|
- name: Ensure matrix-synapse-admin image is pulled
|
|
docker_image:
|
|
name: "{{ matrix_synapse_admin_docker_image }}"
|
|
source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}"
|
|
force_source: "{{ matrix_synapse_admin_docker_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_synapse_admin_docker_image_force_pull }}"
|
|
when: "matrix_synapse_admin_enabled|bool and not matrix_synapse_admin_container_self_build|bool"
|
|
|
|
- name: Ensure matrix-synapse-admin repository is present when self-building
|
|
git:
|
|
repo: "{{ matrix_synapse_admin_docker_repo }}"
|
|
dest: "{{ matrix_synapse_admin_docker_src_files_path }}"
|
|
force: "yes"
|
|
register: matrix_synapse_admin_git_pull_results
|
|
when: "matrix_synapse_admin_enabled|bool and matrix_synapse_admin_container_self_build|bool"
|
|
|
|
- name: Ensure matrix-synapse-admin Docker image is built
|
|
docker_image:
|
|
name: "{{ matrix_synapse_admin_docker_image }}"
|
|
source: build
|
|
force_source: "{{ matrix_synapse_admin_git_pull_results }}"
|
|
build:
|
|
dockerfile: Dockerfile
|
|
path: "{{ matrix_synapse_admin_docker_src_files_path }}"
|
|
pull: yes
|
|
when: "matrix_synapse_admin_enabled|bool and matrix_synapse_admin_container_self_build|bool"
|
|
|
|
- name: Ensure matrix-synapse-admin.service installed
|
|
template:
|
|
src: "{{ role_path }}/templates/systemd/matrix-synapse-admin.service.j2"
|
|
dest: "{{ matrix_systemd_path }}/matrix-synapse-admin.service"
|
|
mode: 0644
|
|
register: matrix_synapse_admin_systemd_service_result
|
|
when: matrix_synapse_admin_enabled|bool
|
|
|
|
- name: Ensure systemd reloaded after matrix-synapse-admin.service installation
|
|
service:
|
|
daemon_reload: yes
|
|
when: "matrix_synapse_admin_enabled|bool and matrix_synapse_admin_systemd_service_result.changed"
|
|
|
|
#
|
|
# Tasks related to getting rid of matrix-synapse-admin (if it was previously enabled)
|
|
#
|
|
|
|
- name: Check existence of matrix-synapse-admin service
|
|
stat:
|
|
path: "{{ matrix_systemd_path }}/matrix-synapse-admin.service"
|
|
register: matrix_synapse_admin_service_stat
|
|
|
|
- name: Ensure matrix-synapse-admin is stopped
|
|
service:
|
|
name: matrix-synapse-admin
|
|
state: stopped
|
|
daemon_reload: yes
|
|
register: stopping_result
|
|
when: "not matrix_synapse_admin_enabled|bool and matrix_synapse_admin_service_stat.stat.exists"
|
|
|
|
- name: Ensure matrix-synapse-admin.service doesn't exist
|
|
file:
|
|
path: "{{ matrix_systemd_path }}/matrix-synapse-admin.service"
|
|
state: absent
|
|
when: "not matrix_synapse_admin_enabled|bool and matrix_synapse_admin_service_stat.stat.exists"
|
|
|
|
- name: Ensure systemd reloaded after matrix-synapse-admin.service removal
|
|
service:
|
|
daemon_reload: yes
|
|
when: "not matrix_synapse_admin_enabled|bool and matrix_synapse_admin_service_stat.stat.exists"
|
|
|
|
- name: Ensure matrix-synapse-admin Docker image doesn't exist
|
|
docker_image:
|
|
name: "{{ matrix_synapse_admin_docker_image }}"
|
|
state: absent
|
|
when: "not matrix_synapse_admin_enabled|bool"
|