ansible-collection-fediverse/roles/gotosocial/templates/gotosocial.service.j2
2023-10-22 16:18:54 +02:00

42 lines
1.3 KiB
Django/Jinja

# This Unit is managed by Ansible #
[Unit]
Description=GoToSocial Server
[Service]
User={{ gotosocial_user }}
Group={{ gotosocial_group | default(gotosocial_user) }}
Type=exec
Restart=on-failure
ExecStart={{ gotosocial_base_dir }}/gotosocial --config-path config.yaml server start
WorkingDirectory={{ gotosocial_base_dir }}
NoNewPrivileges=yes
PrivateTmp=yes
PrivateDevices=yes
RestrictAddressFamilies=AF_UNIX AF_INET AF_INET6
RestrictNamespaces=yes
RestrictRealtime=yes
DevicePolicy=closed
ProtectSystem=full
ProtectControlGroups=yes
ProtectKernelModules=yes
ProtectKernelTunables=yes
LockPersonality=yes
SystemCallFilter=~@clock @debug @module @mount @obsolete @reboot @setuid @swap
CapabilityBoundingSet=~CAP_RAWIO CAP_MKNOD
CapabilityBoundingSet=~CAP_AUDIT_CONTROL CAP_AUDIT_READ CAP_AUDIT_WRITE
CapabilityBoundingSet=~CAP_SYS_BOOT CAP_SYS_TIME CAP_SYS_MODULE CAP_SYS_PACCT
CapabilityBoundingSet=~CAP_LEASE CAP_LINUX_IMMUTABLE CAP_IPC_LOCK
CapabilityBoundingSet=~CAP_BLOCK_SUSPEND CAP_WAKE_ALARM
CapabilityBoundingSet=~CAP_SYS_TTY_CONFIG
CapabilityBoundingSet=~CAP_MAC_ADMIN CAP_MAC_OVERRIDE
CapabilityBoundingSet=~CAP_NET_ADMIN CAP_NET_BROADCAST CAP_NET_RAW
CapabilityBoundingSet=~CAP_SYS_ADMIN CAP_SYS_PTRACE CAP_SYSLOG
AmbientCapabilities=CAP_NET_BIND_SERVICE
[Install]
WantedBy=default.target