Download the PHP package vernes/yiimailer without Composer
On this page you can find all versions of the php package vernes/yiimailer. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download vernes/yiimailer
More information about vernes/yiimailer
Files in vernes/yiimailer
Package yiimailer
Short Description Yii extension for sending emails with layouts using PHPMailer
License
Informations about the package yiimailer
YiiMailer
Yii (v1.1.x) extension for sending emails with layouts using PHPMailer
Features
- Based on PHPMailer
- Supports Yii layouts and translation
- Supports web and console applications
- Send full HTML emails with embedded images
- Work with views like you usually do in Yii
- Use test mode to save emails instead of sending them (useful when you don't have mail server installed locally)
Installation
- Install with composer:
composer require vernes/yiimailer
- Add 'vendor.vernes.yiimailer.YiiMailer' line to your imports in main and/or console yii config
- Copy mail.php config file to protected/config or add configuration array in 'params' under the key 'YiiMailer'
- Create email layout file mail.php in protected/views/layouts/ (default path, can be changed in config)
- Create all the views you want to use in protected/views/mail/ (default path, can be changed in config)
- Put all images you want to embed in emails in images/mail/ (default path, can be changed in config)
Note
In console apps, alias 'webroot' may not be the same as in web apps. See https://github.com/yiisoft/yii/issues/1267. Best workaround is to set alias you need directly in config/console.php, e.g.:
Yii::setPathOfAlias('webroot.images.mail', '/path/to/your/images/mail/dir');
Yet another solution is to override protected/yiic.php and set 'webroot' alias there (see example files).
Usage
Instantiate YiiMailer in your controller or console command and pass view and data array:
$mail = new YiiMailer('contact', array('message' => 'Message to send', 'name' => 'John Doe', 'description' => 'Contact form'));
or
$mail = new YiiMailer(); $mail->setView('contact'); $mail->setData(array('message' => 'Message to send', 'name' => 'John Doe', 'description' => 'Contact form'));
Layout is automatically set from config but you may override it with
$mail->setLayout('layoutName');
Set the properties:
$mail->setFrom('[email protected]', 'John Doe'); $mail->setTo(Yii::app()->params['adminEmail']); $mail->setSubject('Mail subject');
You may use all PHPMailer properties you would usually use.
And finally send email(s):
if ($mail->send()) { Yii::app()->user->setFlash('contact','Thank you for contacting us. We will respond to you as soon as possible.'); } else { Yii::app()->user->setFlash('error','Error while sending email: '.$mail->getError()); }
Sending simple messages
You can send email without both the layout and view by using:
$mail = new YiiMailer(); //$mail->clearLayout();//if layout is already set in config $mail->setFrom('[email protected]', 'John Doe'); $mail->setTo(Yii::app()->params['adminEmail']); $mail->setSubject('Mail subject'); $mail->setBody('Simple message'); $mail->send();
Alternatively, you may also send email message with layout but without specific view (set layout and set body) or with view but without layout (clear layout and set view).
Setting addresses
When using methods for setting addresses (setTo(), setCc(), setBcc(), setReplyTo()) any of the following is valid for arguments:
$mail->setTo('[email protected]'); $mail->setTo(array('[email protected]','[email protected]')); $mail->setTo(array('[email protected]'=>'John Doe','[email protected]'));
Sending attachments
You may send one or more attachments using setAttachemnt() method:
$mail->setAttachment('something.pdf'); $mail->setAttachment(array('something.pdf','something_else.pdf','another.doc')); $mail->setAttachment(array('something.pdf'=>'Some file','something_else.pdf'=>'Another file'));
Test mode
When working locally without mail server installed, it may be useful to save emails as files instead of trying to send them and getting errors in the process. To use test mode, you must specify path to directory where you want to save your emails and set 'testMode' property to 'true' in your config:
'savePath' => 'webroot.assets.mail', 'testMode' => true,
Emails are saved as .eml files and you can use software like Mozilla Thunderbird to open them.
Using SMTP
If you want to use SMTP, configure appropriate properties in your config. Example setup for GMail:
'Mailer' => 'smtp', 'Host' => 'smtp.gmail.com', 'Port' => 465, 'SMTPSecure' => 'ssl', 'SMTPAuth' => true, 'Username' => '[email protected]', 'Password' => 'your_password',
You may also configure this just before sending email:
$mail->setSmtp('smtp.gmail.com', 465, 'ssl', true, '[email protected]', 'your_password');
Examples
Two examples included: one for standard contact form in yii web app and the other one for yii console app.