Barry Warsaw | 40ef006 | 2006-03-18 15:41:53 +0000 | [diff] [blame] | 1 | # Copyright (C) 2002-2006 Python Software Foundation |
Barry Warsaw | bb11386 | 2004-10-03 03:16:19 +0000 | [diff] [blame] | 2 | # Author: Barry Warsaw |
| 3 | # Contact: email-sig@python.org |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 4 | |
Barry Warsaw | bb11386 | 2004-10-03 03:16:19 +0000 | [diff] [blame] | 5 | """Base class for MIME multipart/* type messages.""" |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 6 | |
Barry Warsaw | 40ef006 | 2006-03-18 15:41:53 +0000 | [diff] [blame] | 7 | __all__ = ['MIMEMultipart'] |
| 8 | |
| 9 | from email.mime.base import MIMEBase |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 10 | |
| 11 | |
| 12 | |
Barry Warsaw | 40ef006 | 2006-03-18 15:41:53 +0000 | [diff] [blame] | 13 | class MIMEMultipart(MIMEBase): |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 14 | """Base class for MIME multipart/* type messages.""" |
| 15 | |
Barry Warsaw | d285600 | 2004-05-09 18:04:24 +0000 | [diff] [blame] | 16 | def __init__(self, _subtype='mixed', boundary=None, _subparts=None, |
| 17 | **_params): |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 18 | """Creates a multipart/* type message. |
| 19 | |
| 20 | By default, creates a multipart/mixed message, with proper |
Barry Warsaw | fd2e8f7 | 2002-09-30 21:24:00 +0000 | [diff] [blame] | 21 | Content-Type and MIME-Version headers. |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 22 | |
| 23 | _subtype is the subtype of the multipart content type, defaulting to |
| 24 | `mixed'. |
| 25 | |
| 26 | boundary is the multipart boundary string. By default it is |
| 27 | calculated as needed. |
| 28 | |
Barry Warsaw | fd2e8f7 | 2002-09-30 21:24:00 +0000 | [diff] [blame] | 29 | _subparts is a sequence of initial subparts for the payload. It |
Barry Warsaw | d285600 | 2004-05-09 18:04:24 +0000 | [diff] [blame] | 30 | must be an iterable object, such as a list. You can always |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 31 | attach new subparts to the message by using the attach() method. |
| 32 | |
Barry Warsaw | fd2e8f7 | 2002-09-30 21:24:00 +0000 | [diff] [blame] | 33 | Additional parameters for the Content-Type header are taken from the |
Barry Warsaw | 2f514a8 | 2002-06-01 05:59:12 +0000 | [diff] [blame] | 34 | keyword arguments (or passed into the _params argument). |
| 35 | """ |
Barry Warsaw | 40ef006 | 2006-03-18 15:41:53 +0000 | [diff] [blame] | 36 | MIMEBase.__init__(self, 'multipart', _subtype, **_params) |
Facundo Batista | 2b1b195 | 2008-01-19 12:32:27 +0000 | [diff] [blame] | 37 | |
| 38 | # Initialise _payload to an empty list as the Message superclass's |
| 39 | # implementation of is_multipart assumes that _payload is a list for |
| 40 | # multipart messages. |
| 41 | self._payload = [] |
| 42 | |
Barry Warsaw | bb493a7 | 2002-07-09 02:44:26 +0000 | [diff] [blame] | 43 | if _subparts: |
Barry Warsaw | d285600 | 2004-05-09 18:04:24 +0000 | [diff] [blame] | 44 | for p in _subparts: |
| 45 | self.attach(p) |
Barry Warsaw | bb493a7 | 2002-07-09 02:44:26 +0000 | [diff] [blame] | 46 | if boundary: |
| 47 | self.set_boundary(boundary) |