You can go to $Link.
``` The PHP Logic.. ```php $email = SilverStripe\Control\Email\Email::create() ->setHTMLTemplate('Email\\MyCustomEmail') ->setData([ 'Member' => Security::getCurrentUser(), 'Link'=> $link, ]) ->setFrom($from) ->setTo($to) ->setSubject($subject); if ($email->send()) { //email sent successfully } else { // there may have been 1 or more failures } ``` [alert] As we've added a new template file (`MyCustomEmail`) make sure you clear the Silverstripe CMS cache for your changes to take affect. [/alert] #### Custom plain templates By default Silverstripe CMS will generate a plain text representation of the email from the HTML body. However if you'd like to specify your own own plaintext version/template you can use `$email->setPlainTemplate()` to render a custom view of the plain email: ```php $email = new SilverStripe\Control\Email\Email(); $email->setPlainTemplate('MyPlanTemplate'); $this->send(); ``` ## Administrator Emails You can set the default sender address of emails through the `Email.admin_email` [configuration setting](/developer_guides/configuration). **app/_config/app.yml** ```yaml SilverStripe\Control\Email\Email: admin_email: support@example.com ``` To add a display name, set `admin_email` as follow. ```yaml SilverStripe\Control\Email\Email: admin_email: support@example.com: 'Support team' ``` [alert] Remember, setting a `from` address that doesn't come from your domain (such as the users email) will likely see your email marked as spam. If you want to send from another address think about using the `setReplyTo` method. [/alert] ## Redirecting Emails There are several other [configuration settings](/developer_guides/configuration) to manipulate the email server. * `SilverStripe\Control\Email\Email.send_all_emails_to` will redirect all emails sent to the given address. All recipients will be removed (including CC and BCC addresses). This is useful for testing and staging servers where you do not wish to send emails out. For debugging the original addresses are added as `X-Original-*` headers on the email. * `SilverStripe\Control\Email\Email.cc_all_emails_to` and `SilverStripe\Control\Email\Email.bcc_all_emails_to` will add an additional recipient in the BCC / CC header. These are good for monitoring system-generated correspondence on the live systems. Configuration of those properties looks like the following: **app/_config.php** ```php use SilverStripe\Control\Email\Email; use SilverStripe\Core\Config\Config; if(Director::isLive()) { Config::modify()->set(Email::class, 'bcc_all_emails_to', "client@example.com"); } else { Config::modify()->set(Email::class, 'send_all_emails_to', "developer@example.com"); } ``` ### Setting custom "Reply To" email address. For email messages that should have an email address which is replied to that actually differs from the original "from" email, do the following. This is encouraged especially when the domain responsible for sending the message isn't necessarily the same which should be used for return correspondence and should help prevent your message from being marked as spam. ```php $email = new Email(..); $email->setReplyTo('reply@example.com'); ``` ### Setting Custom Headers For email headers which do not have getters or setters (like setTo(), setFrom()) you can manipulate the underlying `Swift_Message` that we provide a wrapper for. ```php $email = new Email(...); $email->getSwiftMessage()->getHeaders()->addTextHeader('HeaderName', 'HeaderValue'); ``` [info] See this [Wikipedia](http://en.wikipedia.org/wiki/E-mail#Message_header) entry for a list of header names. [/info] ## Disabling Emails If required, you can also disable email sending entirely. This is useful for testing and staging servers where you do not wish to send emails out. ```yaml --- Name: myemailconfig Only: Environment: dev --- SilverStripe\Core\Injector\Injector: Swift_Transport: class: Swift_NullTransport ``` ## SwiftMailer Documentation For further information on SwiftMailer, consult their docs: http://swiftmailer.org/docs/introduction.html ## API Documentation * [Email](api:SilverStripe\Control\Email\Email)