nixpkgs/pkgs/tools/security/expliot/default.nix
stuebinm ff1a94e523 treewide: add meta.mainProgram to packages with a single binary
The nixpkgs-unstable channel's programs.sqlite was used to identify
packages producing exactly one binary, and these automatically added
to their package definitions wherever possible.
2024-03-19 03:14:51 +01:00

88 lines
1.8 KiB
Nix

{ lib
, fetchFromGitLab
, python3
}:
let
py = python3.override {
packageOverrides = self: super: {
cmd2 = super.cmd2.overridePythonAttrs (oldAttrs: rec {
version = "1.5.0";
src = oldAttrs.src.override {
inherit version;
hash = "sha256-cBqMmXXEq8ReXROQarFJ+Vn4EoaRBjRzI6P4msDoKmI=";
};
doCheck = false;
});
};
};
in
with py.pkgs;
buildPythonApplication rec {
pname = "expliot";
version = "0.9.8";
src = fetchFromGitLab {
owner = "expliot_framework";
repo = pname;
rev = version;
hash = "sha256-7Cuj3YKKwDxP2KKueJR9ZO5Bduv+lw0Y87Rw4b0jbGY=";
};
pythonRelaxDeps = [
"pymodbus"
"pynetdicom"
"cryptography"
"python-can"
"pyparsing"
"zeroconf"
];
nativeBuildInputs = [
pythonRelaxDepsHook
];
propagatedBuildInputs = [
aiocoap
awsiotpythonsdk
bluepy
can
cmd2
cryptography
paho-mqtt
pyi2cflash
pymodbus
pynetdicom
pyparsing
pyserial
pyspiflash
upnpy
xmltodict
zeroconf
];
# Project has no tests
doCheck = false;
pythonImportsCheck = [
"expliot"
];
meta = with lib; {
description = "IoT security testing and exploitation framework";
mainProgram = "expliot";
longDescription = ''
EXPLIoT is a Framework for security testing and exploiting IoT
products and IoT infrastructure. It provides a set of plugins
(test cases) which are used to perform the assessment and can
be extended easily with new ones. The name EXPLIoT (pronounced
expl-aa-yo-tee) is a pun on the word exploit and explains the
purpose of the framework i.e. IoT exploitation.
'';
homepage = "https://expliot.readthedocs.io/";
license = with licenses; [ agpl3Plus ];
maintainers = with maintainers; [ fab ];
};
}