mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	[1.0.X] Fixed #9233 -- Allow date and message-id headers to be passed in
manually in email messages. Previously we were creating duplicate headers, which was bad. Backport of r9197 from trunk. I'm calling this a bugfix, since the docs are unclear about which headers you can pass into an EmailMessage constructor. git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.0.X@9198 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -247,7 +247,13 @@ class EmailMessage(object): | |||||||
|         msg['Subject'] = self.subject |         msg['Subject'] = self.subject | ||||||
|         msg['From'] = self.from_email |         msg['From'] = self.from_email | ||||||
|         msg['To'] = ', '.join(self.to) |         msg['To'] = ', '.join(self.to) | ||||||
|  |  | ||||||
|  |         # Email header names are case-insensitive (RFC 2045), so we have to | ||||||
|  |         # accommodate that when doing comparisons. | ||||||
|  |         header_names = [key.lower() for key in self.extra_headers] | ||||||
|  |         if 'date' not in header_names: | ||||||
|             msg['Date'] = formatdate() |             msg['Date'] = formatdate() | ||||||
|  |         if 'message-id' not in header_names: | ||||||
|             msg['Message-ID'] = make_msgid() |             msg['Message-ID'] = make_msgid() | ||||||
|         for name, value in self.extra_headers.items(): |         for name, value in self.extra_headers.items(): | ||||||
|             msg[name] = value |             msg[name] = value | ||||||
|   | |||||||
| @@ -52,4 +52,12 @@ BadHeaderError: Header values can't contain newlines (got u'Subject\nInjection T | |||||||
| >>> message.as_string() | >>> message.as_string() | ||||||
| 'Content-Type: text/plain; charset="utf-8"\nMIME-Version: 1.0\nContent-Transfer-Encoding: quoted-printable\nSubject: Long subject lines that get wrapped should use a space continuation\n character to get expected behaviour in Outlook and Thunderbird\nFrom: from@example.com\nTo: to@example.com\nDate: ...\nMessage-ID: <...>\n\nContent' | 'Content-Type: text/plain; charset="utf-8"\nMIME-Version: 1.0\nContent-Transfer-Encoding: quoted-printable\nSubject: Long subject lines that get wrapped should use a space continuation\n character to get expected behaviour in Outlook and Thunderbird\nFrom: from@example.com\nTo: to@example.com\nDate: ...\nMessage-ID: <...>\n\nContent' | ||||||
|  |  | ||||||
|  | # Specifying dates or message-ids in the extra headers overrides the defaul | ||||||
|  | # values (#9233). | ||||||
|  |  | ||||||
|  | >>> headers = {"date": "Fri, 09 Nov 2001 01:08:47 -0000", "Message-ID": "foo"} | ||||||
|  | >>> email = EmailMessage('subject', 'content', 'from@example.com', ['to@example.com'], headers=headers) | ||||||
|  | >>> email.message().as_string() | ||||||
|  | 'Content-Type: text/plain; charset="utf-8"\nMIME-Version: 1.0\nContent-Transfer-Encoding: quoted-printable\nSubject: subject\nFrom: from@example.com\nTo: to@example.com\ndate: Fri, 09 Nov 2001 01:08:47 -0000\nMessage-ID: foo\n\ncontent' | ||||||
|  |  | ||||||
| """ | """ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user