forked from hacktoolkit/django-htk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcompat.py
84 lines (60 loc) · 2.35 KB
/
compat.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# Python Standard Library Imports
import base64
import sys
import uuid
def is_python2():
is_python2 = sys.version_info.major == 2
return is_python2
def is_python3():
is_python3 = sys.version_info.major == 3
return is_python3
def has_min_python_version(major_version, minor_version):
result = sys.version_info.major > major_version or (
sys.version_info.major == major_version
and sys.version_info.minor >= minor_version
)
return result
IS_PYTHON_2 = is_python2()
IS_PYTHON_3 = is_python3()
def b64encode(content, url_safe=False, as_str=True):
"""Base64 encoder with Python 2/3 compatibility
Args:
content: str | unicode (Python 2 only) | bytes (Python 3 only)
url_safe: bool
as_str: bool
When `True` (default), converts the encoded result to a `str` for convenience.
When `False`, the result is preseved as `bytes`
Returns: str if as_str else bytes
"""
encoder = base64.urlsafe_b64encode if url_safe else base64.b64encode
content = (
content.encode()
# Python 3 `base64.b64encode` requires the content to be `bytes`
if (IS_PYTHON_3 and not isinstance(content, bytes))
else content
)
encoded = encoder(content)
# The result of Python 3 `base64.b64encode` is `bytes` but,
# most of the time we want a `str`.
encoded = encoded.decode() if IS_PYTHON_3 and as_str else encoded
return encoded
def b64decode(encoded, url_safe=False, as_str=True):
"""Base64 decoder with Python 2/3 compability
Args:
encoded: str | unicode | bytes
url_safe: bool
as_str: bool
When `True` (default), converts the encoded result to a `str` for convenience.
When `False`, the result is preseved as `bytes`
Returns: str if as_str else bytes
"""
decoder = base64.urlsafe_b64decode if url_safe else base64.b64decode
# `base64.b64decode` can decode either `str` or `bytes`, so no pre-treatment needed
decoded = decoder(encoded)
# The result of Python 3 `base64.b64decode` is `bytes` but,
# most of the time we want a `str`.
decoded = decoded.decode() if IS_PYTHON_3 and as_str else decoded
return decoded
def uuid4_hex():
"""Python 2/3 compatible uuid4() hex generator"""
return uuid.uuid4().hex if IS_PYTHON_3 else uuid.uuid4().get_hex()