1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/mautrix_discord_ynh.git synced 2024-09-03 19:36:35 +02:00
mautrix_discord_ynh/conf/systemd.service

49 lines
1.5 KiB
SYSTEMD
Raw Normal View History

2023-12-30 19:24:43 +01:00
[Unit]
2024-01-15 08:28:29 +01:00
Description=mautrix-discord bridge
After=matrix-synapse.service
2023-12-30 19:24:43 +01:00
[Service]
Type=simple
User=__APP__
Group=__APP__
WorkingDirectory=__INSTALL_DIR__/
2024-01-15 09:02:21 +01:00
ExecStart=__INSTALL_DIR__/mautrix-discord -c __INSTALL_DIR__/config.yaml
2024-01-15 08:28:29 +01:00
Restart=always
RestartSec=3
2023-12-30 19:24:43 +01:00
# Optional hardening to improve security
ReadWritePaths=__INSTALL_DIR__/ /var/log/__APP__
2023-12-30 19:24:43 +01:00
NoNewPrivileges=yes
2024-01-15 08:28:29 +01:00
MemoryDenyWriteExecute=true
2023-12-30 19:24:43 +01:00
PrivateDevices=yes
PrivateTmp=yes
ProtectHome=yes
ProtectSystem=strict
ProtectControlGroups=true
2024-01-15 09:12:08 +01:00
RestrictSUIDSGID=true
RestrictRealtime=true
LockPersonality=true
2024-01-15 09:12:08 +01:00
ProtectKernelLogs=true
ProtectKernelTunables=true
ProtectHostname=true
ProtectKernelModules=true
PrivateUsers=true
ProtectClock=true
2023-12-30 19:24:43 +01:00
SystemCallArchitectures=native
2024-01-15 09:12:08 +01:00
SystemCallErrorNumber=EPERM
SystemCallFilter=@system-service
2023-12-30 19:24:43 +01:00
# Denying access to capabilities that should not be relevant for webapps
# Doc: https://man7.org/linux/man-pages/man7/capabilities.7.html
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
[Install]
WantedBy=multi-user.target