summaryrefslogtreecommitdiff
path: root/Lib/email/generator.py
diff options
context:
space:
mode:
authorR. David Murray <rdmurray@bitdance.com>2010-01-16 16:32:39 +0000
committerR. David Murray <rdmurray@bitdance.com>2010-01-16 16:32:39 +0000
commit3cc6191ecdafecdad2d724053ec95fd5ccbe8dab (patch)
tree55dbf713b5efd0d3f89bdd8efcaf7a6852d4e943 /Lib/email/generator.py
parentb9ba2bb6855db373baef83993abbcd2965ff10ce (diff)
downloadcpython-git-3cc6191ecdafecdad2d724053ec95fd5ccbe8dab.tar.gz
Merged revisions 77517,77525 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r77517 | r.david.murray | 2010-01-16 00:15:17 -0500 (Sat, 16 Jan 2010) | 6 lines Issue #1670765: Prevent email.generator.Generator from re-wrapping headers in multipart/signed MIME parts, which fixes one of the sources of invalid modifications to such parts by Generator. Patch and tests by Martin von Gagern. ........ r77525 | r.david.murray | 2010-01-16 11:08:32 -0500 (Sat, 16 Jan 2010) | 2 lines Fix issue number in comment. ........
Diffstat (limited to 'Lib/email/generator.py')
-rw-r--r--Lib/email/generator.py11
1 files changed, 11 insertions, 0 deletions
diff --git a/Lib/email/generator.py b/Lib/email/generator.py
index ed832a3e9a..ba3ccd8988 100644
--- a/Lib/email/generator.py
+++ b/Lib/email/generator.py
@@ -235,6 +235,17 @@ class Generator:
print >> self._fp
self._fp.write(msg.epilogue)
+ def _handle_multipart_signed(self, msg):
+ # The contents of signed parts has to stay unmodified in order to keep
+ # the signature intact per RFC1847 2.1, so we disable header wrapping.
+ # RDM: This isn't enough to completely preserve the part, but it helps.
+ old_maxheaderlen = self._maxheaderlen
+ try:
+ self._maxheaderlen = 0
+ self._handle_multipart(msg)
+ finally:
+ self._maxheaderlen = old_maxheaderlen
+
def _handle_message_delivery_status(self, msg):
# We can't just write the headers directly to self's file object
# because this will leave an extra newline between the last header