DotNetBrightener.Plugins.EventPubSub.Abstractions 2025.0.4-preview-304

This is a prerelease version of DotNetBrightener.Plugins.EventPubSub.Abstractions.
There is a newer version of this package available.
See the version list below for details.
dotnet add package DotNetBrightener.Plugins.EventPubSub.Abstractions --version 2025.0.4-preview-304
                    
NuGet\Install-Package DotNetBrightener.Plugins.EventPubSub.Abstractions -Version 2025.0.4-preview-304
                    
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.Abstractions" Version="2025.0.4-preview-304" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="DotNetBrightener.Plugins.EventPubSub.Abstractions" Version="2025.0.4-preview-304" />
                    
Directory.Packages.props
<PackageReference Include="DotNetBrightener.Plugins.EventPubSub.Abstractions" />
                    
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.Abstractions --version 2025.0.4-preview-304
                    
#r "nuget: DotNetBrightener.Plugins.EventPubSub.Abstractions, 2025.0.4-preview-304"
                    
#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.Abstractions@2025.0.4-preview-304
                    
#: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.Abstractions&version=2025.0.4-preview-304&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=DotNetBrightener.Plugins.EventPubSub.Abstractions&version=2025.0.4-preview-304&prerelease
                    
Install as a Cake Tool

Event Publish/Subscribe Library

© DotNet Brightener

NuGet Version

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 net9.0 is compatible.  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 (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
2025.0.6-preview-319 0 7/17/2025
2025.0.6-preview-317 0 7/17/2025
2025.0.6-preview-316 0 7/17/2025
2025.0.6-preview-315 0 7/17/2025
2025.0.6-preview-314 0 7/17/2025
2025.0.6-preview-313 0 7/17/2025
2025.0.6-preview-312 40 7/16/2025
2025.0.5 256 7/10/2025
2025.0.5-preview-307 191 7/5/2025
2025.0.4 193 7/5/2025
2025.0.4-preview-305 215 7/4/2025
2025.0.4-preview-304 259 7/1/2025
2025.0.4-preview-299 236 5/31/2025
2025.0.4-preview-298 219 5/30/2025
2025.0.4-preview-296 253 5/30/2025
2025.0.4-preview-295 268 5/29/2025
2025.0.4-preview-293 273 5/26/2025
2025.0.4-preview-292 270 5/26/2025
2025.0.3 270 2/10/2025
2025.0.3-preview-288 257 2/10/2025
2025.0.2 268 1/21/2025
2025.0.2-preview-278 240 1/21/2025
2025.0.2-preview-277 257 12/16/2024
2025.0.1-rc-243301701 532 11/25/2024
2024.0.14.6 316 11/25/2024
2024.0.14.6-rc-243031001 390 10/29/2024
2024.0.14.6-rc-243030701 327 10/29/2024
2024.0.14.6-rc-242840501 312 10/10/2024
2024.0.14.6-rc-242820305 299 10/8/2024
2024.0.14.6-rc-242771401 463 10/3/2024
2024.0.14.6-rc-242770501 297 10/3/2024
2024.0.14.6-rc-242770201 297 10/3/2024
2024.0.14.6-rc-242761801 305 10/2/2024
2024.0.14.6-rc-242761601 317 10/2/2024
2024.0.14.6-rc-242761501 304 10/2/2024
2024.0.14.6-rc-242761401 315 10/2/2024
2024.0.14.6-rc-242760701 322 10/2/2024
2024.0.14.6-rc-242751002 318 10/1/2024
2024.0.14.6-rc-242750901 333 10/1/2024
2024.0.14.6-rc-242750502 324 10/1/2024
2024.0.14.6-rc-242750201 340 10/1/2024
2024.0.14.6-rc-242741501 309 9/30/2024
2024.0.14.6-rc-242730701 335 9/29/2024
2024.0.14.6-preview-2730501 292 9/29/2024
2024.0.14.6-preview-2701501 324 9/26/2024
2024.0.14.6-preview-2620901 358 9/18/2024
2024.0.14.6-preview-2570701 362 9/13/2024
2024.0.14.6-preview-2510703 451 9/7/2024
2024.0.14.6-preview-2480501 467 9/4/2024
2024.0.14.6-preview-2430401 408 8/30/2024
2024.0.14.6-preview-242730701 324 9/29/2024
2024.0.14.6-preview-2421703 345 8/29/2024
2024.0.14.6-preview-2421701 337 8/29/2024
2024.0.14.6-preview-2420901 329 8/29/2024
2024.0.14.6-preview-2390101 369 8/26/2024
2024.0.14.6-preview-2381603 340 8/25/2024
2024.0.14.6-preview-2341601 365 8/21/2024
2024.0.14.6-preview-2321602 331 8/20/2024
2024.0.14.6-preview-2190801 323 8/6/2024
2024.0.14.6-preview-2041501 302 7/22/2024
2024.0.14.6-preview-1920603 369 7/10/2024
2024.0.14.6-preview-1920301 321 7/10/2024
2024.0.14.6-preview-1911302 324 7/9/2024
2024.0.14.6-preview-1901001 323 7/8/2024
2024.0.14.6-preview-1900901 294 7/8/2024
2024.0.14.6-preview-1900801 292 7/8/2024
2024.0.14.6-preview-1860304 305 7/4/2024
2024.0.14.5 409 7/1/2024
2024.0.14.5-preview-1811601 319 6/29/2024
2024.0.14.5-preview-1810501 343 6/29/2024
2024.0.14.5-preview-180132 394 6/28/2024
2024.0.14.5-preview-180131 326 6/28/2024
2024.0.14.5-preview-180121 318 6/28/2024
2024.0.14.4 469 6/27/2024
2024.0.14.4-preview-7 343 6/27/2024
2024.0.14.3 366 6/21/2024
2024.0.14.1 348 6/6/2024
2024.0.14.1-preview 326 6/6/2024
2024.0.14-preview-1 306 6/6/2024
2024.0.13.8-preview 347 6/6/2024
2024.0.13.1-preview-0146 384 6/6/2024
2024.0.12.15803-preview-03 317 6/6/2024
2024.0.12.15608 341 6/4/2024
2024.0.12.15515 397 6/3/2024
2024.0.12.15220 322 5/31/2024
2024.0.12.15220-alpha31-240... 309 5/31/2024
2024.0.12.14911 370 5/28/2024
2024.0.12.14910-alpha28-240... 329 5/28/2024
2024.0.12.14823 362 5/27/2024
2024.0.12.14522-alpha7-2405... 323 5/24/2024
2024.0.12.14514-alpha6-2405... 338 5/24/2024
2024.0.12.14511 374 5/24/2024
2024.0.12.14314 409 5/22/2024