mirror of https://github.com/bol-van/zapret/
2 changed files with 89 additions and 12 deletions
@ -0,0 +1,65 @@ |
|||||
|
# Example systemd service unit for nfqws. Adjust for your installation. |
||||
|
|
||||
|
# WARNING ! This unit requires to compile nfqws using `make systemd` |
||||
|
# WARNING ! This makefile target enabled special systemd notify support. |
||||
|
|
||||
|
# PREPARE |
||||
|
# install build depends |
||||
|
# make -C /opt/zapret systemd |
||||
|
# cp nfqws@service /lib/systemd/system |
||||
|
|
||||
|
# MANAGE INSTANCE |
||||
|
# prepare /etc/zapret/nfqws1.conf with nfqws parameters |
||||
|
# systemctl daemon-reload |
||||
|
# systemctl start nfqws@nfqws1 |
||||
|
# systemctl status nfqws@nfqws1 |
||||
|
# systemctl restart nfqws@nfqws1 |
||||
|
# systemctl enable nfqws@nfqws1 |
||||
|
# systemctl disable nfqws@nfqws1 |
||||
|
# systemctl stop nfqws@nfqws1 |
||||
|
|
||||
|
# DELETE |
||||
|
# rm /lib/systemd/system/[email protected] |
||||
|
# systemctl daemon-reload |
||||
|
|
||||
|
|
||||
|
[Unit] |
||||
|
After=network.target |
||||
|
|
||||
|
[Service] |
||||
|
Type=notify |
||||
|
Restart=on-failure |
||||
|
|
||||
|
ExecSearchPath=/opt/zapret/binaries/my |
||||
|
ExecStart=nfqws @${CONFIG_DIR}/${INSTANCE}.conf |
||||
|
Environment=CONFIG_DIR=/etc/zapret |
||||
|
Environment=INSTANCE=%i |
||||
|
|
||||
|
RestrictAddressFamilies=AF_NETLINK AF_UNIX AF_INET6 AF_INET |
||||
|
|
||||
|
LockPersonality=true |
||||
|
MemoryDenyWriteExecute=true |
||||
|
PrivateDevices=true |
||||
|
PrivateMounts=true |
||||
|
PrivateTmp=true |
||||
|
ProcSubset=pid |
||||
|
ProtectClock=true |
||||
|
ProtectControlGroups=true |
||||
|
ProtectHome=true |
||||
|
ProtectHostname=true |
||||
|
ProtectKernelLogs=true |
||||
|
ProtectKernelModules=true |
||||
|
ProtectKernelTunables=true |
||||
|
ProtectProc=invisible |
||||
|
ProtectSystem=full |
||||
|
RemoveIPC=true |
||||
|
RestrictNamespaces=true |
||||
|
RestrictRealtime=true |
||||
|
RestrictSUIDSGID=true |
||||
|
SystemCallArchitectures=native |
||||
|
SystemCallFilter=@system-service |
||||
|
SystemCallFilter=~@resources |
||||
|
UMask=0077 |
||||
|
|
||||
|
[Install] |
||||
|
WantedBy=multi-user.target |
@ -3,6 +3,26 @@ |
|||||
# WARNING ! This unit requires to compile nfqws using `make systemd` |
# WARNING ! This unit requires to compile nfqws using `make systemd` |
||||
# WARNING ! This makefile target enabled special systemd notify support. |
# WARNING ! This makefile target enabled special systemd notify support. |
||||
|
|
||||
|
# PREPARE |
||||
|
# install build depends |
||||
|
# make -C /opt/zapret systemd |
||||
|
# cp tpws@service /lib/systemd/system |
||||
|
|
||||
|
# MANAGE INSTANCE |
||||
|
# prepare /etc/zapret/tpws1.conf with tpws parameters |
||||
|
# systemctl daemon-reload |
||||
|
# systemctl start tpws@tpws1 |
||||
|
# systemctl status tpws@tpws1 |
||||
|
# systemctl restart tpws@tpws1 |
||||
|
# systemctl enable tpws@tpws1 |
||||
|
# systemctl disable tpws@tpws1 |
||||
|
# systemctl stop tpws@tpws1 |
||||
|
|
||||
|
# DELETE |
||||
|
# rm /lib/systemd/system/[email protected] |
||||
|
# systemctl daemon-reload |
||||
|
|
||||
|
|
||||
[Unit] |
[Unit] |
||||
After=network.target |
After=network.target |
||||
|
|
||||
@ -11,16 +31,10 @@ Type=notify |
|||||
Restart=on-failure |
Restart=on-failure |
||||
|
|
||||
ExecSearchPath=/opt/zapret/binaries/my |
ExecSearchPath=/opt/zapret/binaries/my |
||||
ExecStart=nfqws @${CONFIG_FILE} |
ExecStart=tpws @${CONFIG_DIR}/${INSTANCE}.conf |
||||
Environment=CONFIG_FILE=/etc/zapret/nfqws.config |
Environment=CONFIG_DIR=/etc/zapret |
||||
|
Environment=INSTANCE=%i |
||||
StateDirectory=nfqws |
|
||||
StateDirectoryMode=0700 |
|
||||
WorkingDirectory=%S/nfqws |
|
||||
|
|
||||
DynamicUser=true |
|
||||
AmbientCapabilities=CAP_NET_ADMIN CAP_NET_RAW |
|
||||
CapabilityBoundingSet=CAP_NET_ADMIN CAP_NET_RAW |
|
||||
RestrictAddressFamilies=AF_NETLINK AF_UNIX AF_INET6 AF_INET |
RestrictAddressFamilies=AF_NETLINK AF_UNIX AF_INET6 AF_INET |
||||
|
|
||||
LockPersonality=true |
LockPersonality=true |
||||
@ -35,16 +49,14 @@ ProtectHome=true |
|||||
ProtectHostname=true |
ProtectHostname=true |
||||
ProtectKernelLogs=true |
ProtectKernelLogs=true |
||||
ProtectKernelModules=true |
ProtectKernelModules=true |
||||
ProtectKernelTunables=true |
|
||||
ProtectProc=invisible |
ProtectProc=invisible |
||||
ProtectSystem=strict |
ProtectSystem=full |
||||
RemoveIPC=true |
RemoveIPC=true |
||||
RestrictNamespaces=true |
RestrictNamespaces=true |
||||
RestrictRealtime=true |
RestrictRealtime=true |
||||
RestrictSUIDSGID=true |
RestrictSUIDSGID=true |
||||
SystemCallArchitectures=native |
SystemCallArchitectures=native |
||||
SystemCallFilter=@system-service |
SystemCallFilter=@system-service |
||||
SystemCallFilter=~@resources @privileged |
|
||||
UMask=0077 |
UMask=0077 |
||||
|
|
||||
[Install] |
[Install] |
Loading…
Reference in new issue