2017-11-18 17:35:03 +01:00
# SPDX-License-Identifier: LGPL-2.1+
#
2013-10-17 03:18:36 +02:00
# This file is part of systemd.
#
# systemd is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2.1 of the License, or
# (at your option) any later version.
[Unit]
Description = Network Service
Documentation = man:systemd-networkd.service(8)
2014-06-17 02:18:33 +02:00
ConditionCapability = CAP_NET_ADMIN
2013-10-17 03:18:36 +02:00
DefaultDependencies = no
2016-11-22 08:41:51 +01:00
# systemd-udevd.service can be dropped once tuntap is moved to netlink
Revert "network: set DynamicUser= to systemd-networkd.service"
This reverts commit d4e9e574ea0b5d23598a317e68399584d229568b.
(systemd.conf.m4 part was already reverted in 5b5d82615011b9827466b7cd5756da35627a1608.)
Together those reverts should "fix" #10025 and #10011. ("fix" is in quotes
because this doesn't really fix the underlying issue, which is combining
DynamicUser= with strict container sandbox, but it avoids the problem by not
using that feature in our default installation.)
Dynamic users don't work well if the service requires matching configuration in
other places, for example dbus policy. This is true for those three services.
In effect, distros create the user statically [1, 2]. Dynamic users make more
sense for "add-on" services where not creating the user, or more precisely,
creating the user lazily, can save resources. For "basic" services, if we are
going to create the user on package installation anyway, setting DynamicUser=
just creates unneeded confusion. The only case where it is actually used is
when somebody forgets to do system configuration. But it's better to have the
service fail cleanly in this case too. If we want to turn on some side-effect
of DynamicUser=yes for those services, we should just do that directly through
fine-grained options. By not using DynamicUser= we also avoid the need to
restart dbus.
[1] https://salsa.debian.org/systemd-team/systemd/commit/bd9bf307274faca24699c0c2d67cb86f18c0b2cb
[2] https://src.fedoraproject.org/rpms/systemd/blob/48ac1cebdedb055d9daf3dfe28c7bde80103f7a1/f/systemd.spec#_473
(Fedora does not create systemd-timesync user.)
2018-09-19 10:06:09 +02:00
After = systemd-udevd.service network-pre.target systemd-sysusers.service systemd-sysctl.service
2014-06-17 02:18:33 +02:00
Before = network.target multi-user.target shutdown.target
Conflicts = shutdown.target
2013-10-17 03:18:36 +02:00
Wants = network.target
[Service]
2017-08-27 01:40:47 +09:00
AmbientCapabilities = CAP_NET_ADMIN CAP_NET_BIND_SERVICE CAP_NET_BROADCAST CAP_NET_RAW
2018-11-12 17:19:48 +01:00
CapabilityBoundingSet = CAP_NET_ADMIN CAP_NET_BIND_SERVICE CAP_NET_BROADCAST CAP_NET_RAW
2019-05-01 15:28:36 +03:00
DeviceAllow = char-* rw
2018-11-12 17:19:48 +01:00
ExecStart = !!@rootlibexecdir@/systemd-networkd
LockPersonality = yes
MemoryDenyWriteExecute = yes
NoNewPrivileges = yes
2016-08-26 13:23:27 +02:00
ProtectControlGroups = yes
2018-11-12 17:19:48 +01:00
ProtectHome = yes
2017-02-09 11:09:50 +01:00
ProtectKernelModules = yes
2018-11-12 17:19:48 +01:00
ProtectSystem = strict
Restart = on-failure
RestartSec = 0
2016-08-26 13:23:27 +02:00
RestrictAddressFamilies = AF_UNIX AF_NETLINK AF_INET AF_INET6 AF_PACKET
2018-11-12 17:19:48 +01:00
RestrictNamespaces = yes
RestrictRealtime = yes
2019-03-20 19:52:20 +01:00
RestrictSUIDSGID = yes
2017-08-27 01:40:47 +09:00
RuntimeDirectory = systemd/netif
RuntimeDirectoryPreserve = yes
2018-11-12 17:19:48 +01:00
SystemCallArchitectures = native
SystemCallErrorNumber = EPERM
SystemCallFilter = @system-service
Type = notify
User = systemd-network
WatchdogSec = 3min
2014-02-21 04:38:17 +01:00
[Install]
WantedBy = multi-user.target
2015-02-01 22:13:26 +01:00
Also = systemd-networkd.socket
2017-04-10 11:59:58 -04:00
Alias = dbus-org.freedesktop.network1.service
2017-03-27 06:55:55 -04:00
# We want to enable systemd-networkd-wait-online.service whenever this service
# is enabled. systemd-networkd-wait-online.service has
# WantedBy=network-online.target, so enabling it only has an effect if
# network-online.target itself is enabled or pulled in by some other unit.
Also = systemd-networkd-wait-online.service