historical/moneyrocket.git/contrib/init/moneyrocketd.service
2024-01-16 11:20:27 -06:00

82 lines
2.2 KiB
Desktop File

# It is not recommended to modify this file in-place, because it will
# be overwritten during package upgrades. If you want to add further
# options or overwrite existing ones then use
# $ systemctl edit moneyrocketd.service
# See "man systemd.service" for details.
# Note that almost all daemon options could be specified in
# /etc/moneyrocket/moneyrocket.conf, but keep in mind those explicitly
# specified as arguments in ExecStart= will override those in the
# config file.
[Unit]
Description=Moneyrocket daemon
Documentation=https://github.com/moneyrocket/moneyrocket/blob/master/doc/init.md
# https://www.freedesktop.org/wiki/Software/systemd/NetworkTarget/
After=network-online.target
Wants=network-online.target
[Service]
ExecStart=/usr/bin/moneyrocketd -daemonwait \
-pid=/run/moneyrocketd/moneyrocketd.pid \
-conf=/etc/moneyrocket/moneyrocket.conf \
-datadir=/var/lib/moneyrocketd
# Make sure the config directory is readable by the service user
PermissionsStartOnly=true
ExecStartPre=/bin/chgrp moneyrocket /etc/moneyrocket
# Process management
####################
Type=forking
PIDFile=/run/moneyrocketd/moneyrocketd.pid
Restart=on-failure
TimeoutStartSec=infinity
TimeoutStopSec=600
# Directory creation and permissions
####################################
# Run as moneyrocket:moneyrocket
User=moneyrocket
Group=moneyrocket
# /run/moneyrocketd
RuntimeDirectory=moneyrocketd
RuntimeDirectoryMode=0710
# /etc/moneyrocket
ConfigurationDirectory=moneyrocket
ConfigurationDirectoryMode=0710
# /var/lib/moneyrocketd
StateDirectory=moneyrocketd
StateDirectoryMode=0710
# Hardening measures
####################
# Provide a private /tmp and /var/tmp.
PrivateTmp=true
# Mount /usr, /boot/ and /etc read-only for the process.
ProtectSystem=full
# Deny access to /home, /root and /run/user
ProtectHome=true
# Disallow the process and all of its children to gain
# new privileges through execve().
NoNewPrivileges=true
# Use a new /dev namespace only populated with API pseudo devices
# such as /dev/null, /dev/zero and /dev/random.
PrivateDevices=true
# Deny the creation of writable and executable memory mappings.
MemoryDenyWriteExecute=true
[Install]
WantedBy=multi-user.target