Class Mailer
Mailer base class.
Mailer classes let you encapsulate related Email logic into a reusable and testable class.
Defining Messages
Mailers make it easy for you to define methods that handle email formatting logic. For example:
class UserMailer extends Mailer
{
    public function resetPassword($user)
    {
        $this
            ->subject('Reset Password')
            ->to($user->email)
            ->set(['token' => $user->token]);
    }
}Is a trivial example but shows how a mailer could be declared.
Sending Messages
After you have defined some messages you will want to send them:
$mailer = new UserMailer();
$mailer->send('resetPassword', $user);Event Listener
Mailers can also subscribe to application event allowing you to
decouple email delivery from your application code. By re-declaring the
implementedEvents() method you can define event handlers that can
convert events into email. For example, if your application had a user
registration event:
public function implementedEvents()
{
    return [
        'Model.afterSave' => 'onRegistration',
    ];
}
public function onRegistration(Event $event, Entity $entity, ArrayObject $options)
{
    if ($entity->isNew()) {
         $this->send('welcome', [$entity]);
    }
}The onRegistration method converts the application event into a mailer method. Our mailer could either be registered in the application bootstrap, or in the Table class' initialize() hook.
Property Summary
- 
        $_clonedEmail protectedstringCloned Email instance for restoring instance after email is sent by mailer action. 
- 
        $_email protectedCake\Mailer\EmailEmail instance. 
- 
        $_modelFactories protectedarrayA list of model factory functions. 
- 
        $_modelType protectedstringThe model type to use. 
- 
        $modelClass publicstringThis object's primary model class name. Should be a plural form. CakePHP will not inflect the name. 
- 
        $name public staticstringMailer's name. 
Method Summary
- 
          __call() publicMagic method to forward method class to Email instance. 
- 
          __construct() publicConstructor. 
- 
          _setModelClass() protectedSet the modelClass and modelKey properties based on conventions. 
- 
          addAttachments() public @method
- 
          addBcc() public @method
- 
          addCc() public @method
- 
          addHeaders() public @method
- 
          addTo() public @method
- 
          attachments() public @method
- 
          bcc() public @method
- 
          cc() public @method
- 
          charset() public @method
- 
          domain() public @method
- 
          emailFormat() public @method
- 
          from() public @method
- 
          getHeaders() public @method
- 
          getName() publicReturns the mailer's name. 
- 
          headerCharset() public @method
- 
          helpers() public @method
- 
          implementedEvents() publicImplemented events. 
- 
          layout() publicSets layout to use. 
- 
          loadModel() publicLoads and constructs repository objects required by this object 
- 
          message() public @method
- 
          messageId() public @method
- 
          modelFactory() publicRegister a callable to generate repositories of a given type. 
- 
          modelType() publicSet or get the model type to be used by this class 
- 
          profile() public @method
- 
          readReceipt() public @method
- 
          replyTo() public @method
- 
          reset() protectedReset email instance. 
- 
          returnPath() public @method
- 
          send() publicSends email. 
- 
          sender() public @method
- 
          set() publicSets email view vars. 
- 
          setHeaders() public @method
- 
          subject() public @method
- 
          template() public @method
- 
          theme() public @method
- 
          to() public @method
- 
          transport() public @method
- 
          viewBuilder() publicGet Email instance's view builder. 
- 
          viewRender() public @method
- 
          viewVars() public @method
Method Detail
__call() ¶ public
__call(string $method, array $args): $thisMagic method to forward method class to Email instance.
Parameters
- 
                string$method
- Method name. 
- 
                array$args
- Method arguments 
Returns
$this__construct() ¶ public
__construct(Cake\Mailer\Email|null $email = null)Constructor.
Parameters
- 
                Cake\Mailer\Email|null$email optional
- Email instance. 
_setModelClass() ¶ protected
_setModelClass(string $name): voidSet the modelClass and modelKey properties based on conventions.
If the properties are already set they will not be overwritten
Parameters
- 
                string$name
- Class name. 
Returns
voidaddAttachments() ¶ public @method
addAttachments(mixed $attachments): EmailParameters
- 
                $attachments
Returns
EmailaddBcc() ¶ public @method
addBcc(mixed $email, mixed $name = null): EmailParameters
- 
                $email
- 
                $name optional
Returns
EmailaddCc() ¶ public @method
addCc(mixed $email, mixed $name = null): EmailParameters
- 
                $email
- 
                $name optional
Returns
EmailaddHeaders() ¶ public @method
addHeaders(array $headers): EmailParameters
- 
                array$headers
Returns
EmailaddTo() ¶ public @method
addTo(mixed $email, mixed $name = null): EmailParameters
- 
                $email
- 
                $name optional
Returns
Emailattachments() ¶ public @method
attachments(mixed $attachments = null): EmailParameters
- 
                $attachments optional
