depot/third_party/nixpkgs/pkgs/development/python-modules/paramiko/default.nix
Default email 472aeafc57 Project import generated by Copybara.
GitOrigin-RevId: c31898adf5a8ed202ce5bea9f347b1c6871f32d1
2024-10-04 18:56:33 +02:00

90 lines
2.2 KiB
Nix

{
lib,
bcrypt,
buildPythonPackage,
cryptography,
fetchpatch,
fetchPypi,
gssapi,
icecream,
invoke,
mock,
pyasn1,
pynacl,
pytestCheckHook,
six,
}:
buildPythonPackage rec {
pname = "paramiko";
version = "3.4.0";
format = "setuptools";
src = fetchPypi {
inherit pname version;
hash = "sha256-qsCPJqMdxN/9koIVJ9FoLZnVL572hRloEUqHKPPCdNM=";
};
patches = [
# Fix usage of dsa keys
# https://github.com/paramiko/paramiko/pull/1606/
(fetchpatch {
url = "https://github.com/paramiko/paramiko/commit/18e38b99f515056071fb27b9c1a4f472005c324a.patch";
hash = "sha256-bPDghPeLo3NiOg+JwD5CJRRLv2VEqmSx1rOF2Tf8ZDA=";
})
(fetchpatch {
name = "paramiko-pytest8-compat.patch";
url = "https://github.com/paramiko/paramiko/commit/d71046151d9904df467ff72709585cde39cdd4ca.patch";
hash = "sha256-4CTIZ9BmzRdh+HOwxSzfM9wkUGJOnndctK5swqqsIvU=";
})
];
propagatedBuildInputs = [
bcrypt
cryptography
pyasn1
six
] ++ optional-dependencies.ed25519; # remove on 3.0 update
optional-dependencies = {
gssapi = [
pyasn1
gssapi
];
ed25519 = [
pynacl
bcrypt
];
invoke = [ invoke ];
};
nativeCheckInputs = [
icecream
mock
pytestCheckHook
] ++ lib.flatten (builtins.attrValues optional-dependencies);
disabledTestPaths = [
# disable tests that require pytest-relaxed, which is broken
"tests/test_client.py"
"tests/test_ssh_gss.py"
];
pythonImportsCheck = [ "paramiko" ];
__darwinAllowLocalNetworking = true;
meta = with lib; {
homepage = "https://github.com/paramiko/paramiko/";
changelog = "https://github.com/paramiko/paramiko/blob/${version}/sites/www/changelog.rst";
description = "Native Python SSHv2 protocol library";
license = licenses.lgpl21Plus;
longDescription = ''
Library for making SSH2 connections (client or server). Emphasis is
on using SSH2 as an alternative to SSL for making secure connections
between python scripts. All major ciphers and hash methods are
supported. SFTP client and server mode are both supported too.
'';
maintainers = [ ];
};
}