nixpkgs/pkgs/tools/security/theharvester/default.nix
2024-01-16 12:25:46 +01:00

81 lines
1.9 KiB
Nix

{ lib
, fetchFromGitHub
, python3
}:
python3.pkgs.buildPythonApplication rec {
pname = "theharvester";
version = "4.5.0";
pyproject = true;
src = fetchFromGitHub {
owner = "laramies";
repo = "theharvester";
rev = "refs/tags/${version}";
hash = "sha256-tnCiI4bte2RSWSkEL2rwFz6WFjfRMMFiEBOvv3QMyos=";
};
postPatch = ''
# Requirements are pinned
sed -i 's/==.*//' requirements/base.txt
'';
nativeBuildInputs = with python3.pkgs; [
poetry-core
];
propagatedBuildInputs = with python3.pkgs; [
aiodns
aiofiles
aiohttp
aiomultiprocess
aiosqlite
beautifulsoup4
censys
certifi
dnspython
fastapi
lxml
netaddr
ujson
plotly
pyppeteer
python-dateutil
pyyaml
requests
retrying
shodan
slowapi
starlette
uvicorn
uvloop
];
nativeCheckInputs = with python3.pkgs; [
pytest
pytest-asyncio
];
# We don't run other tests (discovery modules) because they require network access
checkPhase = ''
runHook preCheck
pytest tests/test_myparser.py
runHook postCheck
'';
meta = with lib; {
description = "Gather E-mails, subdomains and names from different public sources";
longDescription = ''
theHarvester is a very simple, yet effective tool designed to be used in the early
stages of a penetration test. Use it for open source intelligence gathering and
helping to determine an entity's external threat landscape on the internet. The tool
gathers emails, names, subdomains, IPs, and URLs using multiple public data sources.
'';
homepage = "https://github.com/laramies/theHarvester";
changelog = "https://github.com/laramies/theHarvester/releases/tag/${version}";
license = licenses.gpl2Only;
maintainers = with maintainers; [ c0bw3b fab treemo ];
mainProgram = "theHarvester";
};
}