dd527d5968
This is mostly here to guard against problems happening
due to server migration and doing `chown -R matrix:matrix /matrix`.
Normally, the file is owned by `1000:1000`, as expected.
If ownership changes, Dimension could still start, but it will fail the
first time it tries to write to the database. Explicitly chowning
before startup guards against this.
Related to #485 and #486 (Github Pull Requests).
Also related to ccc7aaf0ce
.
40 lines
1.3 KiB
Django/Jinja
40 lines
1.3 KiB
Django/Jinja
#jinja2: lstrip_blocks: "True"
|
|
[Unit]
|
|
Description=Matrix Dimension
|
|
After=docker.service
|
|
Requires=docker.service
|
|
|
|
[Service]
|
|
Type=simple
|
|
ExecStartPre=-/usr/bin/docker kill matrix-dimension
|
|
ExecStartPre=-/usr/bin/docker rm matrix-dimension
|
|
|
|
# Fixup database ownership if it got changed somehow (during a server migration, etc.)
|
|
ExecStartPre=-/usr/bin/chown {{ matrix_dimension_user_uid }}:{{ matrix_dimension_user_gid }} {{ matrix_dimension_base_path }}/dimension.db
|
|
|
|
ExecStart=/usr/bin/docker run --rm --name matrix-dimension \
|
|
--log-driver=none \
|
|
--user={{ matrix_dimension_user_uid }}:{{ matrix_dimension_user_gid }} \
|
|
--cap-drop=ALL \
|
|
--network={{ matrix_docker_network }} \
|
|
{% if matrix_dimension_widgets_allow_self_signed_ssl_certificates %}
|
|
-e NODE_TLS_REJECT_UNAUTHORIZED=0 \
|
|
{% endif %}
|
|
{% if matrix_dimension_container_http_host_bind_port %}
|
|
-p {{ matrix_dimension_container_http_host_bind_port }}:8184 \
|
|
{% endif %}
|
|
-v {{ matrix_dimension_base_path }}:/data:rw \
|
|
{% for arg in matrix_dimension_container_extra_arguments %}
|
|
{{ arg }} \
|
|
{% endfor %}
|
|
{{ matrix_dimension_docker_image }}
|
|
|
|
ExecStop=-/usr/bin/docker kill matrix-dimension
|
|
ExecStop=-/usr/bin/docker rm matrix-dimension
|
|
Restart=always
|
|
RestartSec=30
|
|
SyslogIdentifier=matrix-dimension
|
|
|
|
[Install]
|
|
WantedBy=multi-user.target
|