Fusonic.Extensions.Hangfire
9.0.0-preview.2
Prefix Reserved
See the version list below for details.
dotnet add package Fusonic.Extensions.Hangfire --version 9.0.0-preview.2
NuGet\Install-Package Fusonic.Extensions.Hangfire -Version 9.0.0-preview.2
<PackageReference Include="Fusonic.Extensions.Hangfire" Version="9.0.0-preview.2" />
paket add Fusonic.Extensions.Hangfire --version 9.0.0-preview.2
#r "nuget: Fusonic.Extensions.Hangfire, 9.0.0-preview.2"
// Install Fusonic.Extensions.Hangfire as a Cake Addin #addin nuget:?package=Fusonic.Extensions.Hangfire&version=9.0.0-preview.2&prerelease // Install Fusonic.Extensions.Hangfire as a Cake Tool #tool nuget:?package=Fusonic.Extensions.Hangfire&version=9.0.0-preview.2&prerelease
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 | 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. 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. |
-
net8.0
- Fusonic.Extensions.Common (>= 9.0.0-preview.2)
- Fusonic.Extensions.Mediator (>= 9.0.0-preview.2)
- Hangfire.Core (>= 1.8.6)
- SimpleInjector (>= 5.4.2)
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 |