python3Packages.ansible-collections: init at 3.4.0

This commit is contained in:
Martin Weinelt 2021-05-12 04:35:46 +02:00 committed by Jonathan Ringer
parent a4eaed4fd6
commit ff2e731ace
2 changed files with 79 additions and 0 deletions

View file

@ -0,0 +1,77 @@
{ lib
, buildPythonPackage
, fetchPypi
, ansible-base
, jsonschema
, jxmlease
, ncclient
, netaddr
, paramiko
, pynetbox
, scp
, textfsm
, ttp
, xmltodict
, withJunos ? false
, withNetbox ? false
}:
buildPythonPackage rec {
pname = "ansible";
version = "3.4.0";
format = "setuptools";
src = fetchPypi {
inherit pname version;
sha256 = "096rbgz730njk0pg8qnc27mmz110wqrw354ca9gasb7rqg0f4d6a";
};
postPatch = ''
# make ansible-base depend on ansible-collection, not the other way around
sed -i '/ansible-base/d' setup.py
'';
propagatedBuildInputs = lib.unique ([
# Support ansible collections by default, make all others optional
# ansible.netcommon
jxmlease
ncclient
netaddr
paramiko
xmltodict
# ansible.posix
# ansible.utils
jsonschema
textfsm
ttp
xmltodict
# ansible.windows
# lots of collections with dedicated requirements.txt and pyproject.toml files,
# add the dependencies for the collections you need conditionally and install
# ansible using overrides to enable the collections you need.
] ++ lib.optionals (withJunos) [
# ansible_collections/junipernetworks/junos/requirements.txt
jxmlease
ncclient
paramiko
scp
xmltodict
] ++ lib.optionals (withNetbox) [
# ansible_collections/netbox/netbox/pyproject.toml
pynetbox
]);
# don't try and fail to strip 48000+ non strippable files, it takes >5 minutes!
dontStrip = true;
# difficult to test
doCheck = false;
meta = with lib; {
description = "Radically simple IT automation";
homepage = "Radically simple IT automation";
license = licenses.gpl3Plus;
maintainers = with maintainers; [ hexa ];
};
}

View file

@ -413,6 +413,8 @@ in {
ansible-base = callPackage ../development/python-modules/ansible/base.nix { };
ansible-collections = callPackage ../development/python-modules/ansible/collections.nix { };
ansible-kernel = callPackage ../development/python-modules/ansible-kernel { };
ansible-lint = callPackage ../development/python-modules/ansible-lint { };