2024-11-18 15:34:47 +00:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
lib,
|
|
|
|
pkgs,
|
|
|
|
...
|
|
|
|
}:
|
2024-11-18 15:28:05 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.programs.tcpdump;
|
2024-11-18 15:34:47 +00:00
|
|
|
in
|
|
|
|
{
|
2024-11-18 15:28:05 +00:00
|
|
|
options = {
|
|
|
|
programs.tcpdump = {
|
|
|
|
enable = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
Whether to configure a setcap wrapper for tcpdump.
|
|
|
|
To use it, add your user to the `pcap` group.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
security.wrappers.tcpdump = {
|
|
|
|
owner = "root";
|
|
|
|
group = "pcap";
|
|
|
|
capabilities = "cap_net_raw+p";
|
|
|
|
permissions = "u+rx,g+x";
|
|
|
|
source = lib.getExe pkgs.tcpdump;
|
|
|
|
};
|
|
|
|
|
|
|
|
users.groups.pcap = { };
|
|
|
|
};
|
|
|
|
}
|