.NET SDK for Novu - The open-source notification infrastructure for engineers. 🚀
novu-dotnet targets .NET Standard 2.0 and is compatible with .NET Core 2.0+ and .NET Framework 4.6.1+.
Current: Novu api 0.24.0
- Bindings against all API endpoints
- Events, subscribers, notifications, integrations, layouts, topics, workflows, workflow groups, messages, execution details
- Bootstrap each services as part of services provider or directly as a singleton class (setting injectable)
- A Sync service that will mirror an environment based a set of templates (layouts, integrations, workflow groups, workflows)
WARNING: 0.3.0 has breaking changes and the tests should be relied on for understanding the client libraries
dotnet novu | novu api package | Notes |
---|---|---|
0.2.2 | <= 0.17 | Singleton client with Refit's use of RestService |
0.3.0 | >= 0.18 | 0.3.0 is not compatible with 0.2.2 and requires upgrade to code. Also 0.18 introduced a breaking change only found in 0.3.0. All 0.2.2 must be upgraded if used against the production system. HttpClient can now be used and injected. |
0.3.1 | >= 0.18 | Failed release. You will not find this release on Nuget. |
0.3.2 | >= 0.18 | [BREAKING} Obsolete Notification Templates has been removed. Service registration separation of single client and each client. Novu.Extension and Novu.Sync released as packages. |
0.3.2 | >= 0.18 | |
0.4.0 | >= 0.24 |
dotnet add package Novu
using Novu.DTO;
using Novu.Models;
using Novu;
var novuConfiguration = new NovuClientConfiguration
{
// Defaults to https://api.novu.co/v1
Url = "https://novu-api.my-domain.com/v1",
ApiKey = "12345",
};
var novu = new NovuClient(novuConfiguration);
// Note: this client exposes all endpoints as methods but uses RestService
var subscribers = await novu.Subscriber.Get();
Configure via settings
{
"Novu": {
"Url": "http://localhost:3000/v1",
"ApiKey": "e36b820fcc9a68a83db6c79c30f1a461"
}
}
Setup Injection via extension methods
public static IServiceCollection RegisterNotificationSetupServices(
this IServiceCollection services,
IConfiguration configuration)
{
// registers all clients with novu config from appsetting.json
// the services inject HttpClient
return services
.RegisterNovuClients(configuration)
// here as an example that the registered services are injected into local service
.AddTransient<NovuNotificationService>();
}
Write your consuming code with the injected clients
// then instantiate via injection
public class NovuNotificationService
{
private readonly IEventClient _event;
public NovuSyncService(IEventClient @event)
{
_event = @event;
}
public async Task Trigger(string subscriberId){
var trigger = await Event.Trigger(
new EventCreateData
{
EventName = 'event-name',
To = { SubscriberId =subscriberId },
Payload = new Payload("Bogus payload"),
});
}
public record Payload(string Message)
{
[JsonProperty("message")] public string Message { get; set; }
}
}
Usage of the library is best understood by looking at the tests.
- Integration Tests: these show the minimal dependencies required to do one primary request (create, update, delete)
- Acceptance Tests: these show a sequence of actions to complete a business process in an environment
Novu is the main SDK with Novu.Tests housing all unit tests. Novu.Extensions is required for DI and Novu.Sync if your are looking for mirroring environments.
The key folders to look into:
- Models directory holds all objects needed to use the clients (a port of the contracts from openapi spec and consolidated—actually autogen contracts)
- Clients directory holds all interfaces that are intended to outline how a class should be structured
Note: all old release information is in specs/[version]/README
(which includes diffs)
Tracking Versions: New
, Changed
, Deleted
, Deprecated
- New: tracked since version
- Changed: has had changes on the endpoint attributes
- Deleted: was removed (obsolete)
- Deprecated: marked as being removed
Compatability: Full
, Incomplete
, None
, Upgrade
- Full: all attributes are supported on the model on the method/endpoint call
- None: the method/endpoint is not implemented
- Upgrade: known changes to the attributes are required that are flagged (practically same as incomplete but effectively a NEW placeholder)
Events represent a change in state of a subscriber. They are used to trigger workflows, and enable you to send notifications to subscribers based on their actions.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
POST | /v1/events/trigger | Trigger event | 0.18.0 | 0.19.0 | Upgrade | |||
POST | /v1/events/trigger/bulk | Bulk trigger event | 0.18.0 | Full | ||||
POST | /v1/events/trigger/broadcast | Broadcast event to all | 0.18.0 | Full | ||||
DELETE | /v1/events/trigger/{transactionId} | Cancel triggered event | 0.18.0 | Full |
A subscriber in Novu represents someone who should receive a message. A subscriber’s profile information contains important attributes about the subscriber that will be used in messages (name, email). The subscriber object can contain other key-value pairs that can be used to further personalize your messages.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/subscribers | Get subscribers | 0.18.0 | Full | ||||
POST | /v1/subscribers | Create subscriber | 0.18.0 | Full | ||||
GET | /v1/subscribers/{subscriberId} | Get subscriber | 0.18.0 | Full | ||||
PUT | /v1/subscribers/{subscriberId} | Update subscriber | 0.18.0 | Full | ||||
DELETE | /v1/subscribers/{subscriberId} | Delete subscriber | 0.18.0 | Full | ||||
POST | /v1/subscribers/bulk | Bulk create subscribers | 0.19.0 | Full | ||||
PUT | /v1/subscribers/{subscriberId}/credentials | Update subscriber credentials | 0.18.0 | Full | ||||
DELETE | /v1/subscribers/{subscriberId}/credentials/{providerId} | Delete subscriber credentials by providerId | 0.18.0 | Full | ||||
PATCH | /v1/subscribers/{subscriberId}/online-status | Update subscriber online status | 0.18.0 | Full | ||||
GET | /v1/subscribers/{subscriberId}/preferences | Get subscriber preferences | 0.18.0 | Full | ||||
PATCH | /v1/subscribers/{subscriberId}/preferences | Update subscriber global preferences | 0.18.0 | Full | ||||
GET | /v1/subscribers/{subscriberId}/preferences/{level} | Get subscriber preferences by level | 0.18.0 | Full | ||||
PATCH | /v1/subscribers/{subscriberId}/preferences/{templateId} | Update subscriber preference | 0.18.0 | Full | ||||
GET | /v1/subscribers/{subscriberId}/notifications/feed | Get in-app notification feed for a particular subscriber | 0.18.0 | Full | ||||
GET | /v1/subscribers/{subscriberId}/notifications/unseen | Get the unseen in-app notifications count for subscribers feed | 0.18.0 | Full | ||||
POST | /v1/subscribers/{subscriberId}/messages/markAs | Mark a subscriber feed message as seen | 0.18.0 | Full | ||||
POST | /v1/subscribers/{subscriberId}/messages/mark-all | Marks all the subscriber messages as read, unread, seen or unseen. Optionally you can pass feed id (or array) to mark messages of a particular feed. | 0.18.0 | Full | ||||
POST | /v1/subscribers/{subscriberId}/messages/{messageId}/actions/{type} | Mark message action as seen | 0.18.0 | Full | ||||
GET | /v1/subscribers/{subscriberId}/credentials/{providerId}/oauth/callback | Handle providers oauth redirect | 0.18.0 | Full | ||||
GET | /v1/subscribers/{subscriberId}/credentials/{providerId}/oauth | Handle chat oauth | 0.18.0 | Full |
Topics are a way to group subscribers together so that they can be notified of events at once. A topic is identified by a custom key. This can be helpful for things like sending out marketing emails or notifying users of new features. Topics can also be used to send notifications to the subscribers who have been grouped together based on their interests, location, activities and much more.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
POST | /v1/topics | Topic creation | 0.18.0 | Full | ||||
GET | /v1/topics | Filter topics | 0.18.0 | Full | ||||
POST | /v1/topics/{topicKey}/subscribers | Subscribers addition | 0.18.0 | Full | ||||
GET | /v1/topics/{topicKey}/subscribers/{externalSubscriberId} | Check topic subscriber | 0.18.0 | Full | ||||
POST | /v1/topics/{topicKey}/subscribers/removal | Subscribers removal | 0.18.0 | Full | ||||
DELETE | /v1/topics/{topicKey} | Delete topic | 0.18.0 | Full | ||||
GET | /v1/topics/{topicKey} | Get topic | 0.18.0 | Full | ||||
PATCH | /v1/topics/{topicKey} | Rename a topic | 0.18.0 | Full |
A notification conveys information from source to recipient, triggered by a workflow acting as a message blueprint. Notifications can be individual or bundled as digest for user-friendliness.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/notifications | Get notifications | 0.18.0 | Full | ||||
GET | /v1/notifications/stats | Get notification statistics | 0.18.0 | Full | ||||
GET | /v1/notifications/graph/stats | Get notification graph statistics | 0.18.0 | Full | ||||
GET | /v1/notifications/{notificationId} | Get notification | 0.18.0 | Full |
With the help of the Integration Store, you can easily integrate your favorite delivery provider. During the runtime of the API, the Integrations Store is responsible for storing the configurations of all the providers.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/integrations | Get integrations | 0.18.0 | Full | ||||
POST | /v1/integrations | Create integration | 0.18.0 | Full | ||||
GET | /v1/integrations/active | Get active integrations | 0.18.0 | Full | ||||
GET | /v1/integrations/webhook/provider/{providerId}/status | Get webhook support status for provider | 0.18.0 | Full | ||||
PUT | /v1/integrations/{integrationId} | Update integration | 0.18.0 | Full | ||||
DELETE | /v1/integrations/{integrationId} | Delete integration | 0.18.0 | Full | ||||
POST | /v1/integrations/{integrationId}/set-primary | Set integration as primary | 0.18.0 | Full | ||||
GET | /v1/integrations/{channelType}/limit | 0.18.0 | 0.24.0 | Removed | ||||
GET | /v1/integrations/in-app/status | 0.18.0 | 0.24.0 | Removed |
Novu allows the creation of layouts - a specific HTML design or structure to wrap content of email notifications. Layouts can be manipulated and assigned to new or existing workflows within the Novu platform, allowing users to create, manage, and assign these layouts to workflows, so they can be reused to structure the appearance of notifications sent through the platform.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
POST | /v1/layouts | Layout creation | 0.18.0 | Full | ||||
GET | /v1/layouts | Filter layouts | 0.18.0 | Full | ||||
GET | /v1/layouts/{layoutId} | Get layout | 0.18.0 | Full | ||||
DELETE | /v1/layouts/{layoutId} | Delete layout | 0.18.0 | Full | ||||
PATCH | /v1/layouts/{layoutId} | Update a layout | 0.18.0 | Full | ||||
POST | /v1/layouts/{layoutId}/default | Set default layout | 0.18.0 | Full |
All notifications are sent via a workflow. Each workflow acts as a container for the logic and blueprint that are associated with a type of notification in your system.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/workflows | Get workflows | 0.18.0 | Full | ||||
POST | /v1/workflows | Create workflow | 0.18.0 | Full | ||||
PUT | /v1/workflows/{workflowId} | Update workflow | 0.18.0 | Full | ||||
DELETE | /v1/workflows/{workflowId} | Delete workflow | 0.18.0 | Full | ||||
GET | /v1/workflows/{workflowId} | Get workflow | 0.18.0 | Full | ||||
PUT | /v1/workflows/{workflowId}/status | Update workflow status | 0.18.0 | Full |
Deprecated. Use Workflows (/workflows) instead, which provide the same functionality under a new name.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/notification-templates | Get workflows | 0.18.0 | 0.19.0 | Removed | |||
POST | /v1/notification-templates | Create workflow | 0.18.0 | 0.19.0 | Removed | |||
PUT | /v1/notification-templates/{templateId} | Update workflow | 0.18.0 | 0.19.0 | Removed | |||
DELETE | /v1/notification-templates/{templateId} | Delete workflow | 0.18.0 | 0.19.0 | Removed | |||
GET | /v1/notification-templates/{templateId} | Get workflow | 0.18.0 | 0.24.0 | 0.19.0 | Removed | ||
PUT | /v1/notification-templates/{templateId}/status | Update workflow status | 0.18.0 | 0.24.0 | 0.19.0 | Removed |
Workflow groups are used to organize workflows into logical groups.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
POST | /v1/notification-groups | Create workflow group | 0.18.0 | Full | ||||
GET | /v1/notification-groups | Get workflow groups | 0.18.0 | Full | ||||
GET | /v1/notification-groups/{id} | Get workflow group | 0.18.0 | Full | ||||
PATCH | /v1/notification-groups/{id} | Update workflow group | 0.18.0 | Full | ||||
DELETE | /v1/notification-groups/{id} | Delete workflow group | 0.18.0 | Full |
Changes represent a change in state of an environment. They are analagous to a pending pull request in git, enabling you to test changes before they are applied to your environment and atomically apply them when you are ready.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/changes | Get changes | 0.18.0 | Full | ||||
GET | /v1/changes/count | Get changes count | 0.18.0 | Full | ||||
POST | /v1/changes/bulk/apply | Apply changes | 0.18.0 | Full | Unsure how this works | |||
POST | /v1/changes/{changeId}/apply | Apply change | 0.18.0 | Full | Unsure how this works |
Novu uses the concept of environments to ensure logical separation of your data and configuration. This means that subscribers, and preferences created in one environment are never accessible to another.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/environments/me | Get current environment | 0.18.0 | Full | ||||
POST | /v1/environments | Create environment | 0.18.0 | 0.24.0 | ?? | None | ||
GET | /v1/environments | Get environments | 0.18.0 | Full | ||||
PUT | /v1/environments{environmentId} | Update env by id | 0.18.0 | 0.24.0 | ?? | None | ||
GET | /v1/environments/api-keys | Get api keys | 0.18.0 | Full | ||||
POST | /v1/environments/api-keys/regenerate | Regenerate api keys | 0.18.0 | Full |
Inbound Webhook is a feature that allows processing of incoming emails for a domain or subdomain. The feature parses the contents of the email and POSTs the information to a specified URL in a multipart/form-data format.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/inbound-parse/mx/status | Validate the mx record setup for the inbound parse functionality | 0.18.0 | Full |
Novu provides a notification activity feed that monitors every outgoing message associated with its relevant metadata. This can be used to monitor activity and discover potential issues with a specific provider or a channel type.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
POST | /v1/feeds | Create feed | 0.18.0 | Full | ||||
GET | /v1/feeds | Get feeds | 0.18.0 | Full | ||||
DELETE | /v1/feeds/{feedId} | Delete feed | 0.18.0 | Full |
A tenant represents a group of users. As a developer, when your apps have organizations, they are referred to as tenants. Tenants in Novu provides the ability to tailor specific notification experiences to users of different groups or organizations.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/tenants | Get tenants | 0.19.0 | Full | ||||
POST | /v1/tenants | Create tenant | 0.19.0 | Full | ||||
GET | /v1/tenants/{identifier} | Get tenant | 0.19.0 | Full | ||||
PATCH | /v1/tenants/{identifier} | Update tenant | 0.19.0 | Full | ||||
DELETE | /v1/tenants/{identifier} | Delete tenant | 0.19.0 | Full |
A message in Novu represents a notification delivered to a recipient on a particular channel. Messages contain information about the request that triggered its delivery, a view of the data sent to the recipient, and a timeline of its lifecycle events. Learn more about messages.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/messages | Get messages | 0.18.0 | Full | ||||
DELETE | /v1/messages/{messageId} | Delete message | 0.18.0 | Full | ||||
DELETE | /v1/messages/transaction/{transactionId} | Delete messages by transactionId | 0.18.0 | Full |
An organization serves as a separate entity within your Novu account. Each organization you create has its own separate integration store, workflows, subscribers, and API keys. This separation of resources allows you to manage multi-tenant environments and separate domains within a single account.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
POST | /v1/organizations | Create an organization | 0.19.0 | Full | ||||
GET | /v1/organizations | Fetch all organizations | 0.19.0 | Full | ||||
PATCH | /v1/organizations | Rename organization name | 0.19.0 | Full | ||||
GET | /v1/organizations/me | Fetch current organization details | 0.19.0 | Full | ||||
DELETE | /v1/organizations/members/{memberId} | Remove a member from organization using memberId | 0.19.0 | Full | ||||
PUT | /v1/organizations/members/{memberId}/roles | Update a member role to admin | 0.19.0 | ?? | Removed | |||
GET | /v1/organizations/members | Fetch all members of current organizations | 0.19.0 | Full | ||||
PUT | /v1/organizations/branding | Update organization branding details | 0.19.0 | Full |
Execution details are used to track the execution of a workflow. They provided detailed information on the execution of a workflow, including the status of each step, the input and output of each step, and the overall status of the execution.
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/execution-details | Get execution details | 0.18.0 | Full |
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
GET | /v1/blueprints/group-by-category | 0.19.0 | Full | |||||
GET | /v1/blueprints/list | 0.19.0 | 0.24.0 | None | ||||
GET | /v1/blueprints/{templateIdOrIdentifier} | 0.19.0 | Full | Throws 500 error on wrong id |
HTTP Method | Endpoint | Description | New | Changed | Deleted | Deprecated | Compatability | Notes |
---|---|---|---|---|---|---|---|---|
POST | /v1/workflow-overrides | Create a workflow override | 0.19.0 | Full | ||||
GET | /v1/workflow-overrides | Get workflow overrides | 0.19.0 | Full | ||||
PUT | /v1/workflow-overrides/{overrideId} | Update workflow by override id | 0.19.0 | Full | ||||
GET | /v1/workflow-overrides/{overrideId} | Get workflow override by id | 0.19.0 | Full | ||||
DELETE | /v1/workflow-overrides/{overrideId} | Delete workflow override | 0.19.0 | Full | ||||
PUT | /v1/workflow-overrides/workflows/{workflowId}/tenants/{tenantId} | Update workflow override | 0.19.0 | Full | ||||
GET | /v1/workflow-overrides/workflows/{workflowId}/tenants/{tenantId} | Get workflow override | 0.19.0 | Full |