-
Notifications
You must be signed in to change notification settings - Fork 314
CrystalQuartz OWIN Configuration
This article describes how you can use OWIN version of CrystalQuartz to plug Quartz.NET Scheduler viewer into your application.
As a first step, you need to install CrystalQuartz.Owin NuGet package to the target project:
Install-Package CrystalQuartz.Owin
That will add a CrystalQuartz.Owin.dll
reference to your project. The CrystalQuartz.Owin.dll
is a single dll that contains all the resources needed for CrystalQuartz to work.
As a next step, you need to hook CrystalQuartz middleware into your OWIN environment. It should be done by calling UseCrystalQuartz
extension method at the moment of pipeline initialization, usualy it is in Startup.cs
file. The generic syntax for panel configuration looks like this:
/*
* app is your IAppBuilder instance
*/
app.UseCrystalQuartz(schedulerOrProvider, options);
The arguments are:
-
schedulerOrProvider
is a directIScheduler
reference or a provider poining to it; -
options
is an optional for panel customization.
This section describes different ways of passing schedulerOrProvider
argument to the UseCrystalQuartz
method. You need to pick one of these options.
If you already have the IScheduler
object instance then you can pass it directly to the configuration extension method:
public void Configuration(IAppBuilder app)
{
IScheduler scheduler = StdSchedulerFactory.GetDefaultScheduler();
// define the job and tie it to our HelloJob class
IJobDetail job = JobBuilder.Create<HelloJob>()
.WithIdentity("job1", "group1")
.Build();
// Trigger the job to run now, and then repeat every 10 seconds
ITrigger trigger = TriggerBuilder.Create()
.WithIdentity("trigger1", "group1")
.StartNow()
.WithSimpleSchedule(x => x
.WithIntervalInSeconds(10)
.RepeatForever())
.Build();
// Tell quartz to schedule the job using our trigger
scheduler.ScheduleJob(job, trigger);
scheduler.Start();
/*
* Init CrystalQuartz Panel with scheduler instance.
*/
app.UseCrystalQuartz(scheduler);
}
Using this technic you can manually configure panel to work with a remote scheduler:
public void Configuration(IAppBuilder app)
{
string url = "tcp://localhost:555/QuartzScheduler"; // YOUR URL HERE
NameValueCollection properties = new NameValueCollection();
properties["quartz.scheduler.proxy"] = "true";
properties["quartz.scheduler.proxy.address"] = url;
ISchedulerFactory schedulerFactory = new StdSchedulerFactory(properties);
IScheduler scheduler = schedulerFactory.GetScheduler();
/*
* Init CrystalQuartz Panel with Remote scheduler instance.
*/
app.UseCrystalQuartz(scheduler);
}
Depending on your application lifecycle, you might have no IScheduler
instance ready at the moment of OWIN environment setup. For this case you can use a Func<IScheduler>
instance as a first argument of UseCrystalQuartz
call:
public void Configuration(IAppBuilder app)
{
app.UseCrystalQuartz(() => GetSchedulerInstance());
}
For example, you can get it from an IoC container:
public void Configuration(IAppBuilder app)
{
/* ... */
app.UseCrystalQuartz(() => container.Resolve<IScheduler>());
}
Non-OWIN version of CrystalQuartz Panel uses internal ISchedulerProvider
abstraction for getting access to the scheduler
instance. You can pass an instance of ISchedulerProvider
as a first argument of UseCrystalQuartz
call. That might be helpful in some cases, for example:
-
you are migrating from CrystalQuartz.Simple to CrystalQuartz.Owin and you already have your custom implementation of
ISchedulerProvider
:public class MySchedulerProvider : StdSchedulerProvider { protected override void InitScheduler(IScheduler scheduler) { var jobDetail = JobBuilder.Create<HelloJob>() .WithIdentity("myJob") .StoreDurably() .Build(); var trigger = TriggerBuilder.Create() .WithIdentity("myTrigger") .StartNow() .WithSimpleSchedule(x => x.WithIntervalInMinutes(1).RepeatForever()) .Build(); scheduler.ScheduleJob(jobDetail, trigger); } }
In this case you can pass the same provider instance to the
UseCrystalQuartz
call:public void Configuration(IAppBuilder app) { /* ... */ app.UseCrystalQuartz(new MySchedulerProvider()); }
-
you are going to connect to a remote scheduler. In this case the
RemoteSchedulerProvider
implementation ofISchedulerProvider
would be more concise than the explicit configuration:public class Startup { public void Configuration(IAppBuilder app) { app.UseCrystalQuartz(new RemoteSchedulerProvider { SchedulerHost = "tcp://localhost:555/QuartzScheduler" }); } }
Second (optional) argument of UseCrystalQuartz
method allows to do some minor panel customizations. The object should be an instance of CrystalQuartzOptions
class:
public class CrystalQuartzOptions
{
public string Path { get; set; }
public string CustomCssUrl { get; set; }
}
Usage could be like this:
public void Configuration(IAppBuilder app)
{
app.UseCrystalQuartz(
new RemoteSchedulerProvider
{
SchedulerHost = "tcp://localhost:555/QuartzScheduler"
},
new CrystalQuartzOptions
{
CustomCssUrl = "...",
Path = "..."
});
}