"email" --- Un paquete de manejo de correo electrónico y MIME
*************************************************************

**Código fuente** Lib/email/__init__.py

======================================================================

The "email" package is a library for managing email messages.  It is
specifically *not* designed to do any sending of email messages to
SMTP (**RFC 2821**), NNTP, or other servers; those are functions of
modules such as "smtplib" and "nntplib".  The "email" package attempts
to be as RFC-compliant as possible, supporting **RFC 5322** and **RFC
6532**, as well as such MIME-related RFCs as **RFC 2045**, **RFC
2046**, **RFC 2047**, **RFC 2183**, and **RFC 2231**.

La estructura general del paquete de correo electrónico se puede
dividir en tres componentes principales, más un cuarto componente que
controla el comportamiento de los otros componentes.

El componente central del paquete es un "modelo de objetos" que
representa los mensajes de correo electrónico. Una aplicación
interactúa con el paquete principalmente a través de la interfaz del
modelo de objetos definida en el submódulo "message". La aplicación
puede usar esta API para hacer preguntas sobre un correo electrónico
existente, para construir un nuevo correo electrónico o para agregar o
eliminar subcomponentes de correo electrónico que utilizan la misma
interfaz de modelo de objetos. Es decir, siguiendo la naturaleza de
los mensajes de correo electrónico y sus subcomponentes MIME, el
modelo de objetos de correo electrónico es una estructura de árbol de
objetos que proporcionan la API "EmailMessage".

Los otros dos componentes principales del paquete son "parser" y
"generator". El parser toma la versión serializada de un mensaje de
correo electrónico (una secuencia de bytes) Y la convierte en un árbol
de objetos "EmailMessage". El generador toma un "EmailMessage" y lo
convierte de nuevo en un flujo de bytes serializado. (El analizador y
el generador también manejan flujos de caracteres de texto, pero se
desaconseja este uso ya que es demasiado fácil terminar con mensajes
que no son válidos de una forma u otra).

El componente de control es el módulo de "policy". Cada "EmailMessage"
cada "generator", y cada "parser" tiene un objeto de "policy" asociado
que controla su comportamiento. Por lo general, una aplicación solo
necesita especificar la política cuando se crea un "EmailMessage" , ya
sea instanciando directamente un "EmailMessage" para crear un nuevo
correo electrónico o analizando un flujo de entrada con un "parser".
Pero la política se puede cambiar cuando el mensaje se serializa
mediante un "generator". Esto permite, por ejemplo, analizar un
mensaje de correo electrónico genérico desde el disco, pero
serializarlo utilizando la configuración estándar de SMTP al enviarlo
a un servidor de correo electrónico.

El paquete de correo electrónico hace todo lo posible para ocultar los
detalles de las diversas RFC que rigen de la aplicación.
Conceptualmente, la aplicación debería poder tratar el mensaje de
correo electrónico como un árbol estructurado de texto Unicode y
archivos adjuntos binarios, sin tener que preocuparse por cómo se
representan estos cuando se serializan. En la práctica, sin embargo, a
menudo es necesario conocer al menos algunas de las reglas que rigen
los mensajes MIME y su estructura, específicamente los nombres y la
naturaleza de los «tipos de contenido» MIME y cómo identifican los
documentos de varias partes. En su mayor parte, este conocimiento solo
debería ser necesario para aplicaciones más complejas, e incluso
entonces debería ser solo la estructura de alto nivel en cuestión, y
no los detalles de cómo se representan esas estructuras. Dado que los
tipos de contenido MIME se utilizan ampliamente en el software moderno
de Internet (no solo en el correo electrónico), este será un concepto
familiar para muchos programadores.

Las siguientes secciones describen la funcionalidad del paquete
"email". Comenzamos con el modelo de objetos "message", que es la
interfaz principal que usará una aplicación, y lo seguimos con los
componentes del "parser" y "generator" . Luego cubrimos los controles
de la "policy", lo que completa el tratamiento de los principales
componentes de la biblioteca.

Las siguientes tres secciones cubren las excepciones que puede generar
el paquete y los defectos (incumplimiento de las RFC) que el "parser"
puede detectar. Luego cubrimos los subcomponentes "headerregistry" y
"contentmanager", que proporcionan herramientas para realizar una
manipulación más detallada de los encabezados y cargas útiles,
respectivamente. Ambos componentes contienen características
relevantes para consumir y producir mensajes no triviales, pero
también documentan sus API de extensibilidad, que serán de interés
para aplicaciones avanzadas.

A continuación, se muestra un conjunto de ejemplos del uso de las
partes fundamentales de las API cubiertas en las secciones anteriores.

Lo anterior representa la API moderna (compatible con Unicode) del
paquete de correo electrónico. Las secciones restantes, comenzando con
la clase "Message", cubren la API "compat32" heredada que trata mucho
más directamente con los detalles de cómo se representan los mensajes
de correo electrónico. La API "compat32" no oculta los detalles de las
RFC de la aplicación, pero para las aplicaciones que necesitan operar
a ese nivel, pueden ser herramientas útiles. Esta documentación
también es relevante para las aplicaciones que todavía usan la API
"compat32" por razones de compatibilidad con versiones anteriores.

Distinto en la versión 3.6: Documentos reorganizados y reescritos para
promover la nueva API "EmailMessage"/"EmailPolicy".

Contenido de la documentación del paquete "email":

* "email.message": Representando un mensaje de correo electrónico

* "email.parser": Analizar mensajes de correo electrónico

  * API *FeedParser*

  * API *Parser*

  * Notas adicionales

* "email.generator": Generando documentos MIME

* "email.policy": Objetos *Policy*

* "email.errors": Clases de excepción y defecto

* "email.headerregistry": Objetos de encabezado personalizados

* "email.contentmanager": Gestión de contenido MIME

  * Instancias gestoras de contenido

* "email": Ejemplos

API heredada:

* "email.message.Message": Representar un mensaje de correo
  electrónico usando la API "compat32"

* "email.mime": Creación de correo electrónico y objetos MIME desde
  cero

* "email.header": Cabeceras internacionalizadas

* "email.charset":  Representa conjunto de caracteres

* "email.encoders": Codificadores

* "email.utils": Utilidades misceláneas

* "email.iterators": Iteradores

Ver también:

  Módulo "smtplib"
     Cliente SMTP (Protocolo simple de transporte de correo)

  Módulo "poplib"
     Cliente POP (Protocolo de oficina postal)

  Módulo "imaplib"
     Cliente IMAP (Protocolo de acceso a mensajes de Internet)

  Módulo "nntplib"
     Cliente NNTP (Protocolo de transporte de noticias de red)

  Módulo "mailbox"
     Herramientas para crear, leer y administrar colecciones de
     mensajes en disco utilizando una variedad de formatos estándar.

  Módulo "smtpd"
     Marco del servidor SMTP (principalmente útil para pruebas)
