Mapping Novu Concepts to Courier
Workflows, Templates, and Automations
Novu workflows combine notification content, channel routing, and orchestration logic (digest, delay, conditions) into a single resource. Courier splits these into two independent pieces, and this is the most meaningful architectural difference between the platforms. Templates own the content layer. You design them visually in the Designer (drag-and-drop blocks for email, SMS, push, and chat) or define them in code with Elemental JSON. Either way, your product team can ship copy changes without an engineering cycle. Automations own the orchestration layer: delays, conditions, branching, digests, and cancellation. An automation’s send node references a template by ID, so the two evolve independently. A PM updates a welcome email while an engineer tunes the onboarding sequence, and they never step on each other.| Novu Step Type | Courier Equivalent |
|---|---|
| Channel step (email, SMS, push, chat) | Send node (references a template) |
| Digest step | Digest node |
| Delay step | Delay node |
| Custom step | Fetch Data node or condition logic |
Subscribers and Users
Novu subscribers are the equivalent of Courier profiles. Both store recipient data: email, phone, push tokens, locale, and custom properties. Courier profiles accept nested JSON natively, so structured data like account tiers, team roles, or feature flags fits naturally. You can create profiles ahead of time through the API, or identify users inline at send time. Pass auser_id that doesn’t exist yet and Courier creates the profile on the fly.
Topics and Subscription Topics
Novu topics group subscribers for bulk notification delivery. In Courier, the closest equivalent depends on your use case:- For notification categories (letting users opt in/out of types of notifications): use Subscription Topics within Preferences
- For bulk delivery to groups: use Lists or Audiences
Integrations
Novu and Courier both call provider connections “integrations.” Courier supports 50+ providers across email, SMS, push, chat, and webhooks. You can wire up multiple providers for the same channel type, and Courier fails over between them automatically. If your primary email provider goes down, traffic shifts to the backup without any code changes.Digest and Delay
Courier’s Digest node works the same way as Novu’s digest step: collect matching events over a configurable time window, then send a single summary notification. Your template gets access to the full list of digested events for rendering rich summaries. Delay works similarly; specify a duration or a specific timestamp and the automation pauses before continuing to the next step.Preferences
Novu’s preference system supports global and per-workflow channel controls. Courier Preferences support the same hierarchy (global, per-topic, per-channel) and enforce them automatically at send time. On top of the API, Courier ships a hosted preference page you can deploy in minutes and embeddable React components for in-app preference centers. No custom UI work required.In-App Notifications
Novu’s Inbox component provides in-app notifications. Courier Inbox serves the same purpose with drop-in components for React, iOS, Android, and vanilla JS. Courier Inbox runs on the same delivery pipeline as email, push, and SMS; there’s no separate service to manage. Out of the box you get read/unread state, archiving, per-user history, toast notifications, and tab-based organization.Tenants
Tenants in Courier work much like tenants in Novu. You scope branding, preference defaults, and notification feeds to individual customer organizations. Pass atenant_id at send time and Courier applies per-tenant branding and preferences automatically.
Why Courier
- Fully managed infrastructure. No self-hosting to maintain, no bridge endpoints to deploy. Courier handles orchestration, delivery, retries, and scaling.
- Content and logic stay separate. Templates and automations are independent resources. Your product team updates copy in the Designer while engineers tune workflow timing; neither blocks the other.
- Visual template designer. Build email, SMS, push, and chat content with drag-and-drop blocks. Preview across channels, personalize with variables, and publish without deploying code.
- Built-in in-app channel. Courier Inbox works without a third-party provider. Drop in a React, iOS, or Android component and deliver in-app notifications on the same pipeline as email and push.
- Automatic failover. Configure multiple providers per channel and Courier fails over automatically. If SendGrid goes down, your email still goes out through your backup provider.
- Hosted preferences out of the box. Ship a user-facing preference center with a single config, or embed React components directly in your app. No custom UI required.
- 50+ integrations. Email, SMS, push, chat, webhooks, CDPs, and observability tools. Switch providers without changing your send code.
- Full delivery observability. Message Logs track every message from API request to provider delivery with a detailed timeline, error details, and rendered content inspection.
Migration Steps
Create your Courier workspace
Sign up and create a workspace. Courier gives you separate Test and Production environments with independent API keys, so you can migrate safely without affecting live traffic.
Configure integrations
Go to Integrations in your Courier dashboard and connect the same providers you use in Novu (SendGrid, Twilio, FCM, etc.). Each provider maps to a channel type (email, SMS, push, chat). You can configure multiple providers per channel for failover.If you use Novu’s inbox component, enable Courier Inbox; no external provider needed.
Recreate templates
Novu workflows contain inline content per channel step. In Courier, extract the content into templates:
- Create a new template for each notification type
- Add content blocks for each channel (email body, SMS text, push title/body, etc.)
- Use
{{variable}}syntax for dynamic data; both platforms use the same Handlebars-style approach - Publish the template to make it available for sending
Recreate workflows as automations
If your Novu workflows include digest, delay, or conditional logic, recreate them in Automations. You can build automations visually in the Automations Designer or define them programmatically via the Automations API.For simple notification types that don’t need orchestration (no delays, no digests), you can skip automations entirely and send directly via the Send API.
Migrate subscriber data
Create user profiles in Courier with the same identifiers you use in Novu. You can create profiles via the Profiles API or inline at send time.For bulk migration, use the Bulk API to upsert users in batches.
Set up preferences
If you use Novu’s subscriber preferences, recreate your structure in Courier:
- Define subscription topics that map to your Novu workflow categories
- Configure default channel routing per topic
- Migrate subscriber preference selections via the Preferences API
Update your trigger calls
Replace Novu’s workflow trigger calls with Courier’s Send API:Courier handles routing, preferences, and failover automatically based on your template and workspace configuration.
Test and cut over
- Send test messages in your Test environment and verify delivery in Message Logs
- Validate that preferences, routing, and template rendering match your Novu setup
- Switch your production code to use Courier’s Production API key
- Monitor Message Logs and Analytics for delivery confirmation
API Mapping
| Operation | Novu | Courier |
|---|---|---|
| Send a notification | POST /v1/events/trigger | POST /send |
| Create/update a subscriber | PUT /v1/subscribers/:id | PUT /profiles/:id |
| Get a subscriber | GET /v1/subscribers/:id | GET /profiles/:id |
| Set preferences | PATCH /v2/subscribers/:id/preferences | PUT /users/:id/preferences/:topic |
| Get message status | GET /v1/messages/:id | GET /messages/:id |
| List messages | GET /v1/messages | GET /messages |
| Manage topics | POST /v1/topics | PUT /lists/:id |
| Bulk operations | Bulk trigger | POST /bulk |