2014-04-14 07:26:48 -07:00
|
|
|
{ config, lib, pkgs, ... }:
|
2013-05-10 22:41:36 -07:00
|
|
|
let
|
|
|
|
cfg = config.security.apparmor;
|
|
|
|
in
|
2014-04-14 07:26:48 -07:00
|
|
|
with lib;
|
2013-05-10 22:41:36 -07:00
|
|
|
{
|
2019-12-09 17:51:19 -08:00
|
|
|
imports = [
|
|
|
|
(mkRenamedOptionModule [ "security" "virtualization" "flushL1DataCache" ] [ "security" "virtualisation" "flushL1DataCache" ])
|
|
|
|
];
|
2013-05-10 22:41:36 -07:00
|
|
|
|
|
|
|
options.security.apparmor.confineSUIDApplications = mkOption {
|
2020-04-27 00:04:07 -07:00
|
|
|
type = types.bool;
|
2013-05-10 22:41:36 -07:00
|
|
|
default = true;
|
|
|
|
description = ''
|
|
|
|
Install AppArmor profiles for commonly-used SUID application
|
|
|
|
to mitigate potential privilege escalation attacks due to bugs
|
|
|
|
in such applications.
|
|
|
|
|
|
|
|
Currently available profiles: ping
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf (cfg.confineSUIDApplications) {
|
|
|
|
security.apparmor.profiles = [ (pkgs.writeText "ping" ''
|
|
|
|
#include <tunables/global>
|
2017-01-29 02:11:01 -08:00
|
|
|
/run/wrappers/bin/ping {
|
2013-05-13 06:13:06 -07:00
|
|
|
#include <abstractions/base>
|
|
|
|
#include <abstractions/consoles>
|
|
|
|
#include <abstractions/nameservice>
|
2013-05-10 22:41:36 -07:00
|
|
|
|
2013-05-13 06:13:06 -07:00
|
|
|
capability net_raw,
|
|
|
|
capability setuid,
|
|
|
|
network inet raw,
|
2013-05-10 22:41:36 -07:00
|
|
|
|
2018-03-24 18:51:32 -07:00
|
|
|
${pkgs.stdenv.cc.libc.out}/lib/*.so mr,
|
2016-05-07 12:48:29 -07:00
|
|
|
${pkgs.libcap.lib}/lib/libcap.so* mr,
|
2016-01-23 23:28:56 -08:00
|
|
|
${pkgs.attr.out}/lib/libattr.so* mr,
|
2013-05-28 07:15:10 -07:00
|
|
|
|
|
|
|
${pkgs.iputils}/bin/ping mixr,
|
|
|
|
|
2013-05-13 06:13:06 -07:00
|
|
|
#/etc/modules.conf r,
|
2013-05-10 22:41:36 -07:00
|
|
|
|
2013-05-13 06:13:06 -07:00
|
|
|
## Site-specific additions and overrides. See local/README for details.
|
|
|
|
##include <local/bin.ping>
|
2013-05-10 22:41:36 -07:00
|
|
|
}
|
|
|
|
'') ];
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|