python3Packages.scapy: 2.4.3 -> 2.4.4 (#97215)

This commit is contained in:
Michael Weiss 2020-09-06 20:29:31 +02:00 committed by GitHub
parent 24e513bcf0
commit e6cbcc2ac1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 36 additions and 27 deletions

View File

@ -1,6 +1,6 @@
{ buildPythonPackage, fetchFromGitHub, lib, isPyPy, isPy3k, pythonOlder { buildPythonPackage, fetchFromGitHub, lib, isPyPy
, pycrypto, ecdsa # TODO , pycrypto, ecdsa # TODO
, enum34, mock , tox, mock, coverage, can, brotli
, withOptionalDeps ? true, tcpdump, ipython , withOptionalDeps ? true, tcpdump, ipython
, withCryptography ? true, cryptography , withCryptography ? true, cryptography
, withVoipSupport ? true, sox , withVoipSupport ? true, sox
@ -13,7 +13,7 @@
buildPythonPackage rec { buildPythonPackage rec {
pname = "scapy"; pname = "scapy";
version = "2.4.3"; version = "2.4.4";
disabled = isPyPy; disabled = isPyPy;
@ -21,14 +21,11 @@ buildPythonPackage rec {
owner = "secdev"; owner = "secdev";
repo = "scapy"; repo = "scapy";
rev = "v${version}"; rev = "v${version}";
sha256 = "08ypdzp0p3gvmz3pwi0i9q5f7hz9cq8yn6gawia49ynallwnv4zy"; sha256 = "1wpx7gps3g8q5ykbfcd67mxwcs416zg37b53fwfzzlc1m58vhk3p";
}; };
# TODO: Temporary workaround
patches = [ ./fix-version.patch ];
postPatch = '' postPatch = ''
sed -i "s/NIXPKGS_SCAPY_VERSION/${version}/" scapy/__init__.py printf "${version}" > scapy/VERSION
'' + lib.optionalString withManufDb '' '' + lib.optionalString withManufDb ''
substituteInPlace scapy/data.py --replace "/opt/wireshark" "${wireshark}" substituteInPlace scapy/data.py --replace "/opt/wireshark" "${wireshark}"
''; '';
@ -38,16 +35,41 @@ buildPythonPackage rec {
++ lib.optional withCryptography cryptography ++ lib.optional withCryptography cryptography
++ lib.optional withVoipSupport sox ++ lib.optional withVoipSupport sox
++ lib.optional withPlottingSupport matplotlib ++ lib.optional withPlottingSupport matplotlib
++ lib.optionals withGraphicsSupport [ pyx texlive.combined.scheme-minimal graphviz imagemagick ] ++ lib.optionals withGraphicsSupport [ pyx texlive.combined.scheme-minimal graphviz imagemagick ];
++ lib.optional (isPy3k && pythonOlder "3.4") enum34
++ lib.optional doCheck mock;
# Tests fail with Python 3.6 (seems to be an upstream bug, I'll investigate) # Running the tests seems too complicated:
doCheck = if isPy3k then false else true; doCheck = false;
checkInputs = [ tox mock coverage can brotli ];
checkPhase = ''
patchShebangs .
.config/ci/test.sh
'';
meta = with lib; { meta = with lib; {
description = "Powerful interactive network packet manipulation program"; description = "A Python-based network packet manipulation program and library";
longDescription = ''
Scapy is a powerful Python-based interactive packet manipulation program
and library.
It is able to forge or decode packets of a wide number of protocols, send
them on the wire, capture them, store or read them using pcap files,
match requests and replies, and much more. It is designed to allow fast
packet prototyping by using default values that work.
It can easily handle most classical tasks like scanning, tracerouting,
probing, unit tests, attacks or network discovery (it can replace hping,
85% of nmap, arpspoof, arp-sk, arping, tcpdump, wireshark, p0f, etc.). It
also performs very well at a lot of other specific tasks that most other
tools can't handle, like sending invalid frames, injecting your own
802.11 frames, combining techniques (VLAN hopping+ARP cache poisoning,
VoIP decoding on WEP protected channel, ...), etc.
Scapy supports Python 2.7 and Python 3 (3.4 to 3.8). It's intended to be
cross platform, and runs on many different platforms (Linux, OSX, *BSD,
and Windows).
'';
homepage = "https://scapy.net/"; homepage = "https://scapy.net/";
changelog = "https://github.com/secdev/scapy/releases/tag/v${version}";
license = licenses.gpl2; license = licenses.gpl2;
platforms = platforms.unix; platforms = platforms.unix;
maintainers = with maintainers; [ primeos bjornfor ]; maintainers = with maintainers; [ primeos bjornfor ];

View File

@ -1,13 +0,0 @@
diff --git a/scapy/__init__.py b/scapy/__init__.py
index d5ad6164..245ce2fb 100644
--- a/scapy/__init__.py
+++ b/scapy/__init__.py
@@ -90,7 +90,7 @@ def _version():
return 'unknown.version'
-VERSION = __version__ = _version()
+VERSION = __version__ = "NIXPKGS_SCAPY_VERSION"
VERSION_MAIN = re.search(r"[0-9.]+", VERSION).group()
if __name__ == "__main__":