π§Emails
Transactional emails
Open up email.ex
and you will see a list of functions that generate Swoosh email structs. Eg:
If I run this function in IEX I can see the Swoosh struct:
An Swoosh.Email
struct can be delivered to an email address by a Swoosh mailer (see mailer.ex
). Eg:
So email.ex
creates the Swoosh structs and the functions for actually delivering emails like the previous code example are in user_notifier.ex
. Think of email.ex
functions like view templates, and user_notifer.ex
functions like controller actions.
So the steps to creating a new email will be:
Create the function to generate a Swoosh struct in
email.ex
Ensure it looks good by navigating to "http://localhost:4000/dev/emails" and creating a new action in
email_testing_controller.ex
that simply renders the html_body value of the structCreate a new
user_notifier.ex
function for use in our application
To see a more detailed write up on creating an email - see this section in the "Complete web app" guide.
Marketing emails with MailBluster
Marketing emails are emails you wish to send to your whole subscriber base or some segment of them to push some kind of marketing or product updates email. It differs from a transactional email in that you haven't programmed it in your codebase - instead, you create it manually.
Since Petal Pro doesn't come with an email campaign builder, you'll have to rely on a third-party service. Some services, like Sendgrid, will do both your transactional emails and marketing emails. Others, like Postmark and SES, will only send transactional emails.
We chose MailBluster as the default service to send marketing emails because of its very lost cost, and it uses SES under the hood.
All you need to do is drop in an API key in the form of MAIL_BLUSTER_API_KEY
in your .envrc
file and you users will start syncing with MailBluster (see lib/petal_pro/vendor/mail_bluster.ex
). If you have already deployed to production and have some users, then you can sync them up by running PetalPro.MailBluster.sync_all_users()
in IEX on your production server.
If you add some functionality that modifies a user - eg their name, you will need to re-sync that user with Mailbluster - PetalPro.MailBluster.sync_user(user)
.
Once you're all synced you can just log in to MailBluster and send a mass email.
Tags
MailBluster allows you to tag your users so you can segment your users. For example, we currently send the tags is_confirmed
or is_suspended
based on whether a user is either of those things. That way you can send emails only to users with confirmed email addresses.
To add/remove tags you can modify the code in mail_bluster.ex
:
Last updated