nixpkgs/pkgs/os-specific/linux/setools/default.nix
Vladimír Čunát bf051e91d6
setools: fix build
I assume it broke with python 3.8 -> 3.9.
Updating would be another way, but that would require also updating some
dependencies, and I'm not a selinux person so I chose a simple patch.
2021-07-16 16:58:48 +02:00

50 lines
1.2 KiB
Nix

{ 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;
};
}