Autofac.Extras.Quartz 10.0.0-alpha0007

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

Autofac.Extras.Quartz

Autofac integration package for Quartz.Net.

Autofac.Extras.Quartz creates nested litefime scope for each Quartz Job. Nested scope is disposed after job execution has been completed.

This allows to have single instance per job execution as well as deterministic disposal of resources.

Install package via Nuget: install-package Autofac.Extras.Quartz

Build status

Stable Pre-release
Build Master branch Development branch
NuGet NuGet NuGet
CodeCov codecov codecov

Usage example

Autofac configuration for Quartz includes two steps:

  1. Scheduler registration
  2. Job registration

Scheduler registration

QuartzAutofacFactoryModule registers custom ISchedulerFactory and default instance of IScheduler in Autofac container. Both factory and schedulere are registered as singletones. Note: Is is important to resolve IScheduler from container, rather than using default one to get jobs resolved by Autofac.

Optionally custom Quartz configuration can be passed using ConfigurationProvider property. Provider is callback which returns settings using NameValueCollection.

Job scope configuration

Starting with version 7 QuartzAutofacFactoryModule provides a way to customize lifetime scope configuration for job. This can be done via JobScopeConfigurator parameter.

cb.Register(_ => new ScopedDependency("global"))
    .AsImplementedInterfaces()
    .SingleInstance();

cb.RegisterModule(new QuartzAutofacFactoryModule {
    JobScopeConfigurator = (builder, jobScopeTag) => {
        // override dependency for job scope
        builder.Register(_ => new ScopedDependency("job-local "+ DateTime.UtcNow.ToLongTimeString()))
            .AsImplementedInterfaces()
            .InstancePerMatchingLifetimeScope(jobScopeTag);

    }
});

See src/Samples/Shared/Bootstrap.cs for details.

Job registration

QuartzAutofacJobsModule scans given assemblies and registers all non-abstract implementors of IJob interface as transient instances.

internal static ContainerBuilder ConfigureContainer(ContainerBuilder cb)
{
	// 1) Register IScheduler
	cb.RegisterModule(new QuartzAutofacFactoryModule()); 
	// 2) Register jobs
	cb.RegisterModule(new QuartzAutofacJobsModule(typeof (CleanupExpiredAnnouncemetsJob).Assembly));
}

Starting Quartz

Make sure to start the scheduler after it was resolved from Autofac. E.g.

var scheduler = _container.Resolve<IScheduler>();
scheduler.Start();

Sample projects

TopShelf-based sample was removed since Topshelf.Quartz is not compatible with Quartz 3 as af now.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  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 is compatible.  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 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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  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.

NuGet packages (13)

Showing the top 5 NuGet packages that depend on Autofac.Extras.Quartz:

Package Downloads
Lauener.Core.Triggers

A easy to use Quartz implementation

HwApp.Quartz

HwApp Quartz & Quartzmin

SyWaterStandardLibrary

舜禹框架Core 3.0

Cogito.Quartz.Autofac

Provides utilites and extensions for Quartz and Autofac.

Inaction.Web

.net core Web快速开发框架

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Autofac.Extras.Quartz:

