DotNetBrightener.Plugins.EventPubSub.Abstractions
2026.0.2
See the version list below for details.
dotnet add package DotNetBrightener.Plugins.EventPubSub.Abstractions --version 2026.0.2
NuGet\Install-Package DotNetBrightener.Plugins.EventPubSub.Abstractions -Version 2026.0.2
<PackageReference Include="DotNetBrightener.Plugins.EventPubSub.Abstractions" Version="2026.0.2" />
<PackageVersion Include="DotNetBrightener.Plugins.EventPubSub.Abstractions" Version="2026.0.2" />
<PackageReference Include="DotNetBrightener.Plugins.EventPubSub.Abstractions" />
paket add DotNetBrightener.Plugins.EventPubSub.Abstractions --version 2026.0.2
#r "nuget: DotNetBrightener.Plugins.EventPubSub.Abstractions, 2026.0.2"
#:package DotNetBrightener.Plugins.EventPubSub.Abstractions@2026.0.2
#addin nuget:?package=DotNetBrightener.Plugins.EventPubSub.Abstractions&version=2026.0.2
#tool nuget:?package=DotNetBrightener.Plugins.EventPubSub.Abstractions&version=2026.0.2
Event Publish/Subscribe Library
Copyright © 2017 - 2026 Vampire Coder (formerly DotnetBrightener)
Usage
Event message
Event message is a message that would be emitted by the IEventPublisher. The IEventHandler for the message will be proceeded sequentially, and will be stopped if the higher-prioritized handler tells the next one to stop by returning false in its HandleEvent method.
public class YourEventMessage: IEventMessage
{
// your model goes here
}
Non-Stopped event message
Non-stopped event message is the type of IEventMessage that will be handled by all the handlers regardless the result from the process of each handler.
public class YourEventMessage: INonStoppedEventMessage
{
// your model goes here
}
Define event handler
Define an event handler to process the event emitted by the IEventPublisher service as follow:
public class YourEventModelEventHandler: IEventHandler<YourEventMessage>
{
// the higher number will tell the publisher to execute before the others
public int Priority { get; } => 10;
public async Task<bool> HandleEvent(YourEventMessage eventMessage)
{
// do something with your eventMessage
// if YourEventModel implements INonStoppedEventMessage,
// regardless the next statement,
// the next handler will continue to process in parallel
// if you want to let the next handler to process the message
return true;
// otherwise, return false here;
// return false;
}
}
Emit the event
Inject IEventPublisher to your controller / service class and use it as follow:
public class SomeService
{
private readonly IEventPublisher _eventPublisher;
// other services
public SomeService(IEventPublisher eventPublisher,
// other services
)
{
_eventPublisher = eventPublisher;
}
public async Task SomeMethod()
{
var eventMessage = new YourEventMessage
{
// the event content
};
// if you want to let the event message to be processed in the current thread
await _eventPublisher.Publish(eventMessage);
// if you want to let the event message to be processed in the another thread
await _eventPublisher.Publish(eventMessage, true);
}
}
Register at startup
You will need to install the package DotNetBrightener.Plugins.EventPubSub.DependencyInjection from nuget.org and follow instruction there.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net10.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.5)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.5)
- Microsoft.Testing.Platform (>= 2.1.0)
- Newtonsoft.Json (>= 13.0.4)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on DotNetBrightener.Plugins.EventPubSub.Abstractions:
| Package | Downloads |
|---|---|
|
DotNetBrightener.Plugins.EventPubSub
An event publisher / subscriber library for .Net Core Application |
|
|
DotNetBrightener.DataAccess.Abstractions.Models
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2026.0.3-preview-772 | 278 | 4/3/2026 |
| 2026.0.3-preview-770 | 323 | 4/2/2026 |
| 2026.0.3-preview-769 | 316 | 4/2/2026 |
| 2026.0.2 | 331 | 4/2/2026 |
| 2026.0.2-preview-v2026-0-1-755 | 514 | 3/27/2026 |
| 2026.0.2-preview-759 | 368 | 4/1/2026 |
| 2026.0.2-preview-758 | 386 | 3/29/2026 |
| 2026.0.2-preview-757 | 401 | 3/29/2026 |
| 2026.0.2-preview-756 | 385 | 3/27/2026 |
| 2026.0.2-preview-754 | 372 | 3/27/2026 |
| 2026.0.1 | 393 | 3/27/2026 |
| 2026.0.1-preview-752 | 368 | 3/26/2026 |
| 2026.0.1-preview-750 | 368 | 3/26/2026 |
| 2026.0.1-preview-749 | 370 | 3/25/2026 |
| 2026.0.1-preview-748 | 665 | 3/23/2026 |
| 2026.0.1-preview-742 | 374 | 3/22/2026 |
| 2026.0.1-preview-741 | 447 | 3/16/2026 |
| 2025.0.11-preview-771 | 426 | 4/2/2026 |
| 2025.0.11-preview-768 | 414 | 4/2/2026 |
| 2025.0.11-preview-762 | 418 | 4/2/2026 |