2025-05-29 17:04:28 +02:00

72 lines
1.3 KiB
Nix

{
lib,
fetchFromGitHub,
python3Packages,
libsepol,
libselinux,
checkpolicy,
withGraphics ? false,
}:
python3Packages.buildPythonApplication rec {
pname = "setools";
version = "4.5.1";
pyproject = true;
src = fetchFromGitHub {
owner = "SELinuxProject";
repo = "setools";
tag = version;
hash = "sha256-/6dOzSz2Do4d6TSS50fuak0CysoQ532zJ0bJ532BUCE=";
};
build-system = with python3Packages; [
cython
setuptools
];
buildInputs = [ libsepol ];
dependencies =
with python3Packages;
[
libselinux
setuptools
]
++ lib.optionals withGraphics [ pyqt5 ];
optional-dependencies = {
analysis = with python3Packages; [
networkx
pygraphviz
];
};
nativeCheckInputs = [
python3Packages.tox
checkpolicy
];
setupPyBuildFlags = [ "-i" ];
preBuild = ''
export SEPOL="${lib.getLib libsepol}/lib/libsepol.a"
'';
preCheck = ''
export CHECKPOLICY=${lib.getExe checkpolicy}
'';
meta = {
description = "SELinux Policy Analysis Tools";
homepage = "https://github.com/SELinuxProject/setools";
changelog = "https://github.com/SELinuxProject/setools/blob/${version}/ChangeLog";
license = with lib.licenses; [
gpl2Only
lgpl21Plus
];
maintainers = [ ];
platforms = lib.platforms.linux;
};
}