Description :
Email::MIME::Kit is a templating system for email messages. Instead of trying to be yet another templating system for chunks of text, it makes it easy to build complete email messages.
It handles the construction of multipart messages, text and HTML alternatives, attachments, interpart linking, string encoding, and parameter validation.
Although nearly every part of Email::MIME::Kit is a replaceable component, the stock configuration is probably enough for most use. A message kit will be stored as a directory that might look like this:
sample.mkit/ manifest.json body.txt body.html logo.jpg
The manifest file tells Email::MIME::Kit how to put it all together, and might look something like this:
{ \"renderer\": \"TT\", \"header\": [ { \"From\": \"WY Corp < norepliesAATTwy.example.com>\" }, { \"Subject\": \"Welcome aboard, [% recruit.name %]!\" } ], \"alternatives\": [ { \"type\": \"text/plain\", \"path\": \"body.txt\" }, { \"type\": \"text/html\", \"path\": \"body.html\", \"container_type\": \"multipart/related\", \"attachments\": [ { \"type\": \"image/jpeg\", \"path\": \"logo.jpg\" } ] } ] }
*Inline images* may be accessed with the function \'cid_for\', for example to include the above logo.jpg:
< img style=\"margin: 0 auto\" src=\"cid:[% cid_for(\"logo.jpg\") %]\">
*Please note:* the assembly of HTML documents as multipart/related bodies may be simplified with an alternate assembler in the future.
The above manifest would build a multipart alternative message. GUI mail clients would see a rendered HTML document with the logo graphic visible from the attachment. Text mail clients would see the plaintext.
Both the HTML and text parts would be rendered using the named renderer, which here is Template-Toolkit.
The message would be assembled and returned as an Email::MIME object, just as easily as suggested in the SYNOPSIS above.
|