37 lines
1.4 KiB
Python
37 lines
1.4 KiB
Python
|
# Copyright (C) 2001-2006 Python Software Foundation
|
||
|
# Author: Barry Warsaw
|
||
|
# Contact: email-sig@python.org
|
||
|
|
||
|
"""Class representing message/* MIME documents."""
|
||
|
from __future__ import unicode_literals
|
||
|
from __future__ import division
|
||
|
from __future__ import absolute_import
|
||
|
|
||
|
__all__ = ['MIMEMessage']
|
||
|
|
||
|
from future.backports.email import message
|
||
|
from future.backports.email.mime.nonmultipart import MIMENonMultipart
|
||
|
|
||
|
|
||
|
class MIMEMessage(MIMENonMultipart):
|
||
|
"""Class representing message/* MIME documents."""
|
||
|
|
||
|
def __init__(self, _msg, _subtype='rfc822'):
|
||
|
"""Create a message/* type MIME document.
|
||
|
|
||
|
_msg is a message object and must be an instance of Message, or a
|
||
|
derived class of Message, otherwise a TypeError is raised.
|
||
|
|
||
|
Optional _subtype defines the subtype of the contained message. The
|
||
|
default is "rfc822" (this is defined by the MIME standard, even though
|
||
|
the term "rfc822" is technically outdated by RFC 2822).
|
||
|
"""
|
||
|
MIMENonMultipart.__init__(self, 'message', _subtype)
|
||
|
if not isinstance(_msg, message.Message):
|
||
|
raise TypeError('Argument is not an instance of Message')
|
||
|
# It's convenient to use this base class method. We need to do it
|
||
|
# this way or we'll get an exception
|
||
|
message.Message.attach(self, _msg)
|
||
|
# And be sure our default type is set correctly
|
||
|
self.set_default_type('message/rfc822')
|