ff1a94e523
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.
72 lines
1.6 KiB
Nix
72 lines
1.6 KiB
Nix
{ lib
|
|
, stdenv
|
|
, fetchurl
|
|
, flex
|
|
, bison
|
|
, bluez
|
|
, libnl
|
|
, libxcrypt
|
|
, pkg-config
|
|
, withBluez ? false
|
|
, withRemote ? false
|
|
|
|
# for passthru.tests
|
|
, ettercap
|
|
, nmap
|
|
, ostinato
|
|
, tcpreplay
|
|
, vde2
|
|
, wireshark
|
|
, python3
|
|
, haskellPackages
|
|
}:
|
|
|
|
stdenv.mkDerivation rec {
|
|
pname = "libpcap";
|
|
version = "1.10.4";
|
|
|
|
src = fetchurl {
|
|
url = "https://www.tcpdump.org/release/${pname}-${version}.tar.gz";
|
|
hash = "sha256-7RmgOD+tcuOtQ1/SOdfNgNZJFrhyaVUBWdIORxYOvl8=";
|
|
};
|
|
|
|
buildInputs = lib.optionals stdenv.isLinux [ libnl ]
|
|
++ lib.optionals withRemote [ libxcrypt ];
|
|
|
|
nativeBuildInputs = [ flex bison ]
|
|
++ lib.optionals stdenv.isLinux [ pkg-config ]
|
|
++ lib.optionals withBluez [ bluez.dev ];
|
|
|
|
# We need to force the autodetection because detection doesn't
|
|
# work in pure build environments.
|
|
configureFlags = [
|
|
"--with-pcap=${if stdenv.isLinux then "linux" else "bpf"}"
|
|
] ++ lib.optionals stdenv.isDarwin [
|
|
"--disable-universal"
|
|
] ++ lib.optionals withRemote [
|
|
"--enable-remote"
|
|
] ++ lib.optionals (stdenv.hostPlatform == stdenv.buildPlatform)
|
|
[ "ac_cv_linux_vers=2" ];
|
|
|
|
postInstall = ''
|
|
if [ "$dontDisableStatic" -ne "1" ]; then
|
|
rm -f $out/lib/libpcap.a
|
|
fi
|
|
'';
|
|
|
|
passthru.tests = {
|
|
inherit ettercap nmap ostinato tcpreplay vde2 wireshark;
|
|
inherit (python3.pkgs) pcapy-ng scapy;
|
|
haskell-pcap = haskellPackages.pcap;
|
|
};
|
|
|
|
meta = with lib; {
|
|
homepage = "https://www.tcpdump.org";
|
|
description = "Packet Capture Library";
|
|
mainProgram = "pcap-config";
|
|
platforms = platforms.unix;
|
|
maintainers = with maintainers; [ fpletz ];
|
|
license = licenses.bsd3;
|
|
};
|
|
}
|