Commit 0f111c13 authored by R David Murray's avatar R David Murray

#15232: correctly mangle From lines in MIME preamble and epilogue

parent ea2ce479
...@@ -212,7 +212,11 @@ class Generator: ...@@ -212,7 +212,11 @@ class Generator:
msg.set_boundary(boundary) msg.set_boundary(boundary)
# If there's a preamble, write it out, with a trailing CRLF # If there's a preamble, write it out, with a trailing CRLF
if msg.preamble is not None: if msg.preamble is not None:
print >> self._fp, msg.preamble if self._mangle_from_:
preamble = fcre.sub('>From ', msg.preamble)
else:
preamble = msg.preamble
print >> self._fp, preamble
# dash-boundary transport-padding CRLF # dash-boundary transport-padding CRLF
print >> self._fp, '--' + boundary print >> self._fp, '--' + boundary
# body-part # body-part
...@@ -230,7 +234,11 @@ class Generator: ...@@ -230,7 +234,11 @@ class Generator:
self._fp.write('\n--' + boundary + '--') self._fp.write('\n--' + boundary + '--')
if msg.epilogue is not None: if msg.epilogue is not None:
print >> self._fp print >> self._fp
self._fp.write(msg.epilogue) if self._mangle_from_:
epilogue = fcre.sub('>From ', msg.epilogue)
else:
epilogue = msg.epilogue
self._fp.write(epilogue)
def _handle_multipart_signed(self, msg): def _handle_multipart_signed(self, msg):
# The contents of signed parts has to stay unmodified in order to keep # The contents of signed parts has to stay unmodified in order to keep
......
...@@ -9,6 +9,7 @@ import base64 ...@@ -9,6 +9,7 @@ import base64
import difflib import difflib
import unittest import unittest
import warnings import warnings
import textwrap
from cStringIO import StringIO from cStringIO import StringIO
import email import email
...@@ -948,6 +949,28 @@ From the desk of A.A.A.: ...@@ -948,6 +949,28 @@ From the desk of A.A.A.:
Blah blah blah Blah blah blah
""") """)
def test_mangle_from_in_preamble_and_epilog(self):
s = StringIO()
g = Generator(s, mangle_from_=True)
msg = email.message_from_string(textwrap.dedent("""\
From: foo@bar.com
Mime-Version: 1.0
Content-Type: multipart/mixed; boundary=XXX
From somewhere unknown
--XXX
Content-Type: text/plain
foo
--XXX--
From somewhere unknowable
"""))
g.flatten(msg)
self.assertEqual(len([1 for x in s.getvalue().split('\n')
if x.startswith('>From ')]), 2)
# Test the basic MIMEAudio class # Test the basic MIMEAudio class
......
...@@ -90,6 +90,9 @@ Core and Builtins ...@@ -90,6 +90,9 @@ Core and Builtins
Library Library
------- -------
- Issue #15232: when mangle_from is True, email.Generator now correctly mangles
lines that start with 'From' that occur in a MIME preamble or epilog.
- Issue #13922: argparse no longer incorrectly strips '--'s that appear - Issue #13922: argparse no longer incorrectly strips '--'s that appear
after the first one. after the first one.
......
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