Author: MailerSend
Description: MailerSend is a transactional messaging service that enables developers to work faster and smarter.
An intuitively designed interface enables anyone to contribute to transactional email and SMS, while advanced sending infrastructure and flexible payment plans let you scale your sendings.
Built by deliverability experts, your messages always get delivered, along with dedicated IP, email verification and inbound routing for a comprehensive solution.
Get started right now for free!
Details: Use this extension to send emails that contain the information from documents added to a specified Cloud Firestore collection. Adding a document triggers this extension to send an email built from the document's fields.
Note that MailerSend allows you to:
- schedule emails
- send bulk emails
- add attachments up to 25MB
- organize your sendings with tags
- track opens, clicks, and spam reports.
We welcome bug reports and feature requests as well as pull requests in this GitHub repository.
firebase ext:install mailersend/mailersend-email --project=[your-project-id]
Learn more about installing extensions in the Firebase Extensions documentation: console, CLI
After its installation, this extension monitors all document writes to the EMAIL_COLLECTION
collection. Email is sent based on the contents of the document's fields. The document's fields specify an email data.
Here's a basic example document write that would trigger this extension
admin.firestore().collection('emails').add({
to: [
{
email: 'recipient@example.com',
name: 'Recipient name'
}
],
from: {
email: 'from@example.com',
name: 'From name'
},
cc: [
{
email: 'cc.recipient@example.com',
name: 'CC recipient name'
}
],
bcc: [
{
email: 'bcc.recipient@example.com',
name: 'Bcc recipient name'
}
],
subject: 'Hello from Firebase!',
html: 'This is an <code>HTML</code> email body.',
text: 'This is an TEXT email body.',
template_id: 'abc123ced',
variables: [
{
email: 'recipient@example.com',
substitutions: [
{
var: 'variable_name',
value: 'variable value'
}
]
}
],
personalization: [
{
email: 'recipient@example.com',
data: {
personalization_name: 'personalization value'
}
}
],
tags: ['tag1', 'tag2'],
reply_to: {
email: 'reply_to@example.com',
name: 'Reply to name'
},
send_at: '123465789'
})
Before installing this extension, set up the following Firebase service in your Firebase project:
- Cloud Firestore collection in your Firebase project.
Then, in the MailerSend dashboard:
Find all the JSON field parameters you can add to your API call, provided in dot notation
JSON field parameter | Type | Required | Limitations | Details |
---|---|---|---|---|
from |
object |
yes * | Not required if set in extension config or template_id is present and template has default sender set. |
|
from.email |
string |
yes * | Must be a verified domain or subdomain. | Not required if set in extension config or template_id is present and template has default sender set. |
from.name |
string |
no | from.email will be used if not provided or, if set in extension config or template_id is present with default values, the default subject from that will be used. |
|
to |
object[] |
yes | Min 1 , max 50 |
|
to.*.email |
string |
yes | ||
to.*.name |
string |
no | The name of the recipient. May not contain ; or , . |
|
cc |
object[] |
no | Max 10 | |
cc.*.email |
string |
yes | ||
cc.*.name |
string |
no | The name of the CC recipient. May not contain ; or , . |
|
bcc |
object[] |
no | Max 10 | |
bcc.*.email |
string |
yes | ||
bcc.*.name |
string |
no | The name of the BCC recipient. May not contain ; or , . |
|
reply_to |
object |
no | ||
reply_to.email |
string |
no | Can be set in extension config | |
reply_to.name |
string |
no | Can be set in extension config | |
subject |
string |
yes * | Not required if template_id is present and template has default subject set. |
|
text |
string |
yes * | Max size of 2 MB. | Email represented in a text (text/plain ) format. * Only required if there's no html or template_id present. |
html |
string |
yes * | Max size of 2 MB. | Email represented in HTML (text/html ) format. * Only required if there's no text or template_id present. |
template_id |
string |
yes * | * Only required if there's no text or html present. |
|
tags |
string[] |
no | Limit is max 5 tags. | |
variables |
object[] |
no | These will be replaced in the email content using {$var} format. Can be used in the subject , html , text fields. |
|
variables.*.email |
string |
yes | Email address that substitutions will be applied to. Read more about simple personalization. | |
variables.*.substitutions |
object[] |
yes | ||
variables.*.substitutions.*.var |
string |
yes | Name of the variable, will replace {$var} in the subject , html , text fields. |
|
variables.*.substitutions.*.value |
string |
yes | Value to be replaced, based on the variables.*.substitutions.*.var name. |
|
personalization |
object[] |
no | Allows using personalization in {{ var }} syntax. Can be used in the subject , html , text fields. Read more about advanced personalization. |
|
personalization.*.email |
string |
yes | Email address that personalization will be applied to. | |
personalization.*.data |
object[] |
yes | Object with key: value pairs. Values will be added to your template using {{ key }} syntax. |
|
send_at |
integer |
no | min: now , max: now + 72hours |
Has to be a Unix timestamp. Please note that this timestamp is a minimal guarantee and that the email could be delayed due to server load. |
After email sending is triggered this extension fills results into the delivery
field.
Field | Description |
---|---|
error | Validation error, or error from the server |
message_id | Message ID in MailerSend system |
state | State of an email sending: ERROR , SUCCESS |
This extension uses other Firebase or Google Cloud Platform services which may have associated charges:
- Cloud Functions
When you use Firebase Extensions, you're only charged for the underlying resources that you use. A paid-tier billing plan is only required if the extension uses a service that requires a paid-tier plan, for example calling to a Google Cloud Platform API or making outbound network requests to non-Google services. All Firebase services offer a free tier of usage. Learn more about Firebase billing.
This extension also uses the following third-party services:
- MailerSend (pricing information)
You are responsible for any costs associated with your use of these services.
-
Cloud Functions location: Where do you want to deploy the functions created for this extension? For help selecting a location, refer to the location selection guide.
-
Emails documents collection: What is the path to the collection that contains the documents used to build and send the email?
-
MailerSend API key: API tokens are used for authentication when sending emails. You can find more details how to create an API token here.
-
Email parameters:
-
Default FROM email address: The email address to use as the sender's address (if it's not specified in the added email document or template).
-
Default FROM name: The name to use as the sender's name.
-
Default reply to email address: The email address to use as the reply to address (if it's not specified in the added email document or template).(not required)
-
Default reply to name: The name to use as the reply to name. (not required)
-
Default template ID: The default template id to use for emails (it will be used if not specified in the added email document).
-
- processDocumentCreated: Processes created document in Cloud Firestore collection, sends an email and updates status information.