using Quartz;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace IStation.Server
{
///
/// 单个任务辅助类
///
internal class DataDockingSingleJobHelper
{
private IScheduler _sched;//调度器
///
/// 数据对接配置
///
public Model.DataDockingProblem Problem { get; private set; }
///
/// 开始任务
///
public async Task StartJob(Model.DataDockingProblem problem)
{
Problem = problem;
var jobName = DataDockingJobNameHelper.GetJobName(problem);
var jobGroupName = DataDockingJobNameHelper.GetJobGroupName(problem);
var triggerName = DataDockingJobNameHelper.GetTriggerName(problem);
// 1.创建scheduler的引用
var fac = new Quartz.Impl.StdSchedulerFactory();
_sched = await fac.GetScheduler();
//2.启动 scheduler
await _sched.Start();
//3.创建任务
var job = JobBuilder.Create()
.WithIdentity(jobName, jobGroupName)
.Build();
job.JobDataMap.Put(DataDockingSingleJob.ProblemTagName, problem);
//4.创建Trigger
var trigger = TriggerBuilder.Create()
.WithIdentity(triggerName, jobGroupName)
.WithSimpleSchedule(x => x.WithIntervalInSeconds(problem.Interruption)
.RepeatForever().WithMisfireHandlingInstructionNextWithRemainingCount())
.Build();
//5.加入调度管理器
await _sched.ScheduleJob(job, trigger);
}
///
/// 取消任务
///
public async Task CancelJob()
{
if (_sched == null)
return;
var triggerKey = new TriggerKey(DataDockingJobNameHelper.GetTriggerName(Problem), DataDockingJobNameHelper.GetJobGroupName(Problem));
if (await _sched.CheckExists(triggerKey))
{
await _sched.UnscheduleJob(triggerKey);
}
}
}
}