2017-08-07 19:41:36 -04:00
[Unit]
Description = Pleroma social network
After = network.target postgresql.service
[Service]
ExecReload = /bin/kill $MAINPID
KillMode = process
Restart = on-failure
2019-01-17 13:49:54 -05:00
; Name of the user that runs the Pleroma service.
User = pleroma
; Declares that Pleroma runs in production mode.
Environment = "MIX_ENV=prod"
; Make sure that all paths fit your installation.
; Path to the home directory of the user running the Pleroma service.
Environment = "HOME=/home/pleroma"
; Path to the folder containing the Pleroma installation.
WorkingDirectory = /home/pleroma/pleroma
; Path to the Mix binary.
ExecStart = /usr/bin/mix phx.server
2018-10-24 18:37:31 -04:00
; Some security directives.
; Use private /tmp and /var/tmp folders inside a new file system namespace, which are discarded after the process stops.
PrivateTmp = true
2018-10-24 18:57:47 -04:00
; Mount /usr, /boot, and /etc as read-only for processes invoked by this service.
2018-10-24 18:37:31 -04:00
ProtectSystem = full
; Sets up a new /dev mount for the process and only adds API pseudo devices like /dev/null, /dev/zero or /dev/random but not physical devices. Disabled by default because it may not work on devices like the Raspberry Pi.
PrivateDevices = false
2018-10-24 18:57:47 -04:00
; Ensures that the service process and all its children can never gain new privileges through execve().
2018-10-24 18:37:31 -04:00
NoNewPrivileges = true
2018-12-28 15:09:48 -05:00
; Drops the sysadmin capability from the daemon.
CapabilityBoundingSet = ~CAP_SYS_ADMIN
2018-10-24 18:37:31 -04:00
2017-08-07 19:41:36 -04:00
[Install]
WantedBy = multi-user.target