* fix broken links * update broken links utility * add missing payment evens * generate llms * fix segment link
266 lines
7.7 KiB
Plaintext
266 lines
7.7 KiB
Plaintext
import { Table, Prerequisites } from "docs-ui"
|
|
|
|
export const metadata = {
|
|
title: `SendGrid Notification Module Provider`,
|
|
}
|
|
|
|
# {metadata.title}
|
|
|
|
The SendGrid Notification Module Provider integrates [SendGrid](https://sendgrid.com) to send emails to users and customers.
|
|
|
|
## Register the SendGrid Notification Module
|
|
|
|
<Prerequisites
|
|
items={[
|
|
{
|
|
text: "SendGrid account",
|
|
link: "https://signup.sendgrid.com",
|
|
},
|
|
{
|
|
text: "Setup SendGrid single sender",
|
|
link: "https://docs.sendgrid.com/ui/sending-email/sender-verification",
|
|
},
|
|
{
|
|
text: "SendGrid API Key",
|
|
link: "https://docs.sendgrid.com/ui/account-and-settings/api-keys",
|
|
},
|
|
]}
|
|
/>
|
|
|
|
Add the module into the `providers` array of the Notification Module:
|
|
|
|
<Note>
|
|
|
|
Only one provider can be defined for a channel.
|
|
|
|
</Note>
|
|
|
|
```ts title="medusa-config.ts"
|
|
import { Modules } from "@medusajs/framework/utils"
|
|
|
|
// ...
|
|
|
|
module.exports = defineConfig({
|
|
// ...
|
|
modules: [
|
|
{
|
|
resolve: "@medusajs/medusa/notification",
|
|
options: {
|
|
providers: [
|
|
// ...
|
|
{
|
|
resolve: "@medusajs/medusa/notification-sendgrid",
|
|
id: "sendgrid",
|
|
options: {
|
|
channels: ["email"],
|
|
api_key: process.env.SENDGRID_API_KEY,
|
|
from: process.env.SENDGRID_FROM,
|
|
},
|
|
},
|
|
],
|
|
},
|
|
},
|
|
],
|
|
})
|
|
```
|
|
|
|
### Environment Variables
|
|
|
|
Make sure to add the following environment variables:
|
|
|
|
```bash
|
|
SENDGRID_API_KEY=<YOUR_SENDGRID_API_KEY>
|
|
SENDGRID_FROM=<YOUR_SENDGRID_FROM>
|
|
```
|
|
|
|
### SendGrid Notification Module Options
|
|
|
|
<Table>
|
|
<Table.Header>
|
|
<Table.Row>
|
|
<Table.HeaderCell>Option</Table.HeaderCell>
|
|
<Table.HeaderCell>Description</Table.HeaderCell>
|
|
</Table.Row>
|
|
</Table.Header>
|
|
<Table.Body>
|
|
<Table.Row>
|
|
<Table.Cell>`channels`</Table.Cell>
|
|
<Table.Cell>
|
|
The channels this notification module is used to send notifications for.
|
|
Only one provider can be defined for a channel.
|
|
</Table.Cell>
|
|
</Table.Row>
|
|
<Table.Row>
|
|
<Table.Cell>`api_key`</Table.Cell>
|
|
<Table.Cell>The SendGrid API key.</Table.Cell>
|
|
</Table.Row>
|
|
<Table.Row>
|
|
<Table.Cell>`from`</Table.Cell>
|
|
<Table.Cell>The SendGrid from email.</Table.Cell>
|
|
</Table.Row>
|
|
</Table.Body>
|
|
</Table>
|
|
|
|
## SendGrid Templates
|
|
|
|
When you send a notification, you must specify the ID of the template to use in SendGrid.
|
|
|
|
Refer to [this SendGrid documentation guide](https://docs.sendgrid.com/ui/sending-email/how-to-send-an-email-with-dynamic-templates) on how to create templates for your different email types.
|
|
|
|
---
|
|
|
|
## Test out the Module
|
|
|
|
To test the module out, you'll listen to the `product.created` event and send an email when a product is created.
|
|
|
|
Create a [subscriber](!docs!/learn/fundamentals/events-and-subscribers) at `src/subscribers/product-created.ts` with the following content:
|
|
|
|
export const highlights = [
|
|
["11", "notificationModuleService", "Resolve the Notification Module."],
|
|
["14", "product", "Retrieve the product's details."],
|
|
["22", "createNotifications", "Create the notification to be sent."],
|
|
[
|
|
"24",
|
|
'"email"',
|
|
"By specifying the `email` channel, SendGrid will be used to send the notification.",
|
|
],
|
|
["25", '"product-created"', "The ID of the template defined in SendGrid."],
|
|
["26", "data", "The data to pass to the template defined in SendGrid."],
|
|
]
|
|
|
|
```ts title="src/subscribers/product-created.ts" highlights={highlights} collapsibleLines="1-7" expandButtonLabel="Show Imports"
|
|
import type {
|
|
SubscriberArgs,
|
|
SubscriberConfig,
|
|
} from "@medusajs/framework"
|
|
import { Modules } from "@medusajs/framework/utils"
|
|
|
|
export default async function productCreateHandler({
|
|
event: { data },
|
|
container,
|
|
}: SubscriberArgs<{ id: string }>) {
|
|
const notificationModuleService = container.resolve(Modules.NOTIFICATION)
|
|
const query = container.resolve("query")
|
|
|
|
const { data: [product] } = await query.graph({
|
|
entity: "product",
|
|
fields: ["*"],
|
|
filters: {
|
|
id: data.id,
|
|
},
|
|
})
|
|
|
|
await notificationModuleService.createNotifications({
|
|
to: "test@gmail.com",
|
|
channel: "email",
|
|
template: "product-created",
|
|
data: {
|
|
product_title: product.title,
|
|
product_image: product.images[0]?.url,
|
|
},
|
|
})
|
|
}
|
|
|
|
export const config: SubscriberConfig = {
|
|
event: "product.created",
|
|
}
|
|
```
|
|
|
|
In this subscriber, you:
|
|
|
|
- Resolve the Notification Module's main service and [Query](!docs!/learn/fundamentals/module-links/query) from the [Medusa container](!docs!/learn/fundamentals/medusa-container).
|
|
- Retrieve the product's details using Query to pass them to the template in SendGrid.
|
|
- Use the `createNotifications` method of the Notification Module's main service to create a notification to be sent to the specified email. By specifying the `email` channel, the SendGrid Notification Module Provider is used to send the notification.
|
|
- The `template` property of the `createNotifications` method's parameter specifies the ID of the template defined in SendGrid.
|
|
- The `data` property allows you to pass data to the template in SendGrid. For example, the product's title and image.
|
|
|
|
Then, start the Medusa application:
|
|
|
|
```bash npm2yarn
|
|
npm run dev
|
|
```
|
|
|
|
And create a product either using the [API route](!api!/admin#products_postproducts) or the [Medusa Admin](!user-guide!/products/create). This runs the subscriber and sends an email using SendGrid.
|
|
|
|
### Other Events to Handle
|
|
|
|
Medusa emits other events that you can handle to send notifications using the SendGrid Notification Module Provider, such as `order.placed` when an order is placed.
|
|
|
|
Refer to the [Events Reference](/references/events) for a complete list of events emitted by Medusa.
|
|
|
|
### Sending Emails with SendGrid in Workflows
|
|
|
|
You can also send an email using SendGrid in any [workflow](!docs!/learn/fundamentals/workflows). This allows you to send emails within your custom flows.
|
|
|
|
You can use the [sendNotifcationStep](/references/medusa-workflows/steps/sendNotificationsStep) in your workflow to send an email using SendGrid.
|
|
|
|
For example:
|
|
|
|
```ts title="src/workflows/send-email.ts"
|
|
import { createWorkflow } from "@medusajs/framework/workflows-sdk"
|
|
import {
|
|
sendNotificationsStep,
|
|
useQueryGraphStep,
|
|
} from "@medusajs/medusa/core-flows"
|
|
|
|
type WorkflowInput = {
|
|
id: string
|
|
}
|
|
|
|
export const sendEmailWorkflow = createWorkflow(
|
|
"send-email-workflow",
|
|
({ id }: WorkflowInput) => {
|
|
const { data: products } = useQueryGraphStep({
|
|
entity: "product",
|
|
fields: [
|
|
"*",
|
|
"variants.*",
|
|
],
|
|
filters: {
|
|
id,
|
|
},
|
|
})
|
|
|
|
sendNotificationsStep({
|
|
to: "test@gmail.com",
|
|
channel: "email",
|
|
template: "product-created",
|
|
data: {
|
|
product_title: product[0].title,
|
|
product_image: product[0].images[0]?.url,
|
|
},
|
|
})
|
|
}
|
|
)
|
|
```
|
|
|
|
This workflow works similarly to the subscriber. It retrieves the product's details using Query and sends an email using SendGrid (by specifying the `email` channel) to the `test@gmail.com` email.
|
|
|
|
You can also execute this workflow in a subscriber. For example, you can execute it when a product is created:
|
|
|
|
```ts title="src/subscribers/product-created.ts"
|
|
import type {
|
|
SubscriberArgs,
|
|
SubscriberConfig,
|
|
} from "@medusajs/framework"
|
|
import { Modules } from "@medusajs/framework/utils"
|
|
import { sendEmailWorkflow } from "../workflows/send-email"
|
|
|
|
export default async function productCreateHandler({
|
|
event: { data },
|
|
container,
|
|
}: SubscriberArgs<{ id: string }>) {
|
|
await sendEmailWorkflow(container).run({
|
|
input: {
|
|
id: data.id,
|
|
},
|
|
})
|
|
}
|
|
|
|
export const config: SubscriberConfig = {
|
|
event: "product.created",
|
|
}
|
|
```
|
|
|
|
This subscriber will run every time a product is created, and it will execute the `sendEmailWorkflow` to send an email using SendGrid.
|