The Notification Service is made up of two parts the notification type and the notification distribution type. The INotificationType defines your notification and allows you to setup the name, permissions and message. When a notification event is triggered then the INotificationDistributionTypeis responsible for sending the notification via a particular medium. Out of the box Telligent Community provides two distribution types, the email and socket (toast) distribution types.
[toc]
Why Should I Create a Notification Type?
New notification types are useful when you want to notify community members about specific events in the community, either events that occur with core functionality or because of new functionality added to the platform.
Why Should I Create a Notification Distribution Type?
Besides sending a notification via email or toast notification a new distribution type can send a notification through another medium. For example you could setup a notification distribution using a text messaging platform. Defining a distribution type is out of scope for this document.
Creating an INotificationType
To add support for sending notifications through Telligent Community the INotificationType plugin must be implemented. The INotificationType
interface extends IPlugin and the following assemblies must also be referenced in your plugin Telligent.Evolution.Components.dll, Telligent.Evolution.Api and Telligent.Evolution.Core.
When creating a NotificationType plugin use an event handler to create a notification. For instance, if a user comments on content an event handler can be created for the event in the plugin's Initialize method. Then the notification can be sent by using the controller.
When SetController
is called the plugin's instance of the notification controller is passed to the INotificationType
. This is a crucial part of the notification plugin. If you do not define a private INotificationController seen here as _notificationController you cannot send notifications.
In the AddNotifications method the INotificationController is used. When the CreateUpdate
method is called one of two processes will occur. If a notification matching the ContentId and ContentTypeId exists it will modify the notification accordingly. If the notification does not exist, it will create one.
Alternatively there is also a Delete
method in the INotificationController, this can be used if a BeforeDelete
event handler is implemented.
It is also possible to add ExtendedAttibutes if you need to pass other information when rendering the message. In this example we define the content id and type to be used later in the GetTargetUrl
method and save the comment id as an ExtendedAttribute so it can later be used in GetMessage
.
Begin by choosing a name and description for the notification type, this is different than the plugin name. It will be displayed in the user's settings page under the Notification's tab.
The NotificationTypeId
is the unique ID for the notification type.
To tell the system if the notification data can and should be cached the IsCacheable
property is used. The other cache property, VaryCacheByUser
, tells the system if the notification data should be cached according to each user.
It is necessary to define if a user can delete a notification. This value tells the system if the user attempting to delete the notification is allowed to do so. In this sample, deleting is allowed only by the recipient which is defined by the UserId in the notification.
The GetMessage
returns a string value of the message being sent to the user. Here the ExtendedAttributes
can be accessed, the information was passed in from the create notification in CommentEvents_AfterCreate
.
The GetTargetUrl
will contain the URL where the content is located and returns a string value of the location. In this sample the comment contains the content Id and type that it is associated with.
Here is the complete sample.
In this sample the notification is displayed when a comment is created. To enable the plugin, in the administration panel, navigate to the Notifications menu and find the "My Notifications Plugin" check Enabled and click Save. Create a comment and notice the toast notification.
This is a sample of the toast notification.