Matrix Docker Ansible eploy
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

78 lines
3.4 KiB

  1. #jinja2: lstrip_blocks: "True"
  2. [Unit]
  3. Description=Synapse server
  4. {% for service in matrix_synapse_systemd_required_services_list %}
  5. Requires={{ service }}
  6. After={{ service }}
  7. {% endfor %}
  8. {% for service in matrix_synapse_systemd_wanted_services_list %}
  9. Wants={{ service }}
  10. {% endfor %}
  11. {% if matrix_synapse_workers_enabled %}
  12. {% for matrix_synapse_worker_details in matrix_synapse_workers_enabled_list %}
  13. Wants=matrix-synapse-worker-{{ matrix_synapse_worker_details.type }}-{{ matrix_synapse_worker_details.port }}.service
  14. {% endfor %}
  15. {% endif %}
  16. DefaultDependencies=no
  17. PartOf=matrix.target
  18. [Service]
  19. Type=simple
  20. Environment="HOME={{ matrix_systemd_unit_home_path }}"
  21. ExecStartPre=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} stop matrix-synapse 2>/dev/null'
  22. ExecStartPre=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-synapse 2>/dev/null'
  23. {% if matrix_s3_media_store_enabled %}
  24. # Allow for some time before starting, so that media store can mount.
  25. # Mounting can happen later too, but if we start writing,
  26. # we'd write files to the local filesystem and fusermount will complain.
  27. ExecStartPre={{ matrix_host_command_sleep }} 3
  28. {% endif %}
  29. ExecStart={{ matrix_host_command_docker }} run --rm --name matrix-synapse \
  30. --log-driver=none \
  31. --user={{ matrix_user_uid }}:{{ matrix_user_gid }} \
  32. --env=UID={{ matrix_user_uid }} \
  33. --env=GID={{ matrix_user_gid }} \
  34. --cap-drop=ALL \
  35. --read-only \
  36. --tmpfs=/tmp:rw,noexec,nosuid,size={{ matrix_synapse_tmp_directory_size_mb }}m \
  37. --network={{ matrix_docker_network }} \
  38. {% if matrix_synapse_container_client_api_host_bind_port %}
  39. -p {{ matrix_synapse_container_client_api_host_bind_port }}:8008 \
  40. {% endif %}
  41. {% if matrix_synapse_federation_enabled and matrix_synapse_tls_federation_listener_enabled and matrix_synapse_container_federation_api_tls_host_bind_port %}
  42. -p {{ matrix_synapse_container_federation_api_tls_host_bind_port }}:8448 \
  43. {% endif %}
  44. {% if matrix_synapse_federation_enabled and matrix_synapse_container_federation_api_plain_host_bind_port %}
  45. -p {{ matrix_synapse_container_federation_api_plain_host_bind_port }}:8048 \
  46. {% endif %}
  47. {% if matrix_synapse_metrics_enabled and matrix_synapse_container_metrics_api_host_bind_port %}
  48. -p {{ matrix_synapse_container_metrics_api_host_bind_port }}:{{ matrix_synapse_metrics_port }} \
  49. {% endif %}
  50. {% if matrix_synapse_manhole_enabled and matrix_synapse_container_manhole_api_host_bind_port %}
  51. -p {{ matrix_synapse_container_manhole_api_host_bind_port }}:9000 \
  52. {% endif %}
  53. --mount type=bind,src={{ matrix_synapse_config_dir_path }},dst=/data,ro \
  54. --mount type=bind,src={{ matrix_synapse_storage_path }},dst=/matrix-media-store-parent,bind-propagation=slave \
  55. {% for volume in matrix_synapse_container_additional_volumes %}
  56. -v {{ volume.src }}:{{ volume.dst }}:{{ volume.options }} \
  57. {% endfor %}
  58. {% for arg in matrix_synapse_container_extra_arguments %}
  59. {{ arg }} \
  60. {% endfor %}
  61. {{ matrix_synapse_docker_image }} \
  62. run -m synapse.app.homeserver -c /data/homeserver.yaml
  63. ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} stop matrix-synapse 2>/dev/null'
  64. ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-synapse 2>/dev/null'
  65. ExecReload={{ matrix_host_command_docker }} exec matrix-synapse /bin/sh -c 'kill -HUP 1'
  66. Restart=always
  67. RestartSec=30
  68. SyslogIdentifier=matrix-synapse
  69. [Install]
  70. WantedBy=matrix.target