DotNetBrightener.Plugins.EventPubSub
2024.0.12.14314
See the version list below for details.
dotnet add package DotNetBrightener.Plugins.EventPubSub --version 2024.0.12.14314
NuGet\Install-Package DotNetBrightener.Plugins.EventPubSub -Version 2024.0.12.14314
<PackageReference Include="DotNetBrightener.Plugins.EventPubSub" Version="2024.0.12.14314" />
paket add DotNetBrightener.Plugins.EventPubSub --version 2024.0.12.14314
#r "nuget: DotNetBrightener.Plugins.EventPubSub, 2024.0.12.14314"
// Install DotNetBrightener.Plugins.EventPubSub as a Cake Addin
#addin nuget:?package=DotNetBrightener.Plugins.EventPubSub&version=2024.0.12.14314
// Install DotNetBrightener.Plugins.EventPubSub as a Cake Tool
#tool nuget:?package=DotNetBrightener.Plugins.EventPubSub&version=2024.0.12.14314
Event Publish/Subscribe Library
© DotNet Brightener
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 | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net8.0
- DotNetBrightener.Plugins.EventPubSub.Abstractions (>= 2024.0.12.14314)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
NuGet packages (10)
Showing the top 5 NuGet packages that depend on DotNetBrightener.Plugins.EventPubSub:
Package | Downloads |
---|---|
DotNetBrightener.Core.BackgroundTasks
Package Description |
|
DotNetBrightener.Plugins.EventPubSub.DependencyInjection
Package Description |
|
DotNetBrightener.SimpleUploadService
A Simple Upload API for ASP.NET Core Applications |
|
DotNetBrightener.WebApp.CommonShared
Package Description |
|
DotNetBrightener.Infrastructure.ApiKeyAuthentication
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2024.0.14.1 | 113 | 6/6/2024 |
2024.0.14.1-preview | 100 | 6/6/2024 |
2024.0.14-preview-1 | 102 | 6/6/2024 |
2024.0.13.8-preview | 115 | 6/6/2024 |
2024.0.13.1-preview-0146 | 124 | 6/6/2024 |
2024.0.12.15803-preview-03 | 104 | 6/6/2024 |
2024.0.12.15608 | 110 | 6/4/2024 |
2024.0.12.15515 | 140 | 6/3/2024 |
2024.0.12.15220 | 103 | 5/31/2024 |
2024.0.12.15220-alpha31-240... | 90 | 5/31/2024 |
2024.0.12.14911 | 147 | 5/28/2024 |
2024.0.12.14910-alpha28-240... | 113 | 5/28/2024 |
2024.0.12.14823 | 122 | 5/27/2024 |
2024.0.12.14522-alpha7-2405... | 124 | 5/24/2024 |
2024.0.12.14514-alpha6-2405... | 118 | 5/24/2024 |
2024.0.12.14511 | 137 | 5/24/2024 |
2024.0.12.14314 | 175 | 5/22/2024 |
2024.0.12.14114 | 192 | 5/20/2024 |
2024.0.12.12815 | 200 | 5/7/2024 |
2024.0.12.12814 | 168 | 5/7/2024 |
2024.0.12.12721 | 183 | 5/6/2024 |
2024.0.12.12702 | 171 | 5/5/2024 |
2024.0.12.12622 | 182 | 5/5/2024 |
2024.0.12.12514 | 155 | 5/4/2024 |
2024.0.12.12512 | 159 | 5/4/2024 |
2024.0.12.12510 | 151 | 5/4/2024 |
2024.0.12.12420 | 136 | 5/3/2024 |
2024.0.12.12319 | 108 | 5/2/2024 |
2024.0.12.12319-rc-2405021801 | 103 | 5/2/2024 |
2024.0.12.12318 | 109 | 5/2/2024 |
2024.0.12.12215 | 156 | 5/1/2024 |
2024.0.12.12011 | 138 | 4/29/2024 |
2024.0.12.11720 | 152 | 4/26/2024 |
2024.0.12.11719 | 146 | 4/26/2024 |
2024.0.12.11621 | 183 | 4/25/2024 |
2024.0.12.11523 | 158 | 4/24/2024 |
2024.0.12.11522 | 165 | 4/24/2024 |
2024.0.12.11417 | 154 | 4/23/2024 |
2024.0.12.11400 | 154 | 4/22/2024 |
2024.0.12.11316 | 151 | 4/22/2024 |
2024.0.11.10220 | 141 | 4/11/2024 |
2024.0.11.10120 | 121 | 4/10/2024 |
2024.0.11.10119 | 115 | 4/10/2024 |
2024.0.11.10115 | 127 | 4/10/2024 |
2024.0.11.9914 | 140 | 4/8/2024 |
2024.0.11.9901 | 126 | 4/7/2024 |
2024.0.11.9823 | 130 | 4/7/2024 |
2024.0.11.9401 | 134 | 4/2/2024 |
2024.0.11.9301 | 120 | 4/1/2024 |
2024.0.11.9206 | 120 | 3/31/2024 |
2024.0.11.9205 | 112 | 3/31/2024 |
2024.0.11.8200 | 142 | 3/21/2024 |
2024.0.11.8122 | 107 | 3/21/2024 |
2024.0.11.8120 | 127 | 3/21/2024 |
2024.0.11.7320 | 170 | 3/13/2024 |
2024.0.11.7316 | 134 | 3/13/2024 |
2024.0.11.7310 | 126 | 3/13/2024 |
2024.0.11 | 134 | 3/13/2024 |
2024.0.10 | 147 | 3/3/2024 |
2024.0.9 | 147 | 2/27/2024 |
2024.0.8 | 182 | 2/1/2024 |
2024.0.7 | 133 | 1/26/2024 |
2024.0.6 | 125 | 1/25/2024 |
2024.0.5 | 124 | 1/24/2024 |
2024.0.4 | 121 | 1/24/2024 |
2024.0.3 | 136 | 1/22/2024 |
2024.0.2 | 184 | 1/10/2024 |
2024.0.1 | 139 | 1/9/2024 |
2024.0.1-alpha-3 | 112 | 1/9/2024 |
2024.0.1-alpha-2 | 101 | 1/9/2024 |
2024.0.1-alpha-1 | 136 | 1/3/2024 |
2024.0.0 | 172 | 12/26/2023 |
2023.0.27 | 217 | 12/21/2023 |
2023.0.26 | 175 | 12/21/2023 |
2023.0.25 | 237 | 12/11/2023 |
2023.0.24 | 225 | 12/8/2023 |
2023.0.23 | 189 | 12/6/2023 |
2023.0.21 | 250 | 12/4/2023 |
2023.0.20 | 246 | 11/27/2023 |
2023.0.19 | 180 | 11/20/2023 |
2023.0.18 | 221 | 10/25/2023 |
2023.0.17 | 269 | 10/22/2023 |
2023.0.16 | 249 | 10/16/2023 |
2023.0.16-alpha-1 | 139 | 10/16/2023 |
2023.0.15 | 207 | 10/14/2023 |
2023.0.14 | 182 | 10/14/2023 |
2023.0.13 | 167 | 10/14/2023 |
2023.0.12 | 194 | 10/14/2023 |
2023.0.11 | 179 | 10/10/2023 |
2023.0.10 | 197 | 10/9/2023 |
2023.0.9 | 318 | 8/16/2023 |
2023.0.8 | 245 | 8/15/2023 |
2023.0.8-alpha-2 | 311 | 5/31/2023 |
2023.0.7 | 266 | 5/12/2023 |
2023.0.6 | 296 | 5/10/2023 |
2023.0.5 | 270 | 5/7/2023 |
2023.0.4 | 299 | 4/22/2023 |
2023.0.3 | 331 | 4/19/2023 |
2023.0.2 | 328 | 4/6/2023 |
2023.0.1 | 355 | 3/13/2023 |
2022.11.0 | 413 | 11/21/2022 |
2022.10.2 | 321 | 11/21/2022 |
2022.10.0 | 1,602 | 10/15/2022 |
2022.9.0 | 487 | 9/5/2022 |
2021.10.1 | 468 | 10/17/2021 |
1.0.0 | 481 | 1/19/2021 |