How to Send Sign Up Confirmation Email
In this document, you’ll learn how to send a confirmation email to the customer after they sign up.
Overview
When a customer registers, the event customer.created
is triggered. You can then listen to this event in a subscriber to perform an action, such as send the customer a confirmation email.
Alternatively, you can use subscribe a Notification Provider to the event, if the Notification Provider Service implements the logic to handle the event.
This guide will explain how to create the subscriber and how to use SendGrid to send the confirmation email. SendGrid is only used to illustrate how the process works, but you’re free to use any other notification service.
Prerequisites
Event Bus Module
The event bus module trigger the event to the listening subscribers. So, it’s required to have an event bus module installed and configured on your Medusa backend.
The Local Event Bus module works in a development environment. For production, it’s recommended to use the Redis Event Bus module.
Notification Provider
As mentioned in the overview, this guide illustrates how to send the email using SendGrid. If you intend to follow along, you must have the SendGrid plugin installed and configured.
You can also find other available Notification provider plugins in the Plugins directory, or create your own.
Method 1: Using a Subscriber
To subscribe to an event, you must create a subscriber.
Create the file src/subscribers/customer-confirmation.ts
with the following content:
import {
type SubscriberConfig,
type SubscriberArgs,
CustomerService,
} from "@medusajs/medusa"
export default async function handleCustomerCreated({
data, eventName, container, pluginOptions,
}: SubscriberArgs<Record<string, string>>) {
// TODO: handle event
}
export const config: SubscriberConfig = {
event: CustomerService.Events.CREATED,
context: {
subscriberId: "customer-created-handler",
},
}
In this file, you export a configuration object indicating that the subscriber is listening to the CustomerService.Events.CREATED
(or customer.created
) event.
You also export a handler function handleCustomerConfirmation
. In the parameter it receives, the data
object is the payload emitted when the event was triggered, which is the entire customer object. So, you can find in it fields like first_name
, last_name
, email
, and more.
In this method, you should typically send an email to the customer. You can place any content in the email, such as welcoming them to your store or thanking them for registering.
Example: Using SendGrid
For example, you can implement this subscriber to send emails using SendGrid:
import {
type SubscriberConfig,
type SubscriberArgs,
CustomerService,
} from "@medusajs/medusa"
export default async function handleCustomerCreated({
data, eventName, container, pluginOptions,
}: SubscriberArgs<Record<string, string>>) {
const sendGridService = container.resolve("sendgridService")
sendGridService.sendEmail({
templateId: "customer-confirmation",
from: "hello@medusajs.com",
to: data.email,
dynamic_template_data: {
// any data necessary for your template...
first_name: data.first_name,
last_name: data.last_name,
},
})
}
export const config: SubscriberConfig = {
event: CustomerService.Events.CREATED,
context: {
subscriberId: "customer-created-handler",
},
}
Notice that you should replace the values in the object passed to the sendEmail
method:
templateId
: Should be the ID of your confirmation email template in SendGrid.from
: Should be the from email.to
: Should be the customer’s email.data
: Should be an object holding any data that should be passed to your SendGrid email template.