Repository Stars
Reaparr/Reaparr
Plex downloader that brings content from any server to yours!
Version Downloads Last Updated
10.0.0 440,090 3/7/2024
10.0.0-alpha0007 214 3/5/2024
10.0.0-alpha0006 220 3/4/2024
9.0.0 242,908 3/27/2023
8.2.0 76,069 1/30/2023
8.2.0-alpha0001 321 1/30/2023
8.1.0 2,755 1/24/2023
8.1.0-alpha0003 348 12/22/2022
8.1.0-alpha0002 323 12/22/2022
8.0.0 157,259 6/3/2022
7.4.0-alpha0007 414 6/2/2022
7.4.0-alpha0005 11,138 5/17/2022
7.4.0-alpha0002 357 5/8/2022
7.3.0 199,605 10/28/2021
7.3.0-alpha0009 454 10/28/2021
7.2.0 52,038 8/2/2021
7.2.0-alpha0006 458 8/1/2021
7.1.0 70,049 4/25/2021
7.1.0-alpha0011 467 8/1/2021
7.1.0-alpha0010 492 8/1/2021
7.1.0-alpha0009 518 8/1/2021
7.1.0-alpha0008 478 6/20/2021
7.1.0-alpha0006 467 4/30/2021
7.1.0-alpha0004 470 4/24/2021
7.1.0-alpha0003 515 4/24/2021
7.1.0-alpha0002 467 4/19/2021
7.1.0-alpha0001 413 4/19/2021
7.0.0 230,111 2/16/2021
7.0.0-beta0001 478 2/14/2021
7.0.0-alpha0024 495 2/14/2021
7.0.0-alpha0023 498 2/9/2021
6.3.0-alpha0001 469 2/9/2021
6.2.0 16,052 1/29/2021
6.2.0-beta0001 479 1/29/2021
6.2.0-alpha0008 500 1/28/2021
6.2.0-alpha0001 610 1/10/2021
6.1.0 18,274 1/10/2021
6.1.0-beta0001 532 1/4/2021
6.0.1 49,736 10/21/2020
6.0.1-beta0001 641 10/21/2020
6.0.0 78,517 10/9/2020
6.0.0-beta0001 595 10/9/2020
6.0.0-alpha0041 612 10/7/2020
6.0.0-alpha0039 646 10/7/2020
5.4.0 47,857 10/7/2020
5.4.0-beta0001 603 10/4/2020
5.4.0-alpha0007 602 10/4/2020
5.4.0-alpha0001 829 8/6/2020
5.3.0 43,536 8/6/2020
5.3.0-beta0001 635 8/6/2020
5.3.0-alpha0009 639 8/6/2020
5.3.0-alpha0008 685 7/27/2020
5.3.0-alpha0007 675 7/8/2020
5.3.0-alpha0001 1,249 5/19/2020
5.2.0 118,388 5/19/2020
5.2.0-beta0001 678 5/19/2020
5.2.0-alpha0023 669 5/19/2020
5.2.0-alpha0021 941 2/17/2020
5.1.0 171,366 2/17/2020
5.1.0-alpha0015 680 2/17/2020
5.1.0-alpha0014 697 2/8/2020
5.1.0-alpha0005 739 1/30/2020
5.0.0 29,734 1/30/2020
5.0.0-beta0001 752 1/30/2020
5.0.0-alpha0064 659 1/30/2020
4.7.0-alpha0013 3,419 1/29/2020
4.7.0-alpha0009 711 1/27/2020
4.7.0-alpha0007 2,316 11/18/2019
4.7.0-alpha0006 705 11/17/2019
4.7.0-alpha0005 735 11/8/2019
4.7.0-alpha0004 1,360 9/2/2019
4.6.0 252,709 9/2/2019
4.6.0-beta0001 754 9/1/2019
4.6.0-alpha0036 743 9/1/2019
4.6.0-alpha0034 736 9/1/2019
4.6.0-alpha0033 717 9/1/2019
4.6.0-alpha0028 777 7/13/2019
4.6.0-alpha0026 759 7/13/2019
4.6.0-alpha0024 727 7/6/2019
4.6.0-alpha0022 715 7/6/2019
4.6.0-alpha0018 743 7/6/2019
4.6.0-alpha0008 894 5/8/2019
4.6.0-alpha0005 745 5/8/2019
4.6.0-alpha0003 786 5/8/2019
4.6.0-alpha0001 924 3/10/2019
4.5.1 181,446 5/8/2019
4.5.1-beta0001 779 5/8/2019
4.5.0 111,314 3/9/2019
4.5.0-beta0001 780 3/9/2019
4.5.0-alpha0008 758 3/9/2019
4.5.0-alpha0007 803 3/8/2019
4.5.0-alpha0005 808 2/25/2019
4.5.0-alpha0003 1,063 2/11/2019
4.5.0-alpha0002 847 1/28/2019
4.5.0-alpha0001 902 1/27/2019
4.4.0 114,846 1/27/2019
4.4.0-beta0001 910 1/27/2019
4.4.0-alpha0014 1,299 9/29/2018
4.4.0-alpha0013 996 9/29/2018
4.4.0-alpha0012 983 9/29/2018
4.4.0-alpha0002 1,050 9/23/2018
4.4.0-alpha0001 965 9/19/2018
4.3.0 161,242 9/29/2018
4.3.0-beta0001 1,020 9/26/2018
4.3.0-alpha0008 1,903 7/11/2018
4.3.0-alpha0007 1,467 7/7/2018
4.3.0-alpha0006 1,459 7/7/2018
4.3.0-alpha0005 1,487 7/1/2018
4.2.0 45,906 7/1/2018
4.2.0-beta0001 1,434 6/30/2018
4.2.0-alpha0004 1,433 7/1/2018
4.2.0-alpha0003 1,884 5/13/2018
4.2.0-alpha0002 1,501 5/13/2018
4.2.0-alpha0001 1,523 5/13/2018
4.1.2 1,858 6/30/2018
4.1.1 64,067 5/13/2018
4.1.0-beta0004 1,505 5/13/2018
4.1.0-beta0001 1,525 5/13/2018
4.1.0-alpha0016 1,811 4/14/2018
4.0.0 72,681 1/14/2018
4.0.0-beta0007 1,611 1/14/2018
4.0.0-beta0006 1,525 1/13/2018
4.0.0-beta0001 1,490 1/13/2018
3.5.0 121,104 4/14/2018
3.5.0-unstable0012 1,607 1/5/2018
3.5.0-unstable0010 1,743 8/15/2017
3.5.0-unstable0004 1,307 8/1/2017
3.5.0-unstable0003 1,335 7/25/2017
3.5.0-unstable0002 1,369 6/21/2017
3.5.0-unstable0001 1,406 6/15/2017
3.5.0-beta0001 1,666 4/14/2018
3.4.0 132,632 5/5/2017
3.4.0-unstable0009 1,373 4/5/2017
3.4.0-unstable0008 1,350 4/5/2017
3.4.0-unstable0007 1,369 4/5/2017
3.4.0-unstable0006 1,316 4/5/2017
3.4.0-unstable0004 1,454 2/15/2017
3.4.0-unstable0001 1,432 12/4/2016
3.4.0-ci0000 1,320 4/5/2017
3.3.0 77,353 11/1/2016
3.3.0-unstable0001 1,439 11/1/2016
3.3.0-unstable0000 1,325 10/10/2016
3.2.0 8,954 10/10/2016
3.2.0-beta0001 1,340 10/10/2016
3.1.0 58,260 8/25/2016
3.1.0-unstable0022 1,329 10/9/2016
3.1.0-unstable0021 1,376 10/9/2016
3.0.0-unstable0020 1,449 7/17/2016
3.0.0-unstable0017 1,399 8/24/2016
3.0.0-unstable0013 1,384 7/17/2016
3.0.0-unstable0012 1,389 7/17/2016
3.0.0-unstable0011 1,375 7/17/2016
3.0.0-beta-1 1,463 7/4/2016
3.0.0-alpha0014 1,319 7/20/2016
2.2.0-unstable0012 1,427 7/19/2016
2.1.1 19,801 7/16/2016
2.1.0 39,529 4/8/2016
2.0.0.1 2,078 4/6/2016
1.7.0 45,524 10/29/2015
1.6.0 3,725 10/25/2015
1.5.1 21,501 7/14/2015
1.5.0 1,762 7/14/2015
1.4.0 5,352 6/12/2015
1.3.0 17,618 2/1/2015
1.2.0 4,328 1/26/2015
1.1.1 6,848 11/15/2014
1.1.0 10,917 7/13/2014
1.0.0 3,179 7/2/2014
0.11.0 2,351 5/18/2014
0.10.0 2,238 4/9/2014
0.9.0 6,545 4/7/2014