Returns
Emailbcc() ¶ public @method
bcc(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
Emailcc() ¶ public @method
cc(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
Emailcharset() ¶ public @method
charset(mixed $charset = null): EmailParameters
- 
                $charset optional
Returns
Emaildomain() ¶ public @method
domain(mixed $domain = null): EmailParameters
- 
                $domain optional
Returns
EmailemailFormat() ¶ public @method
emailFormat(mixed $format = null): EmailParameters
- 
                $format optional
Returns
Emailfrom() ¶ public @method
from(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
EmailgetHeaders() ¶ public @method
getHeaders(array $include = []): EmailParameters
- 
                array$include optional
Returns
EmailheaderCharset() ¶ public @method
headerCharset(mixed $charset = null): EmailParameters
- 
                $charset optional
Returns
Emailhelpers() ¶ public @method
helpers(mixed $helpers = null): EmailParameters
- 
                $helpers optional
Returns
EmailimplementedEvents() ¶ public
implementedEvents(): arrayImplemented events.
Example:
 public function implementedEvents()
 {
     return [
         'Order.complete' => 'sendEmail',
         'Article.afterBuy' => 'decrementInventory',
         'User.onRegister' => ['callable' => 'logRegistration', 'priority' => 20, 'passParams' => true]
     ];
 }Returns
arraylayout() ¶ public
layout(string $layout): $thisSets layout to use.
Parameters
- 
                string$layout
- Name of the layout to use. 
Returns
$thisloadModel() ¶ public
loadModel(string|null $modelClass = null, string|null $modelType = null): objectLoads and constructs repository objects required by this object
Typically used to load ORM Table objects as required. Can also be used to load other types of repository objects your application uses.
If a repository provider does not return an object a MissingModelException will be thrown.
Parameters
- 
                string|null$modelClass optional
- Name of model class to load. Defaults to $this->modelClass 
- 
                string|null$modelType optional
- The type of repository to load. Defaults to the modelType() value. 
Returns
objectThrows
Cake\Datasource\Exception\MissingModelExceptionIf the model class cannot be found.
InvalidArgumentExceptionWhen using a type that has not been registered.
UnexpectedValueExceptionIf no model type has been defined
message() ¶ public @method
message(mixed $type = null): EmailParameters
- 
                $type optional
Returns
EmailmessageId() ¶ public @method
messageId(mixed $message = null): EmailParameters
- 
                $message optional
Returns
EmailmodelFactory() ¶ public
modelFactory(string $type, callable $factory): voidRegister a callable to generate repositories of a given type.
Parameters
- 
                string$type
- The name of the repository type the factory function is for. 
- 
                callable$factory
- The factory function used to create instances. 
Returns
voidmodelType() ¶ public
modelType(string|null $modelType = null): string|$thisSet or get the model type to be used by this class
Parameters
- 
                string|null$modelType optional
- The model type or null to retrieve the current 
Returns
string|$thisprofile() ¶ public @method
profile(mixed $config = null): EmailParameters
- 
                $config optional
Returns
EmailreadReceipt() ¶ public @method
readReceipt(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
EmailreplyTo() ¶ public @method
replyTo(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
EmailreturnPath() ¶ public @method
returnPath(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
Emailsend() ¶ public
send(string $action, array $args = [], array $headers = []): arraySends email.
Parameters
- 
                string$action
- The name of the mailer action to trigger. 
- 
                array$args optional
- Arguments to pass to the triggered mailer action. 
- 
                array$headers optional
- Headers to set. 
Returns
arrayThrows
Cake\Mailer\Exception\MissingActionExceptionBadMethodCallExceptionsender() ¶ public @method
sender(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
Emailset() ¶ public
set(string|array $key, mixed $value = null): $thisSets email view vars.
Parameters
- 
                string|array$key
- Variable name or hash of view variables. 
- 
                mixed$value optional
- View variable value. 
Returns
$thissetHeaders() ¶ public @method
setHeaders(array $headers): EmailParameters
- 
                array$headers
Returns
Emailsubject() ¶ public @method
subject(mixed $subject = null): EmailParameters
- 
                $subject optional
Returns
Emailtemplate() ¶ public @method
template(mixed $template = false, mixed $layout = false): EmailParameters
- 
                $template optional
- 
                $layout optional
Returns
Emailto() ¶ public @method
to(mixed $email = null, mixed $name = null): EmailParameters
- 
                $email optional
- 
                $name optional
Returns
Emailtransport() ¶ public @method
transport(mixed $name = null): EmailParameters
- 
                $name optional
Returns
EmailviewBuilder() ¶ public
viewBuilder(): Cake\View\ViewBuilderGet Email instance's view builder.
Returns
Cake\View\ViewBuilderviewRender() ¶ public @method
viewRender(mixed $viewClass = null): EmailParameters
- 
                $viewClass optional
Returns
EmailviewVars() ¶ public @method
viewVars(mixed $viewVars = null): EmailParameters
- 
                $viewVars optional
Returns
EmailProperty Detail
$_clonedEmail ¶ protected
Cloned Email instance for restoring instance after email is sent by mailer action.
Type
string$modelClass ¶ public
This object's primary model class name. Should be a plural form. CakePHP will not inflect the name.
Example: For an object named 'Comments', the modelClass would be 'Comments'.
Plugin classes should use Plugin.Comments style names to correctly load
models from the correct plugin.
Type
string