email.contentmanager: Managing MIME Content¶
Code source : Lib/email/contentmanager.py
Ajouté dans la version 3.6: [1]
- class email.contentmanager.ContentManager¶
Classe mère pour les gestionnaires de contenu. Fournit les mécanismes de registre standard pour enregistrer les convertisseurs entre le contenu MIME et d'autres représentations, ainsi que les méthodes de répartition
get_contentetset_content.- get_content(msg, *args, **kw)¶
Recherche une fonction de gestion en se basant sur le
mimetypede msg (voir le paragraphe suivant), l'appelle en lui passant tous les arguments et renvoie le résultat de l'appel. Le gestionnaire doit extraire la charge utile de msg et renvoyer un objet qui encode les informations relatives aux données extraites.Pour trouver le gestionnaire, recherche les clés suivantes dans le registre, en s'arrêtant à la première trouvée :
une chaîne représentant le type MIME complet (
maintype/subtype) ;une chaîne représentant le
maintype;une chaîne vide.
Si aucune de ces clés ne produit de gestionnaire, lève une
KeyErrorpour le type MIME complet.
- set_content(msg, obj, *args, **kw)¶
Si le
maintypeestmultipart, lève uneTypeError; sinon recherche une fonction de gestion en se basant sur le type de obj (voir le paragraphe suivant), appelleclear_content()sur le msg et appelle la fonction de gestion en lui passant tous les arguments. Le gestionnaire doit transformer et stocker obj en msg, apportant éventuellement d'autres modifications à msg également, comme l'ajout de divers en-têtes MIME pour coder les informations nécessaires à l'interprétation des données stockées.Pour trouver le gestionnaire, récupère le type de obj (
typ = type(obj)) et recherche les clés suivantes dans le registre, en s'arrêtant à la première trouvée :le type lui-même (
typ) ;le nom complet du type (
typ.__module__ + '.' + typ.__qualname__) ;the type's
qualname(typ.__qualname__)the type's
name(typ.__name__).
If none of the above match, repeat all of the checks above for each of the types in the MRO (
typ.__mro__). Finally, if no other key yields a handler, check for a handler for the keyNone. If there is no handler forNone, raise aKeyErrorfor the fully qualified name of the type.Ajoute également un en-tête MIME-Version s'il n'y en a pas (voir aussi
MIMEPart).
- add_get_handler(key, handler)¶
Enregistre la fonction handler comme gestionnaire pour key. Pour les valeurs possibles de key, voir
get_content().
- add_set_handler(typekey, handler)¶
Enregistre handler comme fonction à appeler lorsqu'un objet d'un type correspondant à typekey est passé à
set_content(). Pour les valeurs possibles de typekey, voirset_content().
Instances de gestionnaires de contenus¶
Actuellement, le paquet email ne fournit qu'un seul gestionnaire de contenu concret, raw_data_manager, bien que d'autres puissent être ajoutés à l'avenir. raw_data_manager est le content_manager fourni par EmailPolicy et ses dérivés.
- email.contentmanager.raw_data_manager¶
Ce gestionnaire de contenu ne fournit qu'une interface minimale au-delà de celle fournie par
Messagelui-même : il prend seulement en charge le texte, les chaînes d'octets brutes et les objetsMessage. Néanmoins, il offre des avantages significatifs par rapport à l'API de base :get_contentsur une partie de texte renvoie une chaîne Unicode sans que l'application ait besoin de la décoder manuellement,set_contentfournit de nombreuses options pour contrôler les en-têtes ajoutés à une partie et l'encodage du transfert de contenu, et il permet l'utilisation des différentes méthodesadd_, ce qui simplifie la création de messages en plusieurs parties.- email.contentmanager.get_content(msg, errors='replace')¶
Renvoie la charge utile de la partie sous la forme d'une chaîne (pour les parties
text), d'un objetEmailMessage(pour les partiesmessage/rfc822) ou d'un objetbytes(pour tous les autres types à l'exception de multipart). Lève uneKeyErrorsi cette méthode est appelée sur unmultipart. S'il s'agit d'une partietextet que errors est spécifié, ce paramètre est utilisé comme gestionnaire d'erreurs lors du décodage de la charge utile en Unicode. Le gestionnaire d'erreurs par défaut estreplace.
- email.contentmanager.set_content(msg, <'str'>, subtype="plain", charset='utf-8', cte=None, disposition=None, filename=None, cid=None, params=None, headers=None)¶
- email.contentmanager.set_content(msg, <'bytes'>, maintype, subtype, cte="base64", disposition=None, filename=None, cid=None, params=None, headers=None)
- email.contentmanager.set_content(msg, <'EmailMessage'>, cte=None, disposition=None, filename=None, cid=None, params=None, headers=None)
Ajoute des en-têtes et une charge utile à msg :
Ajoute un en-tête Content-Type avec une valeur
maintype/subtype.Pour
str, définit lemaintypeMIME àtextet définit le sous-type à subtype s'il est spécifié, ou àplains'il ne l'est pas.Pour
bytes, utilise les maintype et subtype spécifiés, ou lève uneTypeErrors'ils ne sont pas spécifiés.Pour les objets
EmailMessage, définit le type principal (maintype) àmessageet définit le sous-type à subtype s'il est spécifié ou àrfc822s'il ne l'est pas. Si subtype estpartial, lève une erreur (les objetsbytesdoivent être utilisés pour construire les partiesmessage/partial).
Si charset est fourni (qui n'est valide que pour
str), encode la chaîne en octets en utilisant le jeu de caractères spécifié. La valeur par défaut estutf-8. Si le charset spécifié est un alias connu pour un nom de jeu de caractères MIME standard, utilise plutôt le jeu de caractères standard.Si cte est défini, encode la charge utile à l'aide de l'encodage de transfert de contenu spécifié et définit l'en-tête Content-Transfer-Encoding à cette valeur. Les valeurs possibles pour cte sont
quoted-printable,base64,7bit,8bitetbinary. Si l'entrée ne peut pas être encodée dans l'encodage spécifié (par exemple, en spécifiant un cte de7bitpour une entrée qui contient des valeurs non-ASCII), lève uneValueError.For
strobjects, if cte is not set use heuristics to determine the most compact encoding. Prior to encoding,str.splitlines()is used to normalize all line boundaries, ensuring that each line of the payload is terminated by the current policy'slinesepproperty (even if the original string did not end with one).For
bytesobjects, cte is taken to be base64 if not set, and the aforementioned newline translation is not performed.Pour
EmailMessage, selon la RFC 2046, pour le subtyperfc822, lève une erreur pour un cte valantquoted-printableoubase64. Pour le subtypeexternal-body, lève une erreur pour tout cte autre que7bit. Pourmessage/rfc822, la valeur par défaut de cte est8bit. Pour toutes les autres valeurs de sous-type, la valeur par défaut de cte est7bit.
Note
la valeur
binarypour cte ne fonctionne pas encore correctement. L'objetEmailMessagetel que modifié parset_contentest correct, maisBytesGeneratorne le sérialise pas correctement.Si disposition est spécifié, utilise cette valeur pour l'en-tête Content-Disposition. S'il n'est pas spécifié et que filename est spécifié, utilise la valeur
attachmentpour l'en-tête. Si ni disposition ni filename ne sont spécifiés, n'ajoute pas cet en-tête. Les seules valeurs valides pour disposition sontattachmentetinline.Si filename est spécifié, utilise cette valeur pour le paramètre
filenamede l'en-tête Content-Disposition.Si cid est spécifié, ajoute un en-tête Content-ID avec cette valeur.
Si params est spécifié, itère sur sa méthode
itemset utilise les paires(clé, valeur)résultantes pour définir des paramètres supplémentaires dans l'en-tête Content-Type.Si headers est spécifié et est une liste de chaînes de la forme
headername: headervalueou une liste d'objetsheader(distingués des chaînes par l'attributname), ajoute ces en-têtes à msg.
Notes