Prerequisites
Before diving into the Quickstart, make sure you have the following:- Node.js installed on your development machine.
- A Novu account. If you don’t have one, sign up for free at the web dashboard
Install and Set Up Novu in your Node.js App
First, you must install the Novu package in your Node.js application. Open your terminal and run the following command:<NOVU_API_KEY> value with the authentic key from the API Key section of your Novu Dashboard.
🔑 Note: Please do not hardcode your credentials in a file in production. Use environment variables instead.
Set Up A Channel Provider
A channel provider is a service that provides one or more notification functionality such as sending an email, SMS, push notification etc. Our integration store includes four channels: Email, SMS, Chat, and Push. These channels have multiple providers associated with them.| Channel | Providers | 
|---|---|
| MailGun, Mandrill, MailJet, Amazon SES, Sendgrid, Postmark, Netcore | |
| SMS | Twilio, Amazon SNS, Plivo, SMS, SMSCentral, Kannel, Infobip, Termii | 
| Chat | Mattermost, Slack, Microsoft Teams, Discord | 
| Push | FCM, APNS, Expo | 
Create a Workflow
A workflow is the blueprint for the notifications that will be sent. It holds the entire flow of messages sent to the subscriber. This is where all the different channels are tied together under a single entity. The workflow includes the following:- Workflow name and Identifier
- Channel tailored content:
| Channel | Content Style | Custom Variables {{handlebars}}format | 
|---|---|---|
| HTML | ✅ | |
| Visual Editor | ✅ | |
| SMS | Text | ✅ | 
| Chat | Text | ✅ | 
| In-App | Text | ✅ | 
| Push | Text | ✅ | 
- Click “Workflows” on the left sidebar of your Novu dashboard.
- Click the “Create Workflow” button on the top right.
- The name of the new workflow is currently “Untitled.” Rename it to a more suitable title.
- Select “Email” as the channel you want to add.

Choose email as the channel you want to add
- Click on the recently added channel, fill the email subject and click “Update”.

Fill in email subject
- Click on the “Test” tab and send a test email to verify your workflow.

Send test email to verify your workflow
Create A Subscriber
The recipients of a triggered notification are called subscribers. Click “Subscribers” on the left sidebar of the Novu dashboard to see all subscribers. By default, the dashboard will display a subscriber, as you were added automatically during sign-up.
Subscribers from the left sidebar shows all the subscriber
abc@gmail.com is a random unlikely email your users will have. To update this to an alternative email, you can call the updateSubscriber method like so:
phone, avatar, and data . The data field can accept an array of metadata that you want to attach to the subscriber.
Note: To make all of your app users subscribers, you need to programmatically add them to Novu.
Trigger A Notification
Copy and paste the following code into your app to trigger a notification:- The value of notificationWorkflowIdshould be the workflow’s trigger ID/slug.

Make sure your workflow's trigger ID/slug matches the value you'd used
- The value of payloadis an array of the data that you want to be dynamically injected into the workflow content.
- The value of subscriberIdis the id of the subscriber on Novu. Replace7789with your subscriber ID.
Topics
Novu provides a simple API that offers an easy interface for triggering notifications to multiple subscribers at once. This API is called “Topics” and allows users to manage their bulk notifications without having to implement complex loops. A topic is identified by a custom key that is provided by the user, and this key will be the identifier used in the Topics API. ⚠️ DANGER: The topic key should be unique and can’t be changed once chosen. Novu also safe guards for key uniqueness behind the scenes. Users can assign a name to a topic for descriptive purposes. This name does not need to be unique and can be changed using the API. A topic can have different subscribers, who will receive a notification whenever a notification is sent to the topic.Create a topic
Copy and paste the following code into your app to create a topic:- When creating a key, ensure it is unique and accurately identifies the topic. Document naming conventions and communicate them to team members to avoid confusion and ensure a smooth workflow.
- The value of nameshould be a descriptive topic name.
Add Subscribers To A Topic
Copy and paste the following code into your app to add subscribers to a topic.- To add multiple subscribers to a topic, simply separate their names with commas and add them to the array as part of the subscribersvalue.
Send Notification To A Topic
Thanks to the topics feature, it is possible to trigger a notification to all subscribers assigned to a topic. This helps avoid listing all subscriber identifiers in theto field of the notification trigger.
To trigger a notification to all subscribers of a topic, use Novu’s API as follows: