Deprecated.
NAME
Catalyst::Plugin::Email - (DEPRECATED) Send emails with Catalyst
SYNOPSIS
# please use Email::MIME::Kit or Catalyst::View::Email::Template instead
use Catalyst 'Email';
__PACKAGE__->config->{email} = [qw/SMTP smtp.oook.de/];
$c->email(
header => [
From => 'sri@oook.de',
To => 'sri@cpan.org',
Subject => 'Hello!'
],
body => 'Hello sri'
);
DESCRIPTION
Send emails with Catalyst and Email::Send and Email::MIME::Creator.
CONFIGURATION
config
accepts the same options as Email::Send.
To send using the system's sendmail
program, set config
like so:
__PACKAGE__->config->{email} = ['Sendmail'];
To send using authenticated SMTP:
__PACKAGE__->config->{email} = [
'SMTP',
'smtp.myhost.com',
username => $USERNAME,
password => $PASSWORD,
];
For different methods of sending emails, and appropriate config
options, see Email::Send::NNTP, Email::Send::Qmail, Email::Send::SMTP and Email::Send::Sendmail.
METHODS
email()
accepts the same arguments as Email::MIME::Creator's create()
.
$c->email(
header => [
To => 'me@localhost',
Subject => 'A TT Email',
],
body => $c->subreq( '/render_email' ),
);
To send a multipart message, include a parts
argument containing an arrayref of Email::MIME objects.
my @parts = (
Email::MIME->create(
attributes => {
content_type => 'application/pdf',
encoding => 'quoted-printable',
name => 'report.pdf',
},
body => $FILE_DATA,
),
Email::MIME->create(
attributes => {
content_type => 'text/plain',
disposition => 'attachment',
charset => 'US-ASCII',
},
body => $c->subreq( '/render_email' ),
),
);
$c->email(
header => [
To => 'me@localhost',
Subject => 'A TT Email',
],
parts => \@parts,
);
USING WITH A VIEW
A common practice is to handle emails using the same template language used for HTML pages. If your view supports the 'render' method (Like the TT view does), you just set the body like this: $c->email( header => [ To => 'me@localhost', Subject => 'A TT Email', ], body => $c->view('TT')->render($c,'mytemplate.tt'), }
If your view doesn't support render, you can just forward to it, then reset the body like this:
sub send_email : Local {
my ( $self, $c ) = @_;
{
local $c->stash->{names} = [ qw/andyg sri mst/ ],
local $c->stash->{template}= 'mytemplate.tt';
$c->forward($c->view('MyView'));
$c->email(
header => [
To => 'me@localhost',
Subject => 'A TT Email',
],
body => $c->res->body,
);
$c->res->body(undef);
}
}
And the template:
[%- FOREACH name IN names -%]
Hi, [% name %]!
[%- END -%]
--
Regards,
Us
Output:
Hi, andyg!
Hi, sri!
Hi, mst!
--
Regards,
Us
SEE ALSO
Catalyst, Catalyst::Plugin::SubRequest, Email::Send, Email::MIME::Creator
AUTHOR
Sebastian Riedel, sri@cpan.org
Andy Grundman Carl Franks Marcus Ramberg mramberg@cpan.org
COPYRIGHT
This program is free software, you can redistribute it and/or modify it under the same terms as Perl itself.