Fusonic.Extensions.Hangfire 8.1.0

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package Fusonic.Extensions.Hangfire --version 8.1.0                
NuGet\Install-Package Fusonic.Extensions.Hangfire -Version 8.1.0                
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="Fusonic.Extensions.Hangfire" Version="8.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Fusonic.Extensions.Hangfire --version 8.1.0                
#r "nuget: Fusonic.Extensions.Hangfire, 8.1.0"                
#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.
// Install Fusonic.Extensions.Hangfire as a Cake Addin
#addin nuget:?package=Fusonic.Extensions.Hangfire&version=8.1.0

// Install Fusonic.Extensions.Hangfire as a Cake Tool
#tool nuget:?package=Fusonic.Extensions.Hangfire&version=8.1.0                

Hangfire

Out-Of-Band Processing of CQRS Command and Event-Handlers

When applying CQRS, it allows us to easily decorate handlers with generic decorators. By applying the Fusonic.Extensions.Common.OutOfBandAttribute, you can decorate handlers which are allowed to run outside of the current flow. Whenever this handler gets called, the execution pipeline looks for the attribute on the handler. If the attribute is available, the handler is scheduled for async execution, meaning it runs “out of band” of the current logical flow. That means that the message will be stored in the outbox as part of the current ACID transaction and so it gets scheduled for async background processing as soon as the current transaction completes.

This way we you can atomically perform your business operation including scheduling commands/events which must be executed afterwards, so that we get into an consistent state.

Registration:

Container.RegisterOutOfBandDecorators();
Container.RegisterDecorator(typeof(IRequestHandler<,>), typeof(TransactionalRequestHandlerDecorator<,>));

If you want to process notifications out of band it is important to call Container.RegisterOutOfBandDecorators() before you register any other decorator. Otherwise this would cause the NotificationDispatcher to try to resolve a decorator instead of the actual NotificationHandler.

Usage:

[OutOfBand]
public class SendEmailCommandHandler : IRequestHandler<SendEmailCommand>
{
     ...
}

DisableHangfireDashboardAuthorizationFilter

For local development, where you have other means of authorization, you may want to disable the hangfire authorization for the dashboard.

For disabling the local development authorization for local development, you usually just can use the default options. However, those may not work when running the backend in a docker container, as hangfire still filters the requests to "only local requests". To completly disable any authorization use this filter instead.

Usage:

dashboardOptions = new DashboardOptions { Authorization = new[] { new DisableHangfireDashboardAuthorizationFilter() } };
app.UseHangfireDashboard(options: dashboardOptions);

Transactional job processor

If you want all your background jobs to run within a transaction (which is usually the case), you can use the TransactionalJobProcessor.

Configuration with SimpleInjector:

Container.RegisterSingleton<ITransactionScopeHandler, TransactionScopeHandler>();

// Transaction scope for all request handlers:
Container.RegisterDecorator(typeof(IRequestHandler<,>), typeof(TransactionalCommandHandlerDecorator<,>));

// Transaction scope for all notification handlers:
Container.RegisterDecorator(typeof(INotificationHandler<>), typeof(TransactionalNotificationHandlerDecorator<>));

Using DisplayNameFunc.DisplayNameFunc

OutOfBand jobs are processed via IJobProcessor.ProcessAsync. As a consequence, each jobs name in hangfires dashboard will be listed as "JobProcessor.ProcessAsync".
Fortunately there is an easy way to enable meaningful job display names:

dashboardOptions.DisplayNameFunc = DashboardHelpers.FormatJobDisplayName;

