This is a lightweight SMTP mailer package for Mako Framework >=4.2.
Use composer to install. Simply add package to your project.
composer require aldoanizio/carteiro:*
So now you can update your project with a single command.
composer update
After installing you'll have to register the package in your app/config/application.php
file.
/**
* ---------------------------------------------------------
* Packages
* ---------------------------------------------------------
*
* Packages to boot during the application boot sequence.
* They will be booted in the order that they are defined.
*/
'packages' =>
[
....
'aldoanizio\carteiro\CarteiroPackage',
],
There are two ways to configure your package. The first is editing config file directly in packages folder: app/packages/carteiro/config/config.php
and input the necessary information.
If you like you can copy the package's config file app/packages/carteiro/config/config.php
into app/config/packages/carteiro
folder and the application will load that file instead of the one located in the package. This makes it possible to update the package while keeping your custom settings.
To send emails just use the create
method parsing some data.
$this->carteiro->create('my.email.view', $data, function($mail)
{
$mail->subject('Hello World');
$mail->to('foo@bar.com', 'John Doe');
});
The first argument passed to the create
method is the name of the view that should be used as the e-mail body. If passed as string will set mail body to use html
format.
The second is the $data
that should be passed to the view.
The third is a Closure allowing you to specify various options on the e-mail message. Also using closure you can access other variables.
You can also specify a plain text view to use in addition to an html
view. To do this you need to use an array to define wich view to use in each format.
$this->carteiro->create(['text' => 'my.text.view', 'html' => 'my.html.view'], $data, function($mail) use ($newUser)
{
$mail->subject('Welcome New User');
$mail->to($newUser->email, $newUser->name);
}
Or just use text
key to send email as a plain text only.
$this->carteiro->create(['text' => 'my.text.view'], $data, function($mail) use ($newUser)
{
$mail->subject('Welcome New User');
$mail->to($newUser->email, $newUser->name);
}
Sometimes you need to send emails using a content that do not depends of a view file. For example if you would like to send a custom message to one of your customers stored in database.
To do this you can make use of raw
key to parse a custom content. Notice in this case you don't need to use a view data so pass an empty array to second parameter.
// Your form post data
$postData = $this->request->post();
// ORM
$customer = Custommer::get($postData['customer_id']);
// Send message
$this->carteiro->create(['raw' => $postData['message']], [], function($mail) use ($postData, $customer)
{
$mail->subject($postData['subject']);
$mail->to($customer->email, $customer->name);
});
You may specify other options on the e-mail message such as any carbon copies or attachments as well.
$mail->subject('Welcome User');
Instead use information stored in config file you can use array or string to set 'from' and 'reply-to' addresses / name.
$address = ['webmaster@domain.tld', 'System Webmaster'];
// From
$mail->from($address);
// or
$mail->from('webmaster@domain.tld', 'System Webmaster');
// Reply To
$mail->reply($address);
// or
$mail->reply('webmaster@domain.tld', 'System Webmaster');
You can define multiples recipients (name is optional).
// Add to
$mail->to('receiver1@domain.tld');
$mail->to('receiver2@domain.tld');
You can add multiples using array.
// Build list
$list = [];
$list[] = 'receiver1@domain.tld';
$list[] = 'receiver2@domain.tld';
// List with names
$list = [];
$list[] = ['receiver1@domain.tld', 'Receiver 1'];
$list[] = ['receiver1@domain.tld', 'Receiver 2'];
// Add to
$mail->to($list);
The cc
option works like to
option even using multiples recipients.
$mail->cc('carboncopy1@domain.tld', 'Copy Receiver 1');
// or
$mail->cc($list);
The bcc
option works like to
option even using multiples recipients.
$mail->bcc('blindcarboncopy1@domain.tld', 'Blind Copy Receiver 1');
// or
$mail->bcc($list);
You can add attachments.
$mail->attach('/path/to/file1.png');
$mail->attach('/path/to/file2.png');
In config file you can flag 'debug_mode' = true;
, which can be helpful in testing your SMTP connections. It will write log files with server responses from each step in the email sending process.
Or you can enable/disable debug mode just in some cases without edit config file.
$mail->debug(true);
$mail->debug(false);
By default the package uses default mako debug files but you can define another debug file location. Use the 'debugFilePath()'
method to change file location.
When you call this method you don't need to enable debug using $mail->debug(true)
.
$mail->debugFilePath('my/new/file/path');
In config file you can define multiple connections
, each of them with their own settings. The default connection settings used is defined in 'default' => 'primary'
flag.
Sometimes you may want to change which connection will be used. You can do this 'on-the-fly'.
$mail->useConn('my_other_connection');
Also, you can define server parameters that are not included in config file.
$mail->setConn('server_host_addr', 'server_conn_port', (null|'ssl'|'tls'), (true|false), 'my_auth_user_name', 'my_auth_password');
You may want to change the origin of the HELO / EHLO request.
Setting default value as "localhost" may cause email to be considered spam.
$mail->setLocalhost('my.host.domain.name');
This package was build in top of Laravel SMTP class by swt83 - (https://github.com/swt83/php-laravel-smtp)
Just like original class, this package has some limitations. Please feel free to contribute to this project.
- Does not support encryption.
- Does not support priority level.
- Does not keep connection open for spooling email sends.