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.
 
 

73 lines
3.1 KiB

  1. #jinja2: lstrip_blocks: "True"
  2. [Unit]
  3. Description=Matrix nginx-proxy server
  4. {% for service in matrix_nginx_proxy_systemd_required_services_list %}
  5. Requires={{ service }}
  6. After={{ service }}
  7. {% endfor %}
  8. {% for service in matrix_nginx_proxy_systemd_wanted_services_list %}
  9. Wants={{ service }}
  10. {% endfor %}
  11. After=network-online.target
  12. DefaultDependencies=no
  13. PartOf=matrix.target
  14. [Service]
  15. Type=simple
  16. Environment="HOME={{ matrix_systemd_unit_home_path }}"
  17. ExecStartPre=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} stop matrix-nginx-proxy 2>/dev/null'
  18. ExecStartPre=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-nginx-proxy 2>/dev/null'
  19. ExecStart={{ matrix_host_command_docker }} run --rm --name matrix-nginx-proxy \
  20. --log-driver=none \
  21. --user={{ matrix_user_uid }}:{{ matrix_user_gid }} \
  22. --cap-drop=AUDIT_WRITE \
  23. --cap-drop=CHOWN \
  24. --cap-drop=DAC_OVERRIDE \
  25. --cap-drop=FOWNER \
  26. --cap-drop=FSETID \
  27. --cap-drop=KILL \
  28. --cap-drop=MKNOD \
  29. --cap-drop=SETFCAP \
  30. --cap-drop=SETGID \
  31. --cap-drop=SETPCAP \
  32. --cap-drop=SETUID \
  33. --cap-drop=SYS_CHROOT \
  34. --read-only \
  35. --tmpfs=/tmp:rw,noexec,nosuid,size={{ matrix_nginx_proxy_tmp_directory_size_mb }}m \
  36. --network={{ matrix_docker_network }} \
  37. {% if matrix_nginx_proxy_container_http_host_bind_port %}
  38. -p {{ matrix_nginx_proxy_container_http_host_bind_port }}:8080 \
  39. {% endif %}
  40. {% if matrix_nginx_proxy_https_enabled and matrix_nginx_proxy_container_https_host_bind_port %}
  41. -p {{ matrix_nginx_proxy_container_https_host_bind_port }}:8443 \
  42. {% endif %}
  43. {% if matrix_nginx_proxy_proxy_matrix_federation_api_enabled and matrix_nginx_proxy_container_federation_host_bind_port %}
  44. -p {{ matrix_nginx_proxy_container_federation_host_bind_port }}:{{ matrix_nginx_proxy_proxy_matrix_federation_port }} \
  45. {% endif %}
  46. --mount type=bind,src={{ matrix_nginx_proxy_base_path }}/nginx.conf,dst=/etc/nginx/nginx.conf,ro \
  47. --mount type=bind,src={{ matrix_nginx_proxy_data_path }},dst={{ matrix_nginx_proxy_data_path_in_container }},ro \
  48. --mount type=bind,src={{ matrix_nginx_proxy_confd_path }},dst=/etc/nginx/conf.d,ro \
  49. {% if matrix_ssl_retrieval_method != 'none' %}
  50. --mount type=bind,src={{ matrix_ssl_config_dir_path }},dst={{ matrix_ssl_config_dir_path }},ro \
  51. {% endif %}
  52. --mount type=bind,src={{ matrix_static_files_base_path }},dst={{ matrix_static_files_base_path }},ro \
  53. {% for volume in matrix_nginx_proxy_container_additional_volumes %}
  54. -v {{ volume.src }}:{{ volume.dst }}:{{ volume.options }} \
  55. {% endfor %}
  56. {% for arg in matrix_nginx_proxy_container_extra_arguments %}
  57. {{ arg }} \
  58. {% endfor %}
  59. {{ matrix_nginx_proxy_docker_image }}
  60. ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} stop matrix-nginx-proxy 2>/dev/null'
  61. ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-nginx-proxy 2>/dev/null'
  62. ExecReload={{ matrix_host_command_docker }} exec matrix-nginx-proxy /usr/sbin/nginx -s reload
  63. Restart=always
  64. RestartSec=30
  65. SyslogIdentifier=matrix-nginx-proxy
  66. [Install]
  67. WantedBy=matrix.target