A nonofficial, feature complete, client library for sending transactional emails via Bloomreach.
The aim of the bloomreach-transactional-email
package is to get you going with the Bloomreach Transactional Email API as quickly as possible. The sendEmail function takes the minimum number of required parameters to send an email. Other parameters are optional. Full details of all the options can be found in the Blooreach Transactional Email API documentation.
bloomreach-transactional-email
uses axios, as a peer dependency, to make HTTP calls.
npm i -save bloomreach-transactional-email
If you have Customer IDs and a default email integration with a sender name and address setup in Bloomreach then you can use the minimum configuration to send an email by specifying a HTML body and a subject:
import { sendEmail } from 'bloomreach-transactional-email';
const auth = {
username: '...', // Your APIKeyID
password: '...', // Your APISecret
baseUrl: 'https://api.exponea.com', // Your base url
projectToken: '...', // Your project token
};
const campaignName = 'MyCampaign';
const customerIds = {
registered: 'marian@exponea.com'
};
const htmlContent = {
html: '<!DOCTYPEhtml><body>Hello world</body></html>',
subject: 'SubjectExample',
}
await sendEmail(auth, campaignName, customerIds, htmlContent);
If you have a template set up you can also send an email using it:
const templateContent = {
templateId: '60758e2d18883e1048b817a8',
params: { first_name: 'Marian' }
}
await sendEmail(auth, campaignName, customerIds, templateContent);
If you don’t have Customer IDs setup in Bloomreach you can specify the email address to send the email to (you still need to specify Customer IDs). If you have language variants of your template, you can specify the language. You can also specify the sender name and sender address:
await sendEmail(
auth,
campaignName,
customerIds,
htmlContent,
{
email: 'jon.doe@example.com',
language: 'en',
senderAddress: 'Marian',
senderName: 'marian@exponea.com'
}
);
You can specify either a single integration:
await sendEmail(
auth,
campaignName,
customerIds,
htmlContent,
{
integrationId: "5b337eceeb7cdb000d4e20f3"
}
);
or up to two integrations, a primary and a backup in case the primary fails, with individual sender addresses:
await sendEmail(
auth,
campaignName,
customerIds,
htmlContent,
{
integrations: [
{
id: "5b337eceeb7cdb000d4e20f3",
senderAddress: "marian@exponea.com",
},
{
id: "3f02e4d000bdc7beece733b5",
senderAddress: "marian@exponea.com",
}
]
}
);
You can specify a transfer identity of:
- enabled
- disabled
- first_click
await sendEmail(
auth,
campaignName,
customerIds,
htmlContent,
{
transferIdentity: 'disabled'
}
);
You can add an array of attachments with base64 encoded content:
await sendEmail(
auth,
campaignName,
customerIds,
htmlContent,
{}, // Options object can also be undefined
[
{
filename: 'example1.txt',
content: 'RXhhbXBsZSBhdHRhY2htZW50',
contentType: 'text/plain',
},
{
filename: 'example2.txt',
content: 'RXhhbXBsZSBhdHRhY2htZW50',
contentType: 'text/plain',
},
]
);
You can also add:
- Custom Event Properties
- Custom Headers
- UrlParams
- Transfer User Identity
- Consent Category
- Consent Category Tracking
Check the Blooreach Transactional Email API documentation for details:
await sendEmail(
auth,
campaignName,
customerIds,
htmlContent,
{}, // Options object can also be undefined
[], // Attachments array can also be undefined
{
customEventProperties: {
bannana: 'yellow',
1: 2,
},
customHeaders: {
source: 'your-company',
1: 2,
},
urlParams: {
source: 'email',
1: 2,
},
transferUserIdentity: 'first_click',
consentCategory: 'sms',
consentCategoryTracking: 'sms',
}
);