aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--CHANGELOG.rst2
-rw-r--r--src/cryptography/hazmat/backends/__init__.py32
-rw-r--r--tests/hazmat/backends/test_backendinit.py17
3 files changed, 50 insertions, 1 deletions
diff --git a/CHANGELOG.rst b/CHANGELOG.rst
index 9ca4c120..f6c0a3a7 100644
--- a/CHANGELOG.rst
+++ b/CHANGELOG.rst
@@ -22,6 +22,8 @@ Changelog
support to :class:`~cryptography.x509.CertificateRevocationList`.
* Added support for :class:`~cryptography.hazmat.primitives.kdf.scrypt.Scrypt`
when using OpenSSL 1.1.0.
+* Added a workaround to improve compatibility with Python application bundling
+ tools like ``PyInstaller`` and ``cx_freeze``.
* Added support for generating a
:meth:`~cryptography.x509.random_serial_number`.
* Added support for encoding ``IPv4Network`` and ``IPv6Network`` in X.509
diff --git a/src/cryptography/hazmat/backends/__init__.py b/src/cryptography/hazmat/backends/__init__.py
index e66f9e10..161a1879 100644
--- a/src/cryptography/hazmat/backends/__init__.py
+++ b/src/cryptography/hazmat/backends/__init__.py
@@ -16,7 +16,7 @@ def _available_backends():
global _available_backends_list
if _available_backends_list is None:
- _available_backends_list = [
+ entry_point_backends = [
# DeprecatedIn16
# setuptools 11.3 deprecated support for the require parameter to
# load(), and introduced the new resolve() method instead.
@@ -29,8 +29,38 @@ def _available_backends():
)
]
+ _available_backends_list = _backend_import_fallback(
+ entry_point_backends
+ )
+
return _available_backends_list
+
+def _backend_import_fallback(backends):
+ # If backends already exist just return them. This branch is here
+ # to get full line coverage from our tests.
+ if backends:
+ return backends
+
+ # if iter_entry_points fails to find any backends then manually try to
+ # import our current backends as a workaround for issues with application
+ # bundlers like pyinstaller, cx_freeze, etc
+
+ # OpenSSL is guaranteed to be present until we unbundle the backends.
+ from cryptography.hazmat.backends.openssl.backend import backend as be_ossl
+ backends = [be_ossl]
+ try:
+ from cryptography.hazmat.backends.commoncrypto.backend import (
+ backend as be_cc
+ )
+ except ImportError:
+ pass
+ else:
+ backends.append(be_cc)
+
+ return backends
+
+
_default_backend = None
diff --git a/tests/hazmat/backends/test_backendinit.py b/tests/hazmat/backends/test_backendinit.py
new file mode 100644
index 00000000..b930f99f
--- /dev/null
+++ b/tests/hazmat/backends/test_backendinit.py
@@ -0,0 +1,17 @@
+# This file is dual licensed under the terms of the Apache License, Version
+# 2.0, and the BSD License. See the LICENSE file in the root of this repository
+# for complete details.
+
+from __future__ import absolute_import, division, print_function
+
+from cryptography.hazmat.backends import _backend_import_fallback
+
+
+def test_backend_import_fallback_empty_backends():
+ backends = _backend_import_fallback([])
+ assert len(backends) >= 1
+
+
+def test_backend_import_fallback_existing_backends():
+ backend_list = [1, 2, 3, 4]
+ assert backend_list == _backend_import_fallback(backend_list)