nickfairchild / themosis-mail
Mail package for Themosis.
v1.0.1
2017-06-25 16:21 UTC
Requires
- php: >=5.6
- illuminate/mail: ^5.4
This package is auto-updated.
Last update: 2024-11-04 21:51:09 UTC
README
This is a package that adds Laravel's mail package to themosis for a nicer way to create and send mail in WordPress.
Usage
Step 1: Install Through Composer
composer require nickfairchild/themosis-mail
Step 2: Add the Service Provider
Add the provider within config/providers.config.php
return [ NickFairchild/Mail/MailServiceProvider::class, ];
Step 3: Add the mail config file
Now create a new config file config/mail.config.php
return [ /* |-------------------------------------------------------------------------- | Mail Driver |-------------------------------------------------------------------------- | | Supported: "mail", "smtp", "sendmail", "mailgun", "mandrill", | "ses", "sparkpost", "log", "array" | */ 'driver' => env('MAIL_DRIVER', 'mail'), /* |-------------------------------------------------------------------------- | SMTP Host Address |-------------------------------------------------------------------------- | | Here you may provide the host address of the SMTP server used by your | applications. A default option is provided that is compatible with | the Mailgun mail service which will provide reliable deliveries. | */ 'host' => env('MAIL_HOST', 'smtp.mailgun.org'), /* |-------------------------------------------------------------------------- | SMTP Host Port |-------------------------------------------------------------------------- | | This is the SMTP port used by your application to deliver e-mails to | users of the application. Like the host we have set this value to | stay compatible with the Mailgun e-mail application by default. | */ 'port' => env('MAIL_PORT', 587), /* |-------------------------------------------------------------------------- | Global "From" Address |-------------------------------------------------------------------------- | | You may wish for all e-mails sent by your application to be sent from | the same address. Here, you may specify a name and address that is | used globally for all e-mails that are sent by your application. | */ 'from' => [ 'address' => env('MAIL_FROM_ADDRESS', 'hello@example.com'), 'name' => env('MAIL_FROM_NAME', 'Example'), ], /* |-------------------------------------------------------------------------- | E-Mail Encryption Protocol |-------------------------------------------------------------------------- | | Here you may specify the encryption protocol that should be used when | the application send e-mail messages. A sensible default using the | transport layer security protocol should provide great security. | */ 'encryption' => env('MAIL_ENCRYPTION', 'tls'), /* |-------------------------------------------------------------------------- | SMTP Server Username |-------------------------------------------------------------------------- | | If your SMTP server requires a username for authentication, you should | set it here. This will get used to authenticate with your server on | connection. You may also set the "password" value below this one. | */ 'username' => env('MAIL_USERNAME'), 'password' => env('MAIL_PASSWORD'), /* |-------------------------------------------------------------------------- | Sendmail System Path |-------------------------------------------------------------------------- | | When using the "sendmail" driver to send e-mails, we will need to know | the path to where Sendmail lives on this server. A default path has | been provided here, which will work well on most of your systems. | */ 'sendmail' => '/usr/sbin/sendmail -bs', /* |-------------------------------------------------------------------------- | Markdown Mail Settings |-------------------------------------------------------------------------- | | If you are using Markdown based email rendering, you may configure your | theme and component paths here, allowing you to customize the design | of the emails. Or, you may simply stick with the Laravel defaults! | */ 'markdown' => [ 'theme' => 'default', 'paths' => [ themosis_path('resources.view')('views/vendor/mail'), ], ], ];
Step 4: Add the services config file
If you are going to be using an smtp driver such as mailgun or sparkpost you will need to create config/services.config.php
and add the following
return [ 'mailgun' => [ 'domain' => env('MAILGUN_DOMAIN'), 'secret' => env('MAILGUN_SECRET'), ], 'sparkpost' => [ 'secret' => env('SPARKPOST_SECRET'), ], ];
Now the rest works like Laravel which you can view the documentationhere