Once enabled, request handlers type name (without assembly information) will be used as the job display name.

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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
9.5.2 70 1/16/2025
9.5.0 177 10/4/2024
9.4.0 252 9/23/2024
9.3.1 185 9/11/2024
9.3.0 119 9/11/2024
9.2.0 132 8/8/2024
9.2.0-rc.3 63 8/7/2024
9.2.0-rc.2 45 8/5/2024
9.2.0-rc.1 57 8/1/2024
9.1.0 77 7/29/2024
9.0.0 536 7/17/2024
9.0.0-preview.2 62 6/13/2024
9.0.0-preview.1 78 4/5/2024
8.1.3 217 3/27/2024
8.1.2 113 3/27/2024
8.1.1 174 3/1/2024
8.1.0 285 1/26/2024
8.0.1 686 12/18/2023
8.0.1-rc.2 82 12/7/2023
8.0.1-rc.1 76 12/6/2023
8.0.0 1,167 11/21/2023
8.0.0-preview1 114 10/4/2023
7.4.0 122 1/25/2024
7.3.0 205 10/11/2023
7.2.1-rc.1 101 8/28/2023
7.2.0 526 6/28/2023
7.2.0-alpha.1 102 6/27/2023
7.1.2 445 5/25/2023
7.1.1 900 4/3/2023
7.1.1-rc.2 97 3/30/2023
7.1.1-rc.1 89 3/30/2023
7.1.0 812 2/28/2023
7.1.0-rc.1 103 2/20/2023
7.0.4-rc.5 104 2/23/2023
7.0.4-rc.4 99 2/23/2023
7.0.4-rc.3 100 2/23/2023
7.0.4-rc.2 103 2/22/2023
7.0.4-rc.1 107 2/16/2023
7.0.3 418 2/16/2023
7.0.2 301 2/9/2023
7.0.2-rc.1 117 2/2/2023
7.0.1 744 1/26/2023
7.0.0 356 1/24/2023
7.0.0-preview1 162 7/18/2022
7.0.0-beta.9 117 1/24/2023
7.0.0-beta.8 107 1/23/2023
7.0.0-beta.7 106 1/23/2023
7.0.0-beta.6 106 1/23/2023
7.0.0-beta.5 113 1/23/2023
7.0.0-beta.4 114 1/19/2023
7.0.0-beta.3 106 1/17/2023
7.0.0-beta.2 113 1/11/2023
7.0.0-beta.1 97 11/24/2022
6.2.2 15,042 9/20/2022
6.2.2-rc.1 132 9/19/2022
6.2.1 3,895 5/4/2022
6.2.0 550 4/21/2022
6.2.0-rc.2 141 4/21/2022
6.2.0-rc.1 142 4/20/2022
6.1.1 947 3/1/2022
6.1.0 617 2/10/2022
6.1.0-rc.3 131 2/10/2022
6.1.0-rc.2 133 2/10/2022
6.1.0-rc.1 137 2/9/2022
6.0.3 1,503 1/18/2022
6.0.2 2,635 1/10/2022
6.0.1 303 12/16/2021
6.0.0 634 12/13/2021
6.0.0-rc.6 159 12/6/2021
6.0.0-rc.5 347 12/6/2021
6.0.0-rc.4 498 12/6/2021
6.0.0-rc.3 392 12/6/2021
6.0.0-rc.2 365 12/6/2021
6.0.0-rc.1 642 11/15/2021
5.4.0 889 10/13/2021
5.3.0 520 9/23/2021
5.3.0-rc.1 350 9/17/2021
5.2.0 3,277 5/20/2021
5.2.0-rcjh.6 204 5/19/2021
5.2.0-rcjh.5 158 5/19/2021
5.2.0-rcjh.4 181 5/19/2021
5.2.0-rcjh.3 161 5/19/2021
5.2.0-rcjh.2 145 4/12/2021
5.2.0-rcjh.1 150 4/12/2021
5.1.3 371 5/19/2021
5.1.2 14,444 3/26/2021
5.1.1 1,055 1/13/2021
5.1.0 2,066 12/16/2020
5.0.0 2,495 11/17/2020
5.0.0-rc.1 292 10/15/2020
4.2.1 18,979 10/8/2020
4.2.0 7,405 8/25/2020
4.1.0 673 8/19/2020
4.0.2 509 8/19/2020
4.0.1 3,784 7/3/2020
4.0.0 524 6/17/2020
3.1.0 517 6/15/2020
3.0.0 10,013 2/4/2020
2.0.0 3,890 9/25/2019
1.0.2 5,089 6/24/2019