about summary refs log tree commit diff
path: root/nixpkgs/pkgs/development/python-modules/sslyze/default.nix
blob: 5680b4bd36b3444aa53eeebf39b24fc75123c45f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
{ lib
, fetchFromGitHub
, buildPythonPackage
, nassl
, cryptography
, typing-extensions
, faker
, pytestCheckHook
, pythonOlder
}:

buildPythonPackage rec {
  pname = "sslyze";
  version = "4.1.0";
  disabled = pythonOlder "3.7";

  src = fetchFromGitHub {
    owner = "nabla-c0d3";
    repo = pname;
    rev = version;
    hash = "sha256-oSTKNiECczlPAbv5Azc023PcquFbnlC5O+8tVgNcUW0=";
  };

  patchPhase = ''
    substituteInPlace setup.py \
      --replace "cryptography>=2.6,<3.5" "cryptography>=2.6,<4.0"
  '';

  checkInputs = [ pytestCheckHook ];

  # Most of the tests are online; hence, applicable tests are listed
  # explicitly here
  pytestFlagsArray = [
    "tests/test_main.py"
    "tests/test_scanner.py"
    "tests/cli_tests/test_console_output.py"
    "tests/cli_tests/test_json_output.py"
    "tests/cli_tests/test_server_string_parser.py"
    "tests/plugins_tests/test_scan_commands.py"
    "tests/plugins_tests/certificate_info/test_certificate_utils.py"
  ];

  disabledTests = [
    "test_error_client_certificate_needed"
  ];

  pythonImportsCheck = [ "sslyze" ];

  propagatedBuildInputs = [ nassl cryptography typing-extensions faker ];

  meta = with lib; {
    homepage = "https://github.com/nabla-c0d3/sslyze";
    description = "Fast and powerful SSL/TLS scanning library";
    platforms = platforms.linux ++ platforms.darwin;
    license = licenses.agpl3Only;
    maintainers = with maintainers; [ veehaitch ];
  };
}