From 5e27eb6046c3666a91d35191eabd6093aeec8c24 Mon Sep 17 00:00:00 2001 From: Felix Fontein Date: Fri, 24 Dec 2021 18:34:48 +0100 Subject: [PATCH] Prepare for distutils.version being removed in Python 3.12 (#3936) * Prepare for distutils.version being removed in Python 2.12. * Fix copy'n'paste error. * Re-add Loose prefix. * Fix Python version typos. * Improve formulation. * Move message into own line. * Fix casing, now that the object is no longer called Version. (cherry picked from commit a2f72be6c8d36c0b836755093e2837518b2e5869) --- .../fragments/3936-distutils.version.yml | 2 ++ plugins/filter/version_sort.py | 2 +- plugins/inventory/cobbler.py | 1 - plugins/inventory/proxmox.py | 3 ++- plugins/inventory/xen_orchestra.py | 4 ++-- plugins/module_utils/gitlab.py | 6 +++--- plugins/module_utils/influxdb.py | 3 ++- plugins/module_utils/version.py | 20 +++++++++++++++++++ .../cloud/centurylink/clc_aa_policy.py | 2 +- .../cloud/centurylink/clc_alert_policy.py | 3 ++- .../centurylink/clc_blueprint_package.py | 6 +++--- .../cloud/centurylink/clc_firewall_policy.py | 6 +++--- .../modules/cloud/centurylink/clc_group.py | 3 ++- .../cloud/centurylink/clc_loadbalancer.py | 6 +++--- .../cloud/centurylink/clc_modify_server.py | 6 +++--- .../modules/cloud/centurylink/clc_publicip.py | 3 ++- .../modules/cloud/centurylink/clc_server.py | 6 +++--- .../cloud/centurylink/clc_server_snapshot.py | 6 +++--- plugins/modules/cloud/misc/proxmox.py | 3 ++- plugins/modules/cloud/misc/proxmox_kvm.py | 3 ++- plugins/modules/cloud/misc/terraform.py | 3 ++- plugins/modules/cloud/rackspace/rax_cbs.py | 2 +- .../modules/database/misc/kibana_plugin.py | 3 ++- plugins/modules/files/xml.py | 3 ++- plugins/modules/identity/ipa/ipa_subca.py | 3 ++- .../modules/monitoring/circonus_annotation.py | 3 ++- plugins/modules/net_tools/dnsimple.py | 3 ++- plugins/modules/notification/mqtt.py | 5 +++-- plugins/modules/notification/sendgrid.py | 2 +- plugins/modules/packaging/os/flatpak.py | 8 ++++---- plugins/modules/packaging/os/homebrew_cask.py | 5 +++-- plugins/modules/packaging/os/mas.py | 5 +++-- plugins/modules/packaging/os/openbsd_pkg.py | 6 +++--- .../modules/packaging/os/zypper_repository.py | 4 ++-- .../source_control/gitlab/gitlab_branch.py | 3 ++- .../gitlab/gitlab_protected_branch.py | 3 ++- plugins/modules/system/dpkg_divert.py | 3 ++- plugins/modules/system/filesystem.py | 3 ++- plugins/modules/system/pids.py | 3 ++- .../system/python_requirements_info.py | 2 +- .../modules/web_infrastructure/htpasswd.py | 3 ++- 41 files changed, 106 insertions(+), 63 deletions(-) create mode 100644 changelogs/fragments/3936-distutils.version.yml create mode 100644 plugins/module_utils/version.py diff --git a/changelogs/fragments/3936-distutils.version.yml b/changelogs/fragments/3936-distutils.version.yml new file mode 100644 index 00000000000..bf6ea7f7157 --- /dev/null +++ b/changelogs/fragments/3936-distutils.version.yml @@ -0,0 +1,2 @@ +bugfixes: + - "Various modules and plugins - use vendored version of ``distutils.version`` included in ansible-core 2.12 if available. This avoids breakage when ``distutils`` is removed from the standard library of Python 3.12. Note that ansible-core 2.11, ansible-base 2.10 and Ansible 2.9 are right now not compatible with Python 3.12, hence this fix does not target these ansible-core/-base/2.9 versions (https://github.com/ansible-collections/community.general/pull/3936)." diff --git a/plugins/filter/version_sort.py b/plugins/filter/version_sort.py index c59e87c9c68..ac62ef8c8f4 100644 --- a/plugins/filter/version_sort.py +++ b/plugins/filter/version_sort.py @@ -5,7 +5,7 @@ from __future__ import (absolute_import, division, print_function) __metaclass__ = type -from distutils.version import LooseVersion +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion def version_sort(value, reverse=False): diff --git a/plugins/inventory/cobbler.py b/plugins/inventory/cobbler.py index d9bc549ed68..7292171f1a5 100644 --- a/plugins/inventory/cobbler.py +++ b/plugins/inventory/cobbler.py @@ -68,7 +68,6 @@ password: secure ''' -from distutils.version import LooseVersion import socket from ansible.errors import AnsibleError diff --git a/plugins/inventory/proxmox.py b/plugins/inventory/proxmox.py index f52f0f1bb37..9d324975b30 100644 --- a/plugins/inventory/proxmox.py +++ b/plugins/inventory/proxmox.py @@ -119,12 +119,13 @@ import re from ansible.module_utils.common._collections_compat import MutableMapping -from distutils.version import LooseVersion from ansible.errors import AnsibleError from ansible.plugins.inventory import BaseInventoryPlugin, Constructable, Cacheable from ansible.module_utils.six.moves.urllib.parse import urlencode +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + # 3rd party imports try: import requests diff --git a/plugins/inventory/xen_orchestra.py b/plugins/inventory/xen_orchestra.py index 1e19051fe83..8a7d9e73546 100644 --- a/plugins/inventory/xen_orchestra.py +++ b/plugins/inventory/xen_orchestra.py @@ -79,11 +79,11 @@ import json import ssl -from distutils.version import LooseVersion - from ansible.errors import AnsibleError from ansible.plugins.inventory import BaseInventoryPlugin, Constructable, Cacheable +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + # 3rd party imports try: HAS_WEBSOCKET = True diff --git a/plugins/module_utils/gitlab.py b/plugins/module_utils/gitlab.py index 1a0bf12a1e8..21af10b5cd4 100644 --- a/plugins/module_utils/gitlab.py +++ b/plugins/module_utils/gitlab.py @@ -7,11 +7,11 @@ from __future__ import (absolute_import, division, print_function) __metaclass__ = type -from distutils.version import StrictVersion - from ansible.module_utils.basic import missing_required_lib from ansible.module_utils.common.text.converters import to_native +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + try: from urllib import quote_plus # Python 2.X from urlparse import urljoin @@ -79,7 +79,7 @@ def gitlab_authentication(module): # python-gitlab library remove support for username/password authentication since 1.13.0 # Changelog : https://github.com/python-gitlab/python-gitlab/releases/tag/v1.13.0 # This condition allow to still support older version of the python-gitlab library - if StrictVersion(gitlab.__version__) < StrictVersion("1.13.0"): + if LooseVersion(gitlab.__version__) < LooseVersion("1.13.0"): gitlab_instance = gitlab.Gitlab(url=gitlab_url, ssl_verify=validate_certs, email=gitlab_user, password=gitlab_password, private_token=gitlab_token, api_version=4) else: diff --git a/plugins/module_utils/influxdb.py b/plugins/module_utils/influxdb.py index 92c78023354..c171131a954 100644 --- a/plugins/module_utils/influxdb.py +++ b/plugins/module_utils/influxdb.py @@ -9,7 +9,8 @@ import traceback from ansible.module_utils.basic import missing_required_lib -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: diff --git a/plugins/module_utils/version.py b/plugins/module_utils/version.py new file mode 100644 index 00000000000..d1769e175e9 --- /dev/null +++ b/plugins/module_utils/version.py @@ -0,0 +1,20 @@ +# -*- coding: utf-8 -*- + +# Copyright: (c) 2021, Felix Fontein +# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) + +"""Provide version object to compare version numbers.""" + +from __future__ import absolute_import, division, print_function +__metaclass__ = type + +from ansible.module_utils.six import raise_from + +try: + from ansible.module_utils.compat.version import LooseVersion +except ImportError: + try: + from distutils.version import LooseVersion + except ImportError as exc: + msg = 'To use this plugin or module with ansible-core < 2.11, you need to use Python < 3.12 with distutils.version present' + raise_from(ImportError(msg), exc) diff --git a/plugins/modules/cloud/centurylink/clc_aa_policy.py b/plugins/modules/cloud/centurylink/clc_aa_policy.py index 1d52cca7c59..416a4a6c1f1 100644 --- a/plugins/modules/cloud/centurylink/clc_aa_policy.py +++ b/plugins/modules/cloud/centurylink/clc_aa_policy.py @@ -120,7 +120,7 @@ import os import traceback -from distutils.version import LooseVersion +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: diff --git a/plugins/modules/cloud/centurylink/clc_alert_policy.py b/plugins/modules/cloud/centurylink/clc_alert_policy.py index de9d146dc4f..b6ed6e96efc 100644 --- a/plugins/modules/cloud/centurylink/clc_alert_policy.py +++ b/plugins/modules/cloud/centurylink/clc_alert_policy.py @@ -161,7 +161,8 @@ import json import os import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: diff --git a/plugins/modules/cloud/centurylink/clc_blueprint_package.py b/plugins/modules/cloud/centurylink/clc_blueprint_package.py index bd0e868fa37..4e03062ba73 100644 --- a/plugins/modules/cloud/centurylink/clc_blueprint_package.py +++ b/plugins/modules/cloud/centurylink/clc_blueprint_package.py @@ -89,7 +89,8 @@ import os import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: @@ -132,8 +133,7 @@ def __init__(self, module): self.module.fail_json(msg=missing_required_lib('clc-sdk'), exception=CLC_IMP_ERR) if not REQUESTS_FOUND: self.module.fail_json(msg=missing_required_lib('requests'), exception=REQUESTS_IMP_ERR) - if requests.__version__ and LooseVersion( - requests.__version__) < LooseVersion('2.5.0'): + if requests.__version__ and LooseVersion(requests.__version__) < LooseVersion('2.5.0'): self.module.fail_json( msg='requests library version should be >= 2.5.0') diff --git a/plugins/modules/cloud/centurylink/clc_firewall_policy.py b/plugins/modules/cloud/centurylink/clc_firewall_policy.py index a8f8a4e5f0f..3fc04276929 100644 --- a/plugins/modules/cloud/centurylink/clc_firewall_policy.py +++ b/plugins/modules/cloud/centurylink/clc_firewall_policy.py @@ -162,7 +162,8 @@ import traceback from ansible.module_utils.six.moves.urllib.parse import urlparse from time import sleep -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: @@ -203,8 +204,7 @@ def __init__(self, module): self.module.fail_json(msg=missing_required_lib('clc-sdk'), exception=CLC_IMP_ERR) if not REQUESTS_FOUND: self.module.fail_json(msg=missing_required_lib('requests'), exception=REQUESTS_IMP_ERR) - if requests.__version__ and LooseVersion( - requests.__version__) < LooseVersion('2.5.0'): + if requests.__version__ and LooseVersion(requests.__version__) < LooseVersion('2.5.0'): self.module.fail_json( msg='requests library version should be >= 2.5.0') diff --git a/plugins/modules/cloud/centurylink/clc_group.py b/plugins/modules/cloud/centurylink/clc_group.py index e1c05c6c0c1..312c6269142 100644 --- a/plugins/modules/cloud/centurylink/clc_group.py +++ b/plugins/modules/cloud/centurylink/clc_group.py @@ -207,7 +207,8 @@ import os import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: diff --git a/plugins/modules/cloud/centurylink/clc_loadbalancer.py b/plugins/modules/cloud/centurylink/clc_loadbalancer.py index 950e0879765..bf09ce22bea 100644 --- a/plugins/modules/cloud/centurylink/clc_loadbalancer.py +++ b/plugins/modules/cloud/centurylink/clc_loadbalancer.py @@ -210,7 +210,8 @@ import os import traceback from time import sleep -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: @@ -255,8 +256,7 @@ def __init__(self, module): self.module.fail_json(msg=missing_required_lib('clc-sdk'), exception=CLC_IMP_ERR) if not REQUESTS_FOUND: self.module.fail_json(msg=missing_required_lib('requests'), exception=REQUESTS_IMP_ERR) - if requests.__version__ and LooseVersion( - requests.__version__) < LooseVersion('2.5.0'): + if requests.__version__ and LooseVersion(requests.__version__) < LooseVersion('2.5.0'): self.module.fail_json( msg='requests library version should be >= 2.5.0') diff --git a/plugins/modules/cloud/centurylink/clc_modify_server.py b/plugins/modules/cloud/centurylink/clc_modify_server.py index 90a368867e2..27cdf614ec5 100644 --- a/plugins/modules/cloud/centurylink/clc_modify_server.py +++ b/plugins/modules/cloud/centurylink/clc_modify_server.py @@ -311,7 +311,8 @@ import json import os import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: @@ -355,8 +356,7 @@ def __init__(self, module): self.module.fail_json(msg=missing_required_lib('clc-sdk'), exception=CLC_IMP_ERR) if not REQUESTS_FOUND: self.module.fail_json(msg=missing_required_lib('requests'), exception=REQUESTS_IMP_ERR) - if requests.__version__ and LooseVersion( - requests.__version__) < LooseVersion('2.5.0'): + if requests.__version__ and LooseVersion(requests.__version__) < LooseVersion('2.5.0'): self.module.fail_json( msg='requests library version should be >= 2.5.0') diff --git a/plugins/modules/cloud/centurylink/clc_publicip.py b/plugins/modules/cloud/centurylink/clc_publicip.py index 1cdb4aa8db6..3b4fcc4eedf 100644 --- a/plugins/modules/cloud/centurylink/clc_publicip.py +++ b/plugins/modules/cloud/centurylink/clc_publicip.py @@ -117,7 +117,8 @@ import os import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: diff --git a/plugins/modules/cloud/centurylink/clc_server.py b/plugins/modules/cloud/centurylink/clc_server.py index 95481f1a52e..734039875d1 100644 --- a/plugins/modules/cloud/centurylink/clc_server.py +++ b/plugins/modules/cloud/centurylink/clc_server.py @@ -433,7 +433,8 @@ import os import time import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: @@ -478,8 +479,7 @@ def __init__(self, module): self.module.fail_json(msg=missing_required_lib('clc-sdk'), exception=CLC_IMP_ERR) if not REQUESTS_FOUND: self.module.fail_json(msg=missing_required_lib('requests'), exception=REQUESTS_IMP_ERR) - if requests.__version__ and LooseVersion( - requests.__version__) < LooseVersion('2.5.0'): + if requests.__version__ and LooseVersion(requests.__version__) < LooseVersion('2.5.0'): self.module.fail_json( msg='requests library version should be >= 2.5.0') diff --git a/plugins/modules/cloud/centurylink/clc_server_snapshot.py b/plugins/modules/cloud/centurylink/clc_server_snapshot.py index 1f92def088d..dbee34bbb26 100644 --- a/plugins/modules/cloud/centurylink/clc_server_snapshot.py +++ b/plugins/modules/cloud/centurylink/clc_server_snapshot.py @@ -101,7 +101,8 @@ import os import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: @@ -145,8 +146,7 @@ def __init__(self, module): self.module.fail_json(msg=missing_required_lib('clc-sdk'), exception=CLC_IMP_ERR) if not REQUESTS_FOUND: self.module.fail_json(msg=missing_required_lib('requests'), exception=REQUESTS_IMP_ERR) - if requests.__version__ and LooseVersion( - requests.__version__) < LooseVersion('2.5.0'): + if requests.__version__ and LooseVersion(requests.__version__) < LooseVersion('2.5.0'): self.module.fail_json( msg='requests library version should be >= 2.5.0') diff --git a/plugins/modules/cloud/misc/proxmox.py b/plugins/modules/cloud/misc/proxmox.py index 0fb7f1ccaef..22e9ad6b7c6 100644 --- a/plugins/modules/cloud/misc/proxmox.py +++ b/plugins/modules/cloud/misc/proxmox.py @@ -348,7 +348,8 @@ import time import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion try: from proxmoxer import ProxmoxAPI diff --git a/plugins/modules/cloud/misc/proxmox_kvm.py b/plugins/modules/cloud/misc/proxmox_kvm.py index 110a78434fb..d532433223c 100644 --- a/plugins/modules/cloud/misc/proxmox_kvm.py +++ b/plugins/modules/cloud/misc/proxmox_kvm.py @@ -725,9 +725,10 @@ import re import time import traceback -from distutils.version import LooseVersion from ansible.module_utils.six.moves.urllib.parse import quote +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + try: from proxmoxer import ProxmoxAPI HAS_PROXMOXER = True diff --git a/plugins/modules/cloud/misc/terraform.py b/plugins/modules/cloud/misc/terraform.py index 8c7bd8c70b3..8eca14e712c 100644 --- a/plugins/modules/cloud/misc/terraform.py +++ b/plugins/modules/cloud/misc/terraform.py @@ -230,11 +230,12 @@ import os import json import tempfile -from distutils.version import LooseVersion from ansible.module_utils.six.moves import shlex_quote from ansible.module_utils.basic import AnsibleModule +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + module = None diff --git a/plugins/modules/cloud/rackspace/rax_cbs.py b/plugins/modules/cloud/rackspace/rax_cbs.py index b543f5979af..abfda419ed5 100644 --- a/plugins/modules/cloud/rackspace/rax_cbs.py +++ b/plugins/modules/cloud/rackspace/rax_cbs.py @@ -97,7 +97,7 @@ register: my_volume ''' -from distutils.version import LooseVersion +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion try: import pyrax diff --git a/plugins/modules/database/misc/kibana_plugin.py b/plugins/modules/database/misc/kibana_plugin.py index 25d77193531..db5091e4002 100644 --- a/plugins/modules/database/misc/kibana_plugin.py +++ b/plugins/modules/database/misc/kibana_plugin.py @@ -117,9 +117,10 @@ ''' import os -from distutils.version import LooseVersion from ansible.module_utils.basic import AnsibleModule +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + PACKAGE_STATE_MAP = dict( present="--install", diff --git a/plugins/modules/files/xml.py b/plugins/modules/files/xml.py index ffdb65400ca..ae95e9c646a 100644 --- a/plugins/modules/files/xml.py +++ b/plugins/modules/files/xml.py @@ -356,9 +356,10 @@ import re import traceback -from distutils.version import LooseVersion from io import BytesIO +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + LXML_IMP_ERR = None try: from lxml import etree, objectify diff --git a/plugins/modules/identity/ipa/ipa_subca.py b/plugins/modules/identity/ipa/ipa_subca.py index 3b0d3e8707a..387d63c5131 100644 --- a/plugins/modules/identity/ipa/ipa_subca.py +++ b/plugins/modules/identity/ipa/ipa_subca.py @@ -74,11 +74,12 @@ type: dict ''' -from distutils.version import LooseVersion from ansible.module_utils.basic import AnsibleModule from ansible_collections.community.general.plugins.module_utils.ipa import IPAClient, ipa_argument_spec from ansible.module_utils.common.text.converters import to_native +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + class SubCAIPAClient(IPAClient): def __init__(self, module, host, port, protocol): diff --git a/plugins/modules/monitoring/circonus_annotation.py b/plugins/modules/monitoring/circonus_annotation.py index 8543aa00fa2..40c7297dd71 100644 --- a/plugins/modules/monitoring/circonus_annotation.py +++ b/plugins/modules/monitoring/circonus_annotation.py @@ -143,7 +143,8 @@ import json import time import traceback -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion REQUESTS_IMP_ERR = None try: diff --git a/plugins/modules/net_tools/dnsimple.py b/plugins/modules/net_tools/dnsimple.py index ac1b2a14168..d6606cc0985 100644 --- a/plugins/modules/net_tools/dnsimple.py +++ b/plugins/modules/net_tools/dnsimple.py @@ -148,9 +148,10 @@ RETURN = r"""# """ import traceback -from distutils.version import LooseVersion import re +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + class DNSimpleV1(): """class which uses dnsimple-python < 2""" diff --git a/plugins/modules/notification/mqtt.py b/plugins/modules/notification/mqtt.py index 991114e8aea..60991961026 100644 --- a/plugins/modules/notification/mqtt.py +++ b/plugins/modules/notification/mqtt.py @@ -124,7 +124,8 @@ import ssl import traceback import platform -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion HAS_PAHOMQTT = True PAHOMQTT_IMP_ERR = None @@ -207,7 +208,7 @@ def main(): if tls_version: tls_version = tls_map.get(tls_version, ssl.PROTOCOL_SSLv23) else: - if LooseVersion(platform.python_version()) <= "3.5.2": + if LooseVersion(platform.python_version()) <= LooseVersion("3.5.2"): # Specifying `None` on later versions of python seems sufficient to # instruct python to autonegotiate the SSL/TLS connection. On versions # 3.5.2 and lower though we need to specify the version. diff --git a/plugins/modules/notification/sendgrid.py b/plugins/modules/notification/sendgrid.py index 4a63a03db71..2c349064b8a 100644 --- a/plugins/modules/notification/sendgrid.py +++ b/plugins/modules/notification/sendgrid.py @@ -124,7 +124,7 @@ import os import traceback -from distutils.version import LooseVersion +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion SENDGRID_IMP_ERR = None try: diff --git a/plugins/modules/packaging/os/flatpak.py b/plugins/modules/packaging/os/flatpak.py index 7f3963ad3e0..da913b5ac0c 100644 --- a/plugins/modules/packaging/os/flatpak.py +++ b/plugins/modules/packaging/os/flatpak.py @@ -152,11 +152,11 @@ sample: "org.gnome.Calendar/x86_64/stable\tcurrent\norg.gnome.gitg/x86_64/stable\tcurrent\n" ''' -from distutils.version import StrictVersion - from ansible.module_utils.six.moves.urllib.parse import urlparse from ansible.module_utils.basic import AnsibleModule +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + OUTDATED_FLATPAK_VERSION_ERROR_MESSAGE = "Unknown option --columns=application" @@ -172,7 +172,7 @@ def install_flat(module, binary, remote, names, method, no_dependencies): id_names.append(name) base_command = [binary, "install", "--{0}".format(method)] flatpak_version = _flatpak_version(module, binary) - if StrictVersion(flatpak_version) < StrictVersion('1.1.3'): + if LooseVersion(flatpak_version) < LooseVersion('1.1.3'): base_command += ["-y"] else: base_command += ["--noninteractive"] @@ -196,7 +196,7 @@ def uninstall_flat(module, binary, names, method): ] command = [binary, "uninstall"] flatpak_version = _flatpak_version(module, binary) - if StrictVersion(flatpak_version) < StrictVersion('1.1.3'): + if LooseVersion(flatpak_version) < LooseVersion('1.1.3'): command += ["-y"] else: command += ["--noninteractive"] diff --git a/plugins/modules/packaging/os/homebrew_cask.py b/plugins/modules/packaging/os/homebrew_cask.py index 6c3de1c9ba9..8fe54e3b049 100644 --- a/plugins/modules/packaging/os/homebrew_cask.py +++ b/plugins/modules/packaging/os/homebrew_cask.py @@ -140,7 +140,8 @@ import os import re import tempfile -from distutils import version + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion from ansible.module_utils.common.text.converters import to_bytes from ansible.module_utils.basic import AnsibleModule @@ -493,7 +494,7 @@ def _get_brew_version(self): def _brew_cask_command_is_deprecated(self): # The `brew cask` replacements were fully available in 2.6.0 (https://brew.sh/2020/12/01/homebrew-2.6.0/) - return version.LooseVersion(self._get_brew_version()) >= version.LooseVersion('2.6.0') + return LooseVersion(self._get_brew_version()) >= LooseVersion('2.6.0') # /checks ------------------------------------------------------ }}} # commands ----------------------------------------------------- {{{ diff --git a/plugins/modules/packaging/os/mas.py b/plugins/modules/packaging/os/mas.py index dd394b7c435..0afd858add6 100644 --- a/plugins/modules/packaging/os/mas.py +++ b/plugins/modules/packaging/os/mas.py @@ -97,9 +97,10 @@ from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.common.text.converters import to_native -from distutils.version import StrictVersion import os +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + class Mas(object): @@ -145,7 +146,7 @@ def check_mas_tool(self): # Is the version recent enough? rc, out, err = self.run(['version']) - if rc != 0 or not out.strip() or StrictVersion(out.strip()) < StrictVersion('1.5.0'): + if rc != 0 or not out.strip() or LooseVersion(out.strip()) < LooseVersion('1.5.0'): self.module.fail_json(msg='`mas` tool in version 1.5.0+ needed, got ' + out.strip()) def check_signin(self): diff --git a/plugins/modules/packaging/os/openbsd_pkg.py b/plugins/modules/packaging/os/openbsd_pkg.py index 4299d60ad07..6943569f8dd 100644 --- a/plugins/modules/packaging/os/openbsd_pkg.py +++ b/plugins/modules/packaging/os/openbsd_pkg.py @@ -135,10 +135,10 @@ import shlex import sqlite3 -from distutils.version import StrictVersion - from ansible.module_utils.basic import AnsibleModule +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + # Function used for executing commands. def execute_command(cmd, module): @@ -435,7 +435,7 @@ def parse_package_name(names, pkg_spec, module): if pkg_spec[name]['branch']: branch_release = "6.0" - if StrictVersion(platform.release()) < StrictVersion(branch_release): + if LooseVersion(platform.release()) < LooseVersion(branch_release): module.fail_json(msg="package name using 'branch' syntax requires at least OpenBSD %s: %s" % (branch_release, name)) # Sanity check that there are no trailing dashes in flavor. diff --git a/plugins/modules/packaging/os/zypper_repository.py b/plugins/modules/packaging/os/zypper_repository.py index a29650a17ef..8483df4c61a 100644 --- a/plugins/modules/packaging/os/zypper_repository.py +++ b/plugins/modules/packaging/os/zypper_repository.py @@ -133,8 +133,6 @@ XML_IMP_ERR = traceback.format_exc() HAS_XML = False -from distutils.version import LooseVersion - from ansible.module_utils.basic import AnsibleModule, missing_required_lib from ansible.module_utils.urls import fetch_url @@ -142,6 +140,8 @@ from ansible.module_utils.six.moves import configparser, StringIO from io import open +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + REPO_OPTS = ['alias', 'name', 'priority', 'enabled', 'autorefresh', 'gpgcheck'] diff --git a/plugins/modules/source_control/gitlab/gitlab_branch.py b/plugins/modules/source_control/gitlab/gitlab_branch.py index 2d60aedc19e..ce71a00a9b7 100644 --- a/plugins/modules/source_control/gitlab/gitlab_branch.py +++ b/plugins/modules/source_control/gitlab/gitlab_branch.py @@ -73,7 +73,8 @@ from ansible.module_utils.basic import AnsibleModule, missing_required_lib from ansible.module_utils.api import basic_auth_argument_spec -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion GITLAB_IMP_ERR = None try: diff --git a/plugins/modules/source_control/gitlab/gitlab_protected_branch.py b/plugins/modules/source_control/gitlab/gitlab_protected_branch.py index d237784cbcc..fe8e98a3f3c 100644 --- a/plugins/modules/source_control/gitlab/gitlab_protected_branch.py +++ b/plugins/modules/source_control/gitlab/gitlab_protected_branch.py @@ -73,7 +73,8 @@ from ansible.module_utils.basic import AnsibleModule, missing_required_lib from ansible.module_utils.api import basic_auth_argument_spec -from distutils.version import LooseVersion + +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion GITLAB_IMP_ERR = None try: diff --git a/plugins/modules/system/dpkg_divert.py b/plugins/modules/system/dpkg_divert.py index 1033f70f14a..709d35b865d 100644 --- a/plugins/modules/system/dpkg_divert.py +++ b/plugins/modules/system/dpkg_divert.py @@ -158,11 +158,12 @@ import re import os -from distutils.version import LooseVersion from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.common.text.converters import to_bytes, to_native +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + def diversion_state(module, command, path): diversion = dict(path=path, state='absent', divert=None, holder=None) diff --git a/plugins/modules/system/filesystem.py b/plugins/modules/system/filesystem.py index 4f1d6ee0d1e..2245d341ce2 100644 --- a/plugins/modules/system/filesystem.py +++ b/plugins/modules/system/filesystem.py @@ -115,7 +115,6 @@ fstype: vfat ''' -from distutils.version import LooseVersion import os import platform import re @@ -124,6 +123,8 @@ from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.common.text.converters import to_native +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + class Device(object): def __init__(self, module, path): diff --git a/plugins/modules/system/pids.py b/plugins/modules/system/pids.py index 9745c314495..1fd80140707 100644 --- a/plugins/modules/system/pids.py +++ b/plugins/modules/system/pids.py @@ -56,13 +56,14 @@ import abc import re -from distutils.version import LooseVersion from os.path import basename from ansible.module_utils import six from ansible.module_utils.basic import AnsibleModule, missing_required_lib from ansible.module_utils.common.text.converters import to_native +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + try: import psutil diff --git a/plugins/modules/system/python_requirements_info.py b/plugins/modules/system/python_requirements_info.py index aae85a2d3e8..76be56850d9 100644 --- a/plugins/modules/system/python_requirements_info.py +++ b/plugins/modules/system/python_requirements_info.py @@ -122,7 +122,7 @@ HAS_DISTUTILS = False try: import pkg_resources - from distutils.version import LooseVersion + from ansible_collections.community.general.plugins.module_utils.version import LooseVersion HAS_DISTUTILS = True except ImportError: pass diff --git a/plugins/modules/web_infrastructure/htpasswd.py b/plugins/modules/web_infrastructure/htpasswd.py index b15a9464480..2eebdfd5b81 100644 --- a/plugins/modules/web_infrastructure/htpasswd.py +++ b/plugins/modules/web_infrastructure/htpasswd.py @@ -95,10 +95,11 @@ import os import tempfile import traceback -from distutils.version import LooseVersion from ansible.module_utils.basic import AnsibleModule, missing_required_lib from ansible.module_utils.common.text.converters import to_native +from ansible_collections.community.general.plugins.module_utils.version import LooseVersion + PASSLIB_IMP_ERR = None try: from passlib.apache import HtpasswdFile, htpasswd_context