DotNetBrightener.Plugins.EventPubSub 2024.0.1-alpha-2

This is a prerelease version of DotNetBrightener.Plugins.EventPubSub.
There is a newer version of this package available.
See the version list below for details.
dotnet add package DotNetBrightener.Plugins.EventPubSub --version 2024.0.1-alpha-2
                    
NuGet\Install-Package DotNetBrightener.Plugins.EventPubSub -Version 2024.0.1-alpha-2
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="DotNetBrightener.Plugins.EventPubSub" Version="2024.0.1-alpha-2" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="DotNetBrightener.Plugins.EventPubSub" Version="2024.0.1-alpha-2" />
                    
Directory.Packages.props
<PackageReference Include="DotNetBrightener.Plugins.EventPubSub" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add DotNetBrightener.Plugins.EventPubSub --version 2024.0.1-alpha-2
                    
#r "nuget: DotNetBrightener.Plugins.EventPubSub, 2024.0.1-alpha-2"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package DotNetBrightener.Plugins.EventPubSub@2024.0.1-alpha-2
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=DotNetBrightener.Plugins.EventPubSub&version=2024.0.1-alpha-2&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=DotNetBrightener.Plugins.EventPubSub&version=2024.0.1-alpha-2&prerelease
                    
Install as a Cake Tool

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 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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
2025.0.10-preview-581 320 11/11/2025
2025.0.10-preview-559 303 10/29/2025
2025.0.10-preview-557 299 10/27/2025
2025.0.9 304 10/26/2025
2025.0.9-preview-553 287 10/26/2025
2025.0.9-preview-539 241 10/12/2025
2025.0.9-preview-535 293 10/8/2025
2025.0.9-preview-509 306 10/2/2025
2025.0.9-preview-508 292 10/2/2025
2025.0.9-preview-487 313 9/29/2025
2025.0.9-preview-481 325 9/29/2025
2025.0.9-preview-473 280 9/28/2025
2025.0.8 340 9/23/2025
2025.0.6 332 9/22/2025
2025.0.6-preview-455 329 9/22/2025
2025.0.6-preview-454 411 9/17/2025
2025.0.6-preview-441 243 9/14/2025
2025.0.6-preview-440 254 9/14/2025
2025.0.6-preview-406 285 9/2/2025
2025.0.6-preview-401 270 9/2/2025
2025.0.6-preview-400 267 9/2/2025
2025.0.6-preview-369 323 8/27/2025
2025.0.6-preview-368 310 8/27/2025
2025.0.6-preview-334 297 8/18/2025
2025.0.6-preview-333 232 7/27/2025
2025.0.6-preview-332 564 7/24/2025
2025.0.6-preview-331 572 7/24/2025
2025.0.6-preview-328 564 7/24/2025
2025.0.6-preview-327 472 7/21/2025
2025.0.6-preview-326 471 7/21/2025
2025.0.6-preview-325 371 7/20/2025
2025.0.6-preview-324 367 7/20/2025
2025.0.6-preview-322 361 7/20/2025
2025.0.6-preview-321 356 7/19/2025
2025.0.6-preview-320 373 7/19/2025
2025.0.6-preview-319 278 7/17/2025
2025.0.6-preview-317 273 7/17/2025
2025.0.6-preview-316 278 7/17/2025
2025.0.6-preview-315 276 7/17/2025
2025.0.6-preview-314 267 7/17/2025
2025.0.6-preview-313 270 7/17/2025
2025.0.6-preview-312 289 7/16/2025
2025.0.5 297 7/10/2025
2025.0.5-preview-307 228 7/5/2025
2025.0.4 218 7/5/2025
2025.0.4-preview-305 220 7/4/2025
2025.0.4-preview-304 282 7/1/2025
2025.0.4-preview-299 275 5/31/2025
2025.0.4-preview-298 239 5/30/2025
2025.0.4-preview-296 283 5/30/2025
2025.0.4-preview-295 289 5/29/2025
2025.0.4-preview-293 297 5/26/2025
2025.0.4-preview-292 312 5/26/2025
2025.0.3 310 2/10/2025
2025.0.3-preview-288 275 2/10/2025
2025.0.2 302 1/21/2025
2025.0.2-preview-278 266 1/21/2025
2025.0.2-preview-277 273 12/16/2024
2025.0.1-rc-243301701 606 11/25/2024
2024.0.14.6 335 11/25/2024
2024.0.14.6-rc-243031001 389 10/29/2024
2024.0.14.6-rc-243030701 344 10/29/2024
2024.0.14.6-rc-242840501 317 10/10/2024
2024.0.14.6-rc-242820305 326 10/8/2024
2024.0.14.6-rc-242771401 510 10/3/2024
2024.0.14.6-rc-242770501 297 10/3/2024
2024.0.14.6-rc-242770201 327 10/3/2024
2024.0.14.6-rc-242761801 305 10/2/2024
2024.0.14.6-rc-242761601 340 10/2/2024
2024.0.14.6-rc-242761501 312 10/2/2024
2024.0.14.6-rc-242761401 331 10/2/2024
2024.0.14.6-rc-242760701 335 10/2/2024
2024.0.14.6-rc-242751002 339 10/1/2024
2024.0.14.6-rc-242750901 351 10/1/2024
2024.0.14.6-rc-242750502 332 10/1/2024
2024.0.14.6-rc-242750201 362 10/1/2024
2024.0.14.6-rc-242741501 340 9/30/2024
2024.0.14.6-rc-242730701 348 9/29/2024
2024.0.14.6-preview-2730501 293 9/29/2024
2024.0.14.6-preview-2701501 341 9/26/2024
2024.0.14.6-preview-2620901 356 9/18/2024
2024.0.14.6-preview-2570701 358 9/13/2024
2024.0.14.6-preview-2510703 420 9/7/2024
2024.0.14.6-preview-2480501 438 9/4/2024
2024.0.14.6-preview-2430401 381 8/30/2024
2024.0.14.6-preview-242730701 319 9/29/2024
2024.0.14.6-preview-2421703 338 8/29/2024
2024.0.14.6-preview-2421701 312 8/29/2024
2024.0.14.6-preview-2420901 316 8/29/2024
2024.0.14.6-preview-2390101 338 8/26/2024
2024.0.14.6-preview-2381603 319 8/25/2024
2024.0.14.6-preview-2341601 345 8/21/2024
2024.0.14.6-preview-2321602 318 8/20/2024
2024.0.14.6-preview-2190801 336 8/6/2024
2024.0.14.6-preview-2041501 292 7/22/2024
2024.0.14.6-preview-1920603 363 7/10/2024
2024.0.14.6-preview-1920301 290 7/10/2024
2024.0.14.6-preview-1911302 304 7/9/2024
2024.0.14.6-preview-1901001 299 7/8/2024
2024.0.14.6-preview-1900901 269 7/8/2024
2024.0.14.6-preview-1900801 306 7/8/2024
2024.0.14.6-preview-1860304 276 7/4/2024
2024.0.14.5 396 7/1/2024
2024.0.14.5-preview-1811601 327 6/29/2024
2024.0.14.5-preview-1810501 336 6/29/2024
2024.0.14.5-preview-180132 338 6/28/2024
2024.0.14.5-preview-180131 298 6/28/2024
2024.0.14.5-preview-180121 297 6/28/2024
2024.0.14.4 415 6/27/2024
2024.0.14.4-preview-7 314 6/27/2024
2024.0.14.3 326 6/21/2024
2024.0.14.1 323 6/6/2024
2024.0.14.1-preview 295 6/6/2024
2024.0.14-preview-1 271 6/6/2024
2024.0.13.8-preview 347 6/6/2024
2024.0.13.1-preview-0146 350 6/6/2024
2024.0.12.15803-preview-03 301 6/6/2024
2024.0.12.15608 328 6/4/2024
2024.0.12.15515 404 6/3/2024
2024.0.12.15220 321 5/31/2024
2024.0.12.15220-alpha31-240... 279 5/31/2024
2024.0.12.14911 373 5/28/2024
2024.0.12.14910-alpha28-240... 309 5/28/2024
2024.0.12.14823 322 5/27/2024
2024.0.12.14522-alpha7-2405... 302 5/24/2024
2024.0.12.14514-alpha6-2405... 302 5/24/2024
2024.0.12.14511 339 5/24/2024
2024.0.12.14314 376 5/22/2024
2024.0.12.14114 486 5/20/2024
2024.0.12.12815 487 5/7/2024
2024.0.12.12814 441 5/7/2024
2024.0.12.12721 448 5/6/2024
2024.0.12.12702 435 5/5/2024
2024.0.12.12622 435 5/5/2024
2024.0.12.12514 425 5/4/2024
2024.0.12.12512 428 5/4/2024
2024.0.12.12510 430 5/4/2024
2024.0.12.12420 394 5/3/2024
2024.0.12.12319 373 5/2/2024
2024.0.12.12319-rc-2405021801 330 5/2/2024
2024.0.12.12318 347 5/2/2024
2024.0.12.12215 395 5/1/2024
2024.0.12.12011 344 4/29/2024
2024.0.12.11720 356 4/26/2024
2024.0.12.11719 359 4/26/2024
2024.0.12.11621 400 4/25/2024
2024.0.12.11523 395 4/24/2024
2024.0.12.11522 380 4/24/2024
2024.0.12.11417 367 4/23/2024
2024.0.12.11400 363 4/22/2024
2024.0.12.11316 350 4/22/2024
2024.0.11.10220 315 4/11/2024
2024.0.11.10120 295 4/10/2024
2024.0.11.10119 267 4/10/2024
2024.0.11.10115 297 4/10/2024
2024.0.11.9914 308 4/8/2024
2024.0.11.9901 317 4/7/2024
2024.0.11.9823 321 4/7/2024
2024.0.11.9401 305 4/2/2024
2024.0.11.9301 329 4/1/2024
2024.0.11.9206 286 3/31/2024
2024.0.11.9205 311 3/31/2024
2024.0.11.8200 330 3/21/2024
2024.0.11.8122 284 3/21/2024
2024.0.11.8120 311 3/21/2024
2024.0.11.7320 360 3/13/2024
2024.0.11.7316 313 3/13/2024
2024.0.11.7310 326 3/13/2024
2024.0.11 314 3/13/2024
2024.0.10 330 3/3/2024
2024.0.9 337 2/27/2024
2024.0.8 378 2/1/2024
2024.0.7 324 1/26/2024
2024.0.6 313 1/25/2024
2024.0.5 302 1/24/2024
2024.0.4 305 1/24/2024
2024.0.3 309 1/22/2024
2024.0.2 363 1/10/2024
2024.0.1 316 1/9/2024
2024.0.1-alpha-3 295 1/9/2024
2024.0.1-alpha-2 310 1/9/2024
2024.0.1-alpha-1 323 1/3/2024
2024.0.0 374 12/26/2023
2023.0.27 429 12/21/2023
2023.0.26 377 12/21/2023
2023.0.25 441 12/11/2023
2023.0.24 428 12/8/2023
2023.0.23 405 12/6/2023
2023.0.21 484 12/4/2023
2023.0.20 459 11/27/2023
2023.0.19 390 11/20/2023
2023.0.18 431 10/25/2023
2023.0.17 459 10/22/2023
2023.0.16 462 10/16/2023
2023.0.16-alpha-1 343 10/16/2023
2023.0.15 411 10/14/2023
2023.0.14 385 10/14/2023
2023.0.13 370 10/14/2023
2023.0.12 395 10/14/2023
2023.0.11 380 10/10/2023
2023.0.10 391 10/9/2023
2023.0.9 558 8/16/2023
2023.0.8 456 8/15/2023
2023.0.8-alpha-2 558 5/31/2023
2023.0.7 506 5/12/2023
2023.0.6 684 5/10/2023
2023.0.5 517 5/7/2023
2023.0.4 554 4/22/2023
2023.0.3 581 4/19/2023
2023.0.2 584 4/6/2023
2023.0.1 574 3/13/2023
2022.11.0 549 11/21/2022
2022.10.2 440 11/21/2022
2022.10.0 1,944 10/15/2022
2022.9.0 625 9/5/2022
2021.10.1 630 10/17/2021
1.0.0 670 1/19/2021