Autofac.Extras.Quartz 10.0.0

dotnet add package Autofac.Extras.Quartz --version 10.0.0
                    
NuGet\Install-Package Autofac.Extras.Quartz -Version 10.0.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="Autofac.Extras.Quartz" Version="10.0.0" />
                    
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" />
                    
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
                    
#r "nuget: Autofac.Extras.Quartz, 10.0.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.
#addin nuget:?package=Autofac.Extras.Quartz&version=10.0.0
                    
Install Autofac.Extras.Quartz as a Cake Addin
#tool nuget:?package=Autofac.Extras.Quartz&version=10.0.0
                    
Install Autofac.Extras.Quartz 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. 
.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 (14)

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

Package Downloads
Lauener.Core.Triggers

A easy to use Quartz implementation

TripleSix.Core

Package Description

HwApp.Quartz

HwApp Quartz & Quartzmin

SyWaterStandardLibrary

舜禹框架Core 3.0

Cogito.Quartz.Autofac

Provides utilites and extensions for Quartz and Autofac.

GitHub repositories (1)

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

Repository Stars
PlexRipper/PlexRipper
A cross-platform Plex media downloader that seamlessly adds media from other Plex servers to your own!
Version Downloads Last updated
10.0.0 212,249 3/7/2024
10.0.0-alpha0007 124 3/5/2024
10.0.0-alpha0006 140 3/4/2024
9.0.0 218,714 3/27/2023
8.2.0 69,551 1/30/2023
8.2.0-alpha0001 205 1/30/2023
8.1.0 2,444 1/24/2023
8.1.0-alpha0003 230 12/22/2022
8.1.0-alpha0002 208 12/22/2022
8.0.0 148,016 6/3/2022
7.4.0-alpha0007 273 6/2/2022
7.4.0-alpha0005 10,781 5/17/2022
7.4.0-alpha0002 219 5/8/2022
7.3.0 192,396 10/28/2021
7.3.0-alpha0009 309 10/28/2021
7.2.0 50,318 8/2/2021
7.2.0-alpha0006 325 8/1/2021
7.1.0 67,635 4/25/2021
7.1.0-alpha0011 336 8/1/2021
7.1.0-alpha0010 370 8/1/2021
7.1.0-alpha0009 387 8/1/2021
7.1.0-alpha0008 336 6/20/2021
7.1.0-alpha0006 329 4/30/2021
7.1.0-alpha0004 336 4/24/2021
7.1.0-alpha0003 375 4/24/2021
7.1.0-alpha0002 325 4/19/2021
7.1.0-alpha0001 315 4/19/2021
7.0.0 214,878 2/16/2021
7.0.0-beta0001 331 2/14/2021
7.0.0-alpha0024 350 2/14/2021
7.0.0-alpha0023 354 2/9/2021
6.3.0-alpha0001 345 2/9/2021
6.2.0 14,988 1/29/2021
6.2.0-beta0001 337 1/29/2021
6.2.0-alpha0008 350 1/28/2021
6.2.0-alpha0001 469 1/10/2021
6.1.0 17,830 1/10/2021
6.1.0-beta0001 384 1/4/2021
6.0.1 47,029 10/21/2020
6.0.1-beta0001 489 10/21/2020
6.0.0 72,830 10/9/2020
6.0.0-beta0001 451 10/9/2020
6.0.0-alpha0041 463 10/7/2020
6.0.0-alpha0039 493 10/7/2020
5.4.0 41,376 10/7/2020
5.4.0-beta0001 458 10/4/2020
5.4.0-alpha0007 450 10/4/2020
5.4.0-alpha0001 679 8/6/2020
5.3.0 40,711 8/6/2020
5.3.0-beta0001 477 8/6/2020
5.3.0-alpha0009 486 8/6/2020
5.3.0-alpha0008 543 7/27/2020
5.3.0-alpha0007 555 7/8/2020
5.3.0-alpha0001 1,092 5/19/2020
5.2.0 112,388 5/19/2020
5.2.0-beta0001 517 5/19/2020
5.2.0-alpha0023 512 5/19/2020
5.2.0-alpha0021 791 2/17/2020
5.1.0 163,950 2/17/2020
5.1.0-alpha0015 511 2/17/2020
5.1.0-alpha0014 584 2/8/2020
5.1.0-alpha0005 591 1/30/2020
5.0.0 27,841 1/30/2020
5.0.0-beta0001 599 1/30/2020
5.0.0-alpha0064 524 1/30/2020
4.7.0-alpha0013 3,240 1/29/2020
4.7.0-alpha0009 546 1/27/2020
4.7.0-alpha0007 1,987 11/18/2019
4.7.0-alpha0006 544 11/17/2019
4.7.0-alpha0005 580 11/8/2019
4.7.0-alpha0004 1,199 9/2/2019
4.6.0 227,555 9/2/2019
4.6.0-beta0001 601 9/1/2019
4.6.0-alpha0036 588 9/1/2019
4.6.0-alpha0034 577 9/1/2019
4.6.0-alpha0033 567 9/1/2019
4.6.0-alpha0028 645 7/13/2019
4.6.0-alpha0026 600 7/13/2019
4.6.0-alpha0024 581 7/6/2019
4.6.0-alpha0022 584 7/6/2019
4.6.0-alpha0018 586 7/6/2019
4.6.0-alpha0008 733 5/8/2019
4.6.0-alpha0005 602 5/8/2019
4.6.0-alpha0003 634 5/8/2019
4.6.0-alpha0001 762 3/10/2019
4.5.1 177,359 5/8/2019
4.5.1-beta0001 634 5/8/2019
4.5.0 110,199 3/9/2019
4.5.0-beta0001 637 3/9/2019
4.5.0-alpha0008 608 3/9/2019
4.5.0-alpha0007 637 3/8/2019
4.5.0-alpha0005 664 2/25/2019
4.5.0-alpha0003 889 2/11/2019
4.5.0-alpha0002 712 1/28/2019
4.5.0-alpha0001 729 1/27/2019
4.4.0 109,145 1/27/2019
4.4.0-beta0001 755 1/27/2019
4.4.0-alpha0014 1,112 9/29/2018
4.4.0-alpha0013 826 9/29/2018
4.4.0-alpha0012 809 9/29/2018
4.4.0-alpha0002 888 9/23/2018
4.4.0-alpha0001 822 9/19/2018
4.3.0 157,465 9/29/2018
4.3.0-beta0001 859 9/26/2018
4.3.0-alpha0008 1,547 7/11/2018
4.3.0-alpha0007 1,112 7/7/2018
4.3.0-alpha0006 1,108 7/7/2018
4.3.0-alpha0005 1,118 7/1/2018
4.2.0 43,897 7/1/2018
4.2.0-beta0001 1,097 6/30/2018
4.2.0-alpha0004 1,095 7/1/2018
4.2.0-alpha0003 1,521 5/13/2018
4.2.0-alpha0002 1,152 5/13/2018
4.2.0-alpha0001 1,156 5/13/2018
4.1.2 1,399 6/30/2018
4.1.1 63,067 5/13/2018
4.1.0-beta0004 1,155 5/13/2018
4.1.0-beta0001 1,166 5/13/2018
4.1.0-alpha0016 1,487 4/14/2018
4.0.0 68,754 1/14/2018
4.0.0-beta0007 1,267 1/14/2018
4.0.0-beta0006 1,190 1/13/2018
4.0.0-beta0001 1,130 1/13/2018
3.5.0 105,935 4/14/2018
3.5.0-unstable0012 1,279 1/5/2018
3.5.0-unstable0010 1,514 8/15/2017
3.5.0-unstable0004 1,061 8/1/2017
3.5.0-unstable0003 1,073 7/25/2017
3.5.0-unstable0002 1,110 6/21/2017
3.5.0-unstable0001 1,165 6/15/2017
3.5.0-beta0001 1,329 4/14/2018
3.4.0 127,071 5/5/2017
3.4.0-unstable0009 1,114 4/5/2017
3.4.0-unstable0008 1,080 4/5/2017
3.4.0-unstable0007 1,107 4/5/2017
3.4.0-unstable0006 1,057 4/5/2017
3.4.0-unstable0004 1,189 2/15/2017
3.4.0-unstable0001 1,179 12/4/2016
3.4.0-ci0000 1,062 4/5/2017
3.3.0 74,961 11/1/2016
3.3.0-unstable0001 1,187 11/1/2016
3.3.0-unstable0000 1,079 10/10/2016
3.2.0 8,427 10/10/2016
3.2.0-beta0001 1,076 10/10/2016
3.1.0 57,199 8/25/2016
3.1.0-unstable0022 1,075 10/9/2016
3.1.0-unstable0021 1,108 10/9/2016
3.0.0-unstable0020 1,196 7/17/2016
3.0.0-unstable0017 1,157 8/24/2016
3.0.0-unstable0013 1,125 7/17/2016
3.0.0-unstable0012 1,134 7/17/2016
3.0.0-unstable0011 1,124 7/17/2016
3.0.0-beta-1 1,204 7/4/2016
3.0.0-alpha0014 1,081 7/20/2016
2.2.0-unstable0012 1,172 7/19/2016
2.1.1 19,313 7/16/2016
2.1.0 38,623 4/8/2016
2.0.0.1 1,763 4/6/2016
1.7.0 43,426 10/29/2015
1.6.0 3,392 10/25/2015
1.5.1 20,003 7/14/2015
1.5.0 1,480 7/14/2015
1.4.0 5,058 6/12/2015
1.3.0 16,988 2/1/2015
1.2.0 3,718 1/26/2015
1.1.1 6,516 11/15/2014
1.1.0 10,307 7/13/2014
1.0.0 2,888 7/2/2014
0.11.0 2,037 5/18/2014
0.10.0 1,928 4/9/2014
0.9.0 5,817 4/7/2014