Commit aa797072 authored by Abhilash Raj's avatar Abhilash Raj Committed by Barry Warsaw

bpo-30835: email: Fix AttributeError when parsing invalid CTE (GH-13598)

* bpo-30835: email: Fix AttributeError when parsing invalid Content-Transfer-Encoding

Parsing an email containing a multipart Content-Type, along with a
Content-Transfer-Encoding containing an invalid (non-ASCII-decodable) byte
will fail. email.feedparser.FeedParser._parsegen() gets the header and
attempts to convert it to lowercase before comparing it with the accepted
encodings, but as the header contains an invalid byte, it's returned as a
Header object rather than a str.

Cast the Content-Transfer-Encoding header to a str to avoid this.

Found using the AFL fuzzer.
Reported-by: default avatarDaniel Axtens <dja@axtens.net>
Signed-off-by: default avatarAndrew Donnellan <andrew@donnellan.id.au>

* Add email and NEWS entry for the bugfix.
parent 46d88a11
...@@ -320,7 +320,7 @@ class FeedParser: ...@@ -320,7 +320,7 @@ class FeedParser:
self._cur.set_payload(EMPTYSTRING.join(lines)) self._cur.set_payload(EMPTYSTRING.join(lines))
return return
# Make sure a valid content type was specified per RFC 2045:6.4. # Make sure a valid content type was specified per RFC 2045:6.4.
if (self._cur.get('content-transfer-encoding', '8bit').lower() if (str(self._cur.get('content-transfer-encoding', '8bit')).lower()
not in ('7bit', '8bit', 'binary')): not in ('7bit', '8bit', 'binary')):
defect = errors.InvalidMultipartContentTransferEncodingDefect() defect = errors.InvalidMultipartContentTransferEncodingDefect()
self.policy.handle_defect(self._cur, defect) self.policy.handle_defect(self._cur, defect)
......
...@@ -1466,6 +1466,15 @@ Blah blah blah ...@@ -1466,6 +1466,15 @@ Blah blah blah
g.flatten(msg) g.flatten(msg)
self.assertEqual(b.getvalue(), source + b'>From R\xc3\xb6lli\n') self.assertEqual(b.getvalue(), source + b'>From R\xc3\xb6lli\n')
def test_mutltipart_with_bad_bytes_in_cte(self):
# bpo30835
source = textwrap.dedent("""\
From: aperson@example.com
Content-Type: multipart/mixed; boundary="1"
Content-Transfer-Encoding: \xc8
""").encode('utf-8')
msg = email.message_from_bytes(source)
# Test the basic MIMEAudio class # Test the basic MIMEAudio class
class TestMIMEAudio(unittest.TestCase): class TestMIMEAudio(unittest.TestCase):
......
Fixed a bug in email parsing where a message with invalid bytes in
content-transfer-encoding of a multipart message can cause an AttributeError.
Patch by Andrew Donnellan.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment