Skip to content

Commit

Permalink
Make compatible with requests 2.29.0.
Browse files Browse the repository at this point in the history
  • Loading branch information
felixfontein committed May 2, 2023
1 parent a364261 commit 825a060
Show file tree
Hide file tree
Showing 8 changed files with 19 additions and 21 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ Some modules and plugins require Docker CLI, or other external, programs. Some r

Installing the Docker SDK for Python also installs the requirements for the modules and plugins that use `requests`. If you want to directly install the Python libraries instead of the SDK, you need the following ones:

- [requests](https://pypi.org/project/requests/) (versions before 2.29.0);
- [requests](https://pypi.org/project/requests/);
- [pywin32](https://pypi.org/project/pywin32/) when using named pipes on Windows with the Windows 32 API;
- [paramiko](https://pypi.org/project/paramiko/) when using SSH to connect to the Docker daemon with `use_ssh_client=false`;
- [pyOpenSSL](https://pypi.org/project/pyOpenSSL/) when using TLS to connect to the Docker daemon;
Expand Down
2 changes: 1 addition & 1 deletion meta/ee-requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

docker
urllib3 < 2.0 # TODO see https://github.com/ansible-collections/community.docker/issues/611
requests < 2.29 # TODO see https://github.com/ansible-collections/community.docker/issues/611
requests
paramiko

# We assume that EEs are not based on Windows, and have Python >= 3.5.
Expand Down
2 changes: 1 addition & 1 deletion plugins/doc_fragments/docker.py
Original file line number Diff line number Diff line change
Expand Up @@ -289,7 +289,7 @@ class ModuleDocFragment(object):
communicate with the Docker daemon. It uses code derived from the Docker SDK or Python that is included in this
collection.
requirements:
- requests < 2.29.0 (see U(https://github.com/ansible-collections/community.docker/issues/611))
- requests
- pywin32 (when using named pipes on Windows 32)
- paramiko (when using SSH with I(use_ssh_client=false))
- pyOpenSSL (when using TLS)
Expand Down
10 changes: 10 additions & 0 deletions plugins/module_utils/_api/_import_helper.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,15 +42,20 @@ class InvalidSchema(Exception):

try:
from requests.packages import urllib3
from requests.packages.urllib3 import connection as urllib3_connection # pylint: disable=unused-import
except ImportError:
try:
import urllib3
from urllib3 import connection as urllib3_connection # pylint: disable=unused-import
except ImportError:
URLLIB3_IMPORT_ERROR = traceback.format_exc()

class _HTTPConnectionPool(object):
pass

class _HTTPConnection(object):
pass

class FakeURLLIB3(object):
def __init__(self):
self._collections = self
Expand All @@ -63,7 +68,12 @@ def __init__(self):
self.match_hostname = object()
self.HTTPConnectionPool = _HTTPConnectionPool

class FakeURLLIB3Connection(object):
def __init__(self):
self.HTTPConnection = _HTTPConnection

urllib3 = FakeURLLIB3()
urllib3_connection = FakeURLLIB3Connection()


# Monkey-patching match_hostname with a version that supports
Expand Down
10 changes: 2 additions & 8 deletions plugins/module_utils/_api/transport/npipeconn.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,24 +10,18 @@
from __future__ import (absolute_import, division, print_function)
__metaclass__ = type

from ansible.module_utils.six import PY3
from ansible.module_utils.six.moves.queue import Empty

from .. import constants
from .._import_helper import HTTPAdapter, urllib3
from .._import_helper import HTTPAdapter, urllib3, urllib3_connection

from .basehttpadapter import BaseHTTPAdapter
from .npipesocket import NpipeSocket

if PY3:
import http.client as httplib
else:
import httplib

RecentlyUsedContainer = urllib3._collections.RecentlyUsedContainer


class NpipeHTTPConnection(httplib.HTTPConnection, object):
class NpipeHTTPConnection(urllib3_connection.HTTPConnection, object):
def __init__(self, npipe_path, timeout=60):
super(NpipeHTTPConnection, self).__init__(
'localhost', timeout=timeout
Expand Down
9 changes: 2 additions & 7 deletions plugins/module_utils/_api/transport/sshconn.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,12 +24,7 @@
from .basehttpadapter import BaseHTTPAdapter
from .. import constants

if PY3:
import http.client as httplib
else:
import httplib

from .._import_helper import HTTPAdapter, urllib3
from .._import_helper import HTTPAdapter, urllib3, urllib3_connection

PARAMIKO_IMPORT_ERROR = None
try:
Expand Down Expand Up @@ -120,7 +115,7 @@ def close(self):
self.proc.terminate()


class SSHConnection(httplib.HTTPConnection, object):
class SSHConnection(urllib3_connection.HTTPConnection, object):
def __init__(self, ssh_transport=None, timeout=60, host=None):
super(SSHConnection, self).__init__(
'localhost', timeout=timeout
Expand Down
4 changes: 2 additions & 2 deletions plugins/module_utils/_api/transport/unixconn.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
from .basehttpadapter import BaseHTTPAdapter
from .. import constants

from .._import_helper import HTTPAdapter, urllib3
from .._import_helper import HTTPAdapter, urllib3, urllib3_connection


RecentlyUsedContainer = urllib3._collections.RecentlyUsedContainer
Expand All @@ -35,7 +35,7 @@ def __init__(self, sock, *args, **kwargs):
super(UnixHTTPResponse, self).__init__(sock, *args, **kwargs)


class UnixHTTPConnection(httplib.HTTPConnection, object):
class UnixHTTPConnection(urllib3_connection.HTTPConnection, object):

def __init__(self, base_url, unix_socket, timeout=60):
super(UnixHTTPConnection, self).__init__(
Expand Down
1 change: 0 additions & 1 deletion tests/utils/constraints.txt
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ paramiko < 2.4.0 ; python_version < '2.7' # paramiko 2.4.0 drops support for pyt
paramiko < 3.0.0 ; python_version < '3.7' # paramiko 3.0.0 forces installation of a too new cryptography
requests < 2.20.0 ; python_version < '2.7' # requests 2.20.0 drops support for python 2.6
requests < 2.28 ; python_version < '3.7' # requests 2.28.0 drops support for python < 3.7
requests < 2.29 # TODO see https://github.com/ansible-collections/community.docker/issues/611
virtualenv < 16.0.0 ; python_version < '2.7' # virtualenv 16.0.0 and later require python 2.7 or later
pyopenssl < 18.0.0 ; python_version < '2.7' # pyOpenSSL 18.0.0 and later require python 2.7 or later
setuptools < 45 ; python_version <= '2.7' # setuptools 45 and later require python 3.5 or later
Expand Down

0 comments on commit 825a060

Please sign in to comment.