|
|
|
|
|
|
|
|
|
"""Class representing text/* type MIME documents.""" |
|
|
|
__all__ = ['MIMEText'] |
|
|
|
from email.charset import Charset |
|
from email.mime.nonmultipart import MIMENonMultipart |
|
|
|
|
|
|
|
class MIMEText(MIMENonMultipart): |
|
"""Class for generating text/* type MIME documents.""" |
|
|
|
def __init__(self, _text, _subtype='plain', _charset=None, *, policy=None): |
|
"""Create a text/* type MIME document. |
|
|
|
_text is the string for this message object. |
|
|
|
_subtype is the MIME sub content type, defaulting to "plain". |
|
|
|
_charset is the character set parameter added to the Content-Type |
|
header. This defaults to "us-ascii". Note that as a side-effect, the |
|
Content-Transfer-Encoding header will also be set. |
|
""" |
|
|
|
|
|
|
|
|
|
if _charset is None: |
|
try: |
|
_text.encode('us-ascii') |
|
_charset = 'us-ascii' |
|
except UnicodeEncodeError: |
|
_charset = 'utf-8' |
|
|
|
MIMENonMultipart.__init__(self, 'text', _subtype, policy=policy, |
|
**{'charset': str(_charset)}) |
|
|
|
self.set_payload(_text, _charset) |
|
|