golden hour
/usr/lib/python2.7/site-packages/future/backports/email
⬆️ Go Up
Upload
File/Folder
Size
Actions
__init__.py
2.22 KB
Del
OK
__init__.pyc
2.57 KB
Del
OK
__init__.pyo
2.57 KB
Del
OK
_encoded_words.py
8.25 KB
Del
OK
_encoded_words.pyc
7.69 KB
Del
OK
_encoded_words.pyo
7.69 KB
Del
OK
_header_value_parser.py
102.24 KB
Del
OK
_header_value_parser.pyc
101.73 KB
Del
OK
_header_value_parser.pyo
101.67 KB
Del
OK
_parseaddr.py
16.98 KB
Del
OK
_parseaddr.pyc
15.74 KB
Del
OK
_parseaddr.pyo
15.74 KB
Del
OK
_policybase.py
14.3 KB
Del
OK
_policybase.pyc
16.41 KB
Del
OK
_policybase.pyo
16.41 KB
Del
OK
base64mime.py
3.64 KB
Del
OK
base64mime.pyc
4.04 KB
Del
OK
base64mime.pyo
4.04 KB
Del
OK
charset.py
17.03 KB
Del
OK
charset.pyc
13.57 KB
Del
OK
charset.pyo
13.52 KB
Del
OK
encoders.py
2.73 KB
Del
OK
encoders.pyc
2.9 KB
Del
OK
encoders.pyo
2.9 KB
Del
OK
errors.py
3.59 KB
Del
OK
errors.pyc
7.81 KB
Del
OK
errors.pyo
7.81 KB
Del
OK
feedparser.py
22.2 KB
Del
OK
feedparser.pyc
13.29 KB
Del
OK
feedparser.pyo
13.12 KB
Del
OK
generator.py
19.06 KB
Del
OK
generator.pyc
14.5 KB
Del
OK
generator.pyo
14.5 KB
Del
OK
header.py
23.88 KB
Del
OK
header.pyc
20.03 KB
Del
OK
header.pyo
20.03 KB
Del
OK
headerregistry.py
20.15 KB
Del
OK
headerregistry.pyc
26.04 KB
Del
OK
headerregistry.pyo
25.98 KB
Del
OK
iterators.py
2.29 KB
Del
OK
iterators.pyc
2.73 KB
Del
OK
iterators.pyo
2.73 KB
Del
OK
message.py
34.41 KB
Del
OK
message.pyc
32.09 KB
Del
OK
message.pyo
32.09 KB
Del
OK
mime
-
Del
OK
parser.py
5.19 KB
Del
OK
parser.pyc
7.02 KB
Del
OK
parser.pyo
7.02 KB
Del
OK
policy.py
8.62 KB
Del
OK
policy.pyc
9.17 KB
Del
OK
policy.pyo
9.17 KB
Del
OK
quoprimime.py
10.67 KB
Del
OK
quoprimime.pyc
11.25 KB
Del
OK
quoprimime.pyo
11.25 KB
Del
OK
utils.py
13.94 KB
Del
OK
utils.pyc
12.86 KB
Del
OK
utils.pyo
12.86 KB
Del
OK
Edit: base64mime.py
# Copyright (C) 2002-2007 Python Software Foundation # Author: Ben Gertzfield # Contact: email-sig@python.org """Base64 content transfer encoding per RFCs 2045-2047. This module handles the content transfer encoding method defined in RFC 2045 to encode arbitrary 8-bit data using the three 8-bit bytes in four 7-bit characters encoding known as Base64. It is used in the MIME standards for email to attach images, audio, and text using some 8-bit character sets to messages. This module provides an interface to encode and decode both headers and bodies with Base64 encoding. RFC 2045 defines a method for including character set information in an `encoded-word' in a header. This method is commonly used for 8-bit real names in To:, From:, Cc:, etc. fields, as well as Subject: lines. This module does not do the line wrapping or end-of-line character conversion necessary for proper internationalized headers; it only does dumb encoding and decoding. To deal with the various line wrapping issues, use the email.header module. """ from __future__ import unicode_literals from __future__ import division from __future__ import absolute_import from future.builtins import range from future.builtins import bytes __all__ = [ 'body_decode', 'body_encode', 'decode', 'decodestring', 'header_encode', 'header_length', ] from base64 import b64encode from binascii import b2a_base64, a2b_base64 CRLF = '\r\n' NL = '\n' EMPTYSTRING = '' # See also Charset.py MISC_LEN = 7 # Helpers def header_length(bytearray): """Return the length of s when it is encoded with base64.""" groups_of_3, leftover = divmod(len(bytearray), 3) # 4 bytes out for each 3 bytes (or nonzero fraction thereof) in. n = groups_of_3 * 4 if leftover: n += 4 return n def header_encode(header_bytes, charset='iso-8859-1'): """Encode a single header line with Base64 encoding in a given charset. charset names the character set to use to encode the header. It defaults to iso-8859-1. Base64 encoding is defined in RFC 2045. """ if not header_bytes: return "" if isinstance(header_bytes, str): header_bytes = header_bytes.encode(charset) encoded = b64encode(header_bytes).decode("ascii") return '=?%s?b?%s?=' % (charset, encoded) def body_encode(s, maxlinelen=76, eol=NL): r"""Encode a string with base64. Each line will be wrapped at, at most, maxlinelen characters (defaults to 76 characters). Each line of encoded text will end with eol, which defaults to "\n". Set this to "\r\n" if you will be using the result of this function directly in an email. """ if not s: return s encvec = [] max_unencoded = maxlinelen * 3 // 4 for i in range(0, len(s), max_unencoded): # BAW: should encode() inherit b2a_base64()'s dubious behavior in # adding a newline to the encoded string? enc = b2a_base64(s[i:i + max_unencoded]).decode("ascii") if enc.endswith(NL) and eol != NL: enc = enc[:-1] + eol encvec.append(enc) return EMPTYSTRING.join(encvec) def decode(string): """Decode a raw base64 string, returning a bytes object. This function does not parse a full MIME header value encoded with base64 (like =?iso-8895-1?b?bmloISBuaWgh?=) -- please use the high level email.header class for that functionality. """ if not string: return bytes() elif isinstance(string, str): return a2b_base64(string.encode('raw-unicode-escape')) else: return a2b_base64(string) # For convenience and backwards compatibility w/ standard base64 module body_decode = decode decodestring = decode
Save