{ config, lib, pkgs, ... }: with lib; let cfg = config.programs.wireshark; wireshark = cfg.package; in { options = { programs.wireshark = { enable = mkOption { type = types.bool; default = false; description = lib.mdDoc '' Whether to add Wireshark to the global environment and configure a setcap wrapper for 'dumpcap' for users in the 'wireshark' group. ''; }; package = mkOption { type = types.package; default = pkgs.wireshark-cli; defaultText = literalExpression "pkgs.wireshark-cli"; description = lib.mdDoc '' Which Wireshark package to install in the global environment. ''; }; }; }; config = mkIf cfg.enable { environment.systemPackages = [ wireshark ]; users.groups.wireshark = {}; security.wrappers.dumpcap = { source = "${wireshark}/bin/dumpcap"; capabilities = "cap_net_raw,cap_net_admin+eip"; owner = "root"; group = "wireshark"; permissions = "u+rx,g+x"; }; }; }