nixpkgs/pkgs/by-name/sn/sn0int/package.nix
2024-02-24 23:08:46 +08:00

60 lines
1.4 KiB
Nix

{ lib
, fetchFromGitHub
, rustPlatform
, libseccomp
, libsodium
, pkg-config
, pkgs
, sqlite
, stdenv
, installShellFiles
}:
rustPlatform.buildRustPackage rec {
pname = "sn0int";
version = "0.26.0";
src = fetchFromGitHub {
owner = "kpcyrd";
repo = pname;
rev = "refs/tags/v${version}";
hash = "sha256-ze4OFKUuc/t6tXgmoWFFDjpAQraSY6RIekkcDBctPJo=";
};
cargoHash = "sha256-PAKmoifqB1YC02fVF2SRbXAAGrMcB+Wlvr3FwuqmPVU=";
nativeBuildInputs = [
pkg-config
installShellFiles
];
buildInputs = [
libsodium
sqlite
] ++ lib.optionals stdenv.isLinux [
libseccomp
] ++ lib.optionals stdenv.isDarwin [
pkgs.darwin.apple_sdk.frameworks.Security
];
# One of the dependencies (chrootable-https) tries to read "/etc/resolv.conf"
# in "checkPhase", hence fails in sandbox of "nix".
doCheck = false;
postInstall = ''
installShellCompletion --cmd sn0int \
--bash <($out/bin/sn0int completions bash) \
--fish <($out/bin/sn0int completions fish) \
--zsh <($out/bin/sn0int completions zsh)
'';
meta = with lib; {
description = "Semi-automatic OSINT framework and package manager";
homepage = "https://github.com/kpcyrd/sn0int";
changelog = "https://github.com/kpcyrd/sn0int/releases/tag/v${version}";
license = with licenses; [ gpl3Plus ];
maintainers = with maintainers; [ fab xrelkd ];
platforms = platforms.linux ++ platforms.darwin;
mainProgram = "sn0int";
};
}