Indrivo.BackgroundProcessor.Utility.Contracts 1.0.4-alpha

This is a prerelease version of Indrivo.BackgroundProcessor.Utility.Contracts.
dotnet add package Indrivo.BackgroundProcessor.Utility.Contracts --version 1.0.4-alpha
                    
NuGet\Install-Package Indrivo.BackgroundProcessor.Utility.Contracts -Version 1.0.4-alpha
                    
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="Indrivo.BackgroundProcessor.Utility.Contracts" Version="1.0.4-alpha" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Indrivo.BackgroundProcessor.Utility.Contracts" Version="1.0.4-alpha" />
                    
Directory.Packages.props
<PackageReference Include="Indrivo.BackgroundProcessor.Utility.Contracts" />
                    
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 Indrivo.BackgroundProcessor.Utility.Contracts --version 1.0.4-alpha
                    
#r "nuget: Indrivo.BackgroundProcessor.Utility.Contracts, 1.0.4-alpha"
                    
#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 Indrivo.BackgroundProcessor.Utility.Contracts@1.0.4-alpha
                    
#: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=Indrivo.BackgroundProcessor.Utility.Contracts&version=1.0.4-alpha&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=Indrivo.BackgroundProcessor.Utility.Contracts&version=1.0.4-alpha&prerelease
                    
Install as a Cake Tool

Background Processing

Introduction

During the development of multiple solutions @Indrivo we have ussually encoutered the need of having a background or ASYNCHRONOUS process that runs on different triggers like : cron expression, http trigger, message that came via a message bus etc. .NET Core comes with a basic functionality that covers the need of a background worker to some extent, however that is most often not enough and is pretty uncomfortable to develop and monitor.

Purpose

The main purpose of the module came from the need of a having MediatR run specific commands (long running requests) in the background asynchronously, known under the term Fire-and-Forget processes. As well the administrators would need to have a monitoring dashboard built on top of the functionality. Seamless integration and extension of MediatR functionality is desired. In time the module developed a way to run CRON jobs in a simillar fashion. So the main functionality right now consists of:

  1. MediatR extension method for ASYNC processing -- .Enqueue();
  2. Easy to use CRON job setup that can be integrated in projects that run with/without MediatR.
  3. Monitoring dashboard for easier debugging and resolving of issues.

How to set up

Set up is pretty straightforward you will need to install the following packages inside your solution:

  1. Indrivo.BackgroundProcessor.Utility.Contracts
  2. Indrivo.BackgroundProcessor.Utility.Service.Hangfire
  3. Indrivo.BackgroundProcessor.Utility.Service.Hangfire.PostgreSQL.Plugin
  4. Indrivo.BackgroundProcessor.Utility.Service.Hangfire.SQLServer.Plugin

Each plugin comes with his own small installer. So you are free to use them explicitly. However the desired way is to add the following structure to your appsetting file. Example:

  "HangfireConfigurationOptions": {
    "DatabaseProvider": "SQLServer",
    "DatabaseConnectionString": "Server=(localdb)\\mssqllocaldb;Database=aspnet-hangfireTest;Trusted_Connection=True;MultipleActiveResultSets=true"
  }

Where the DatabaseProvider can be either of the : "SQLServer" | "PostregSQL".

Example of this setup can be seen in the reference web application present in the current repo.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  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. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.1

NuGet packages (2)

Showing the top 2 NuGet packages that depend on Indrivo.BackgroundProcessor.Utility.Contracts:

Package Downloads
Indrivo.BackgroundProcessor.Utility.Service.Hangfire

Package Description

Indrivo.Notifications.Engine

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.0.4-alpha 193 8/21/2025
1.0.3 3,428 4/18/2023
1.0.2 1,137 12/6/2022
1.0.1 958 12/6/2022
1.0.0 1,015 6/7/2022

Added backward compatibility for .NET5