blob: 2042dd97529f62f3a5ad86ee70914f376bf74257 [file] [log] [blame]
Barry Warsaw409a4c02002-04-10 21:01:31 +00001# Copyright (C) 2001,2002 Python Software Foundation
Barry Warsaw3dd978d2001-09-26 05:34:30 +00002# Author: barry@zope.com (Barry Warsaw)
3
4"""Class representing message/* MIME documents.
5"""
6
Barry Warsaw524af6f2002-06-02 19:05:08 +00007from email import Message
8from email.MIMENonMultipart import MIMENonMultipart
Barry Warsaw3dd978d2001-09-26 05:34:30 +00009
10
Barry Warsawe968ead2001-10-04 17:05:11 +000011
Barry Warsaw524af6f2002-06-02 19:05:08 +000012class MIMEMessage(MIMENonMultipart):
Barry Warsaw3dd978d2001-09-26 05:34:30 +000013 """Class representing message/* MIME documents."""
14
15 def __init__(self, _msg, _subtype='rfc822'):
16 """Create a message/* type MIME document.
17
18 _msg is a message object and must be an instance of Message, or a
19 derived class of Message, otherwise a TypeError is raised.
20
21 Optional _subtype defines the subtype of the contained message. The
22 default is "rfc822" (this is defined by the MIME standard, even though
23 the term "rfc822" is technically outdated by RFC 2822).
24 """
Barry Warsaw524af6f2002-06-02 19:05:08 +000025 MIMENonMultipart.__init__(self, 'message', _subtype)
Barry Warsaw3dd978d2001-09-26 05:34:30 +000026 if not isinstance(_msg, Message.Message):
27 raise TypeError, 'Argument is not an instance of Message'
Barry Warsaw524af6f2002-06-02 19:05:08 +000028 # It's convenient to use this base class method. We need to do it
29 # this way or we'll get an exception
30 Message.Message.attach(self, _msg)
Barry Warsawed53bdb2002-07-09 02:40:35 +000031 # And be sure our default type is set correctly
32 self.set_default_type('message/rfc822')