nixpkgs-immich/pkgs/by-name/bu/bulk_extractor/package.nix
2024-09-17 10:23:40 -06:00

79 lines
1.8 KiB
Nix

{ lib
, stdenv
, fetchFromGitHub
, autoreconfHook
, exiv2
, flex
, libewf
, libxml2
, openssl
, zlib
, pkg-config
, python310
, re2
}:
stdenv.mkDerivation (finalAttrs: {
pname = "bulk_extractor";
version = "2.1.1";
src = fetchFromGitHub {
owner = "simsong";
repo = "bulk_extractor";
rev = "v${finalAttrs.version}";
hash = "sha256-Jj/amXESFBu/ZaiIRlDKmtWTBVQ2TEvOM2jBYP3y1L8=";
fetchSubmodules = true;
};
enableParallelBuilding = true;
nativeBuildInputs = [
pkg-config
python310
autoreconfHook
];
buildInputs = [
exiv2
flex
libewf
libxml2
openssl
zlib
re2
];
preAutoreconf = ''
python3 etc/makefile_builder.py
autoheader -f
aclocal -I m4
'';
postPatch = lib.optionalString stdenv.isDarwin ''
substituteInPlace src/be20_api/feature_recorder_set.cpp --replace-fail '#warn ' '#warning '
'';
meta = with lib; {
description = "Digital forensics tool for extracting information from file systems";
longDescription = ''
bulk_extractor is a C++ program that scans a disk image, a file, or a
directory of files and extracts useful information without parsing
the file system or file system structures. The results are stored in
feature files that can be easily inspected, parsed, or processed with
automated tools.
'';
mainProgram = "bulk_extractor";
homepage = "https://github.com/simsong/bulk_extractor";
downloadPage = "http://downloads.digitalcorpora.org/downloads/bulk_extractor/";
changelog = "https://github.com/simsong/bulk_extractor/blob/${finalAttrs.src.rev}/ChangeLog";
maintainers = with maintainers; [ d3vil0p3r ];
platforms = with platforms; unix ++ windows;
license = with licenses; [
mit
cpl10
gpl3Only
lgpl21Only
lgpl3Only
licenses.openssl
];
};
})