grimm-nixos-laptop/hardening/systemd/nix-daemon.nix

76 lines
1.8 KiB
Nix
Raw Normal View History

2025-01-08 19:06:22 +01:00
{
lib,
config,
...
}:
{
config.systemd.services = lib.mkIf (config.specialisation != { }) {
nix-daemon.serviceConfig = {
MemoryDenyWriteExecute = true;
NoNewPrivileges = true;
SystemCallArchitectures = "native";
RestrictSUIDSGID = true; # good, somehow???
2025-01-09 13:54:25 +01:00
RestrictAddressFamilies = [
"AF_UNIX"
"AF_INET"
"AF_INET6"
]; # needed to download sources and caches
RestrictNamespaces = [
"user"
"net"
"uts"
"mnt"
"ipc"
"pid"
]; # namespaces needed for sandboxing
SystemCallFilter = [
"@system-service"
"@cpu-emulation"
"@mount"
"@privileged"
];
2025-01-08 19:06:22 +01:00
LockPersonality = true;
ProtectControlGroups = true;
ProtectKernelModules = true; # todo: does kvm need a modprobe here?
PrivateMounts = true;
ProtectProc = "invisible";
ProtectClock = true;
# file system
2025-01-09 13:54:25 +01:00
# PrivateTmp = true; # breaks --keep-failed
2025-01-08 19:06:22 +01:00
ProtectSystem = "strict";
2025-01-09 13:54:25 +01:00
ReadWritePaths = [
"/nix"
"/tmp"
];
2025-01-08 19:06:22 +01:00
# Scheduling: only do as much as resources are available
LimitNICE = 1;
Nice = 19;
RestrictRealtime = true;
# devices
DevicePolicy = "closed"; # allow pseudo-devices like /dev/null, but no real devices
DeviceAllow = "/dev/kvm"; # kvm is needed for VM tests
CapabilityBoundingSet = [
2025-01-09 13:54:25 +01:00
"CAP_FOWNER"
"CAP_CHOWN"
"CAP_SETUID"
"CAP_SETGID"
"CAP_SYS_ADMIN"
"CAP_DAC_OVERRIDE"
];
2025-01-08 19:06:22 +01:00
# ProtectKernelLogs=true; # BAD
# ProtectKernelTunables = true; # BAD
# PrivateUsers=true; BAD
# ProtectHome = "read-only"; # BAD
# ProtectHostname = true; # BAD!
# PrivateNetwork = true; # BAD!
};
};
}