Feature #64047
closedextbase mail wrapper for core mail; ActionMailer
0%
Description
The current way to go when implementing mail delivery in an extbase extension seems to be http://wiki.typo3.org/How_to_use_the_Fluid_Standalone_view_to_render_template_based_emails. Peeking at out ActionController, extbase could provide the same architecture for looking up and rendering mails.
I'm just throwing my idea in here with a bit of pseudo-code, as this may explain things better than when writing it out. IMHO this would help extension developers to concentrate on building their extension and spare a lot of time writing / copy-pasting code to handle mail deliveries.
File structure
typo3conf/ext/<myext> - Classes - Mailer - MyMailer.php - Resources - Private - Templates - MyMailer
MyMailer.php
class MyMailer extends \TYPO3\CMS\Extbase\Mailer\ActionMailer { public function welcomeUserMail($user) { /** @var \TYPO3\Core\Mail\Message */ $mail = $this->createMail(); /* * ActionMailer base class sets layout and template automagically * based on the current controller name and action name; This e.g. would be * * $templateRootPath/@MailerClassName/@MailerMethodName.html * * The only thing you actually do in here is set / assign data, similiar to the controller. */ $mail->setTo($user->getEmail()); $mail->setSubject('Successfully signed up!'); $mail->assign('user', $user); // Exposed to the fluid standalone view return $mail->send(); } }
MyController.php
public function confirmationAction() { // ... creating $user ... $mailer = makeInstance('MyMailer'); // or maybe instantiate it through DI's @inject? $mailer->welcomeUserMail($user); }
Updated by Pascal Dürsteler over 9 years ago
Sorry for the broken link above, missed a space. It should be http://wiki.typo3.org/How_to_use_the_Fluid_Standalone_view_to_render_template_based_emails
Updated by Markus Klein over 9 years ago
Just a note from my side: We need multilanguage and plaintext support for mails. So our current structure looks like this:
Resources/Private/MailTemplates/<lang-iso-2-code>/<controller>/mailtemplate.html Resources/Private/MailTemplates/<lang-iso-2-code>/<controller>/mailtemplate.txt
The subject of the mail is the first line of the txt-file.
We use standalone view to load the template and a viewhelper to embed images in the HTML mail.
Updated by Pascal Dürsteler over 9 years ago
Multilanguage is required, that's for sure. But your structure seems a bit off for me, as this would be the only place with such a structure. By now, we only have one html template for views (the "usual" views are meant here) and localize through f:translate and its according xliff/xml files. Why not stick with that to keep it consistent?
Updated by Markus Klein over 9 years ago
Well, this structure is necessary as you do not want to translate huge mails bit by bit via xliff.
An email is generally different compared to a web output, where mostly single labels need to be translated.
In emails you generally have lots of text to be translated with potentially formatting differences, so it is way easier to translate a whole file.
Moreover you may need to adjust a lot of links in the mail to include the L parameter for the specific language.
Updated by Xavier Perseguers over 9 years ago
There's an additional usual requirement when sending localized emails. Namely that you should be able to override the language, typically in a BE context where e.g., an editor is using a module to send mails to users and those emails should match the preferred language of the recipient, not the sender.
Updated by Markus Klein over 9 years ago
Full ACK!
I have a private mail api based on Fluid templates, which supports all that.
Updated by Georg Ringer over 4 years ago
- Status changed from New to Resolved
we have now FluidEmail
with #90266. therefore I am closing this generall issue. it might not yet support every edgecase but is a good start. feel free to open dedicated issues for stuff which is missing.
Updated by Georg Ringer over 4 years ago
- Related to Feature #90266: Fluid-based templated emails added