diff options
Diffstat (limited to 'nixpkgs/pkgs/os-specific/linux/setools/default.nix')
-rw-r--r-- | nixpkgs/pkgs/os-specific/linux/setools/default.nix | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/os-specific/linux/setools/default.nix b/nixpkgs/pkgs/os-specific/linux/setools/default.nix new file mode 100644 index 000000000000..842a525353d4 --- /dev/null +++ b/nixpkgs/pkgs/os-specific/linux/setools/default.nix @@ -0,0 +1,50 @@ +{ lib, fetchFromGitHub, python3 +, libsepol, libselinux, checkpolicy +, fetchpatch +, withGraphics ? false +}: + +with lib; +with python3.pkgs; + +buildPythonApplication rec { + pname = "setools"; + version = "4.3.0"; + + src = fetchFromGitHub { + owner = "SELinuxProject"; + repo = pname; + rev = version; + sha256 = "0vr20bi8w147z5lclqz1l0j1b34137zg2r04pkafkgqqk7qbyjk6"; + }; + + patches = [ + (fetchpatch { # included in 4.4.0 + url = "https://github.com/SELinuxProject/setools/commit/f1b4a5d375be05fbccedb258c940d771bff8e524.diff"; + sha256 = "1r38s6i4i6bdr2zdp5wcg1yifpf3pd018c73a511mgynyg7d11xy"; + }) + ]; + + nativeBuildInputs = [ cython ]; + buildInputs = [ libsepol ]; + propagatedBuildInputs = [ enum34 libselinux networkx ] + ++ optionals withGraphics [ pyqt5 ]; + + checkInputs = [ tox checkpolicy ]; + preCheck = '' + export CHECKPOLICY=${checkpolicy}/bin/checkpolicy + ''; + + setupPyBuildFlags = [ "-i" ]; + + preBuild = '' + export SEPOL="${lib.getLib libsepol}/lib/libsepol.a" + ''; + + meta = { + description = "SELinux Policy Analysis Tools"; + homepage = "https://github.com/SELinuxProject/setools"; + license = licenses.gpl2; + platforms = platforms.linux; + }; +} |