diff options
author | Christian Poessinger <christian@poessinger.com> | 2020-05-08 18:35:30 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-08 18:35:30 +0200 |
commit | 991ff167d53ab173495f75b33b877a94c3edd24f (patch) | |
tree | 5f4c0fc632f4b1a1504f1a3a498f5a79c203d309 /src/systemd/isc-dhcp-server6.service | |
parent | 29dee3abb55d0f0c6b91b311f30521b45d7e46b6 (diff) | |
parent | b90e3a08ea5cbfc9bae3fd13a49b847b6f2085bb (diff) | |
download | vyos-1x-991ff167d53ab173495f75b33b877a94c3edd24f.tar.gz vyos-1x-991ff167d53ab173495f75b33b877a94c3edd24f.zip |
Merge pull request #404 from jjakob/dhcp-systemd-improve-T2438
dhcp(v6)-server/relay: T2438: change systemd service type to forking, validate config files
Diffstat (limited to 'src/systemd/isc-dhcp-server6.service')
-rw-r--r-- | src/systemd/isc-dhcp-server6.service | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/src/systemd/isc-dhcp-server6.service b/src/systemd/isc-dhcp-server6.service index 27bebc57f..8ac861d7a 100644 --- a/src/systemd/isc-dhcp-server6.service +++ b/src/systemd/isc-dhcp-server6.service @@ -6,13 +6,19 @@ ConditionPathExists=/run/dhcp-server/dhcpdv6.conf After=vyos-router.service [Service] +Type=forking WorkingDirectory=/run/dhcp-server -# The leases files need to be root:vyattacfg even when dropping privileges -ExecStart=/bin/sh -ec '\ - [ -e /config/dhcpdv6.leases ] || touch /config/dhcpdv6.leases; \ - chown root:vyattacfg /config/dhcpdv6.leases; \ - chmod 664 /config/dhcpdv6.leases; \ - exec /usr/sbin/dhcpd -user nobody -group nogroup -f -6 -pf /run/dhcp-server/dhcpdv6.pid -cf /run/dhcp-server/dhcpdv6.conf -lf /config/dhcpdv6.leases' +RuntimeDirectory=dhcp-server +RuntimeDirectoryPreserve=yes +Environment=PID_FILE=/run/dhcp-server/dhcpdv6.pid CONFIG_FILE=/run/dhcp-server/dhcpdv6.conf LEASE_FILE=/config/dhcpdv6.leases +PIDFile=/run/dhcp-server/dhcpdv6.pid +ExecStartPre=/bin/sh -ec '\ +touch ${LEASE_FILE}; \ +chown nobody:nogroup ${LEASE_FILE}* ; \ +chmod 664 ${LEASE_FILE}* ; \ +/usr/sbin/dhcpd -6 -t -T -q -user nobody -group nogroup -pf ${PID_FILE} -cf ${CONFIG_FILE} -lf ${LEASE_FILE} ' +ExecStart=/usr/sbin/dhcpd -6 -q -user nobody -group nogroup -pf ${PID_FILE} -cf ${CONFIG_FILE} -lf ${LEASE_FILE} +Restart=always [Install] WantedBy=multi-user.target |