2013-05-07 03:39:33 +03:00
|
|
|
using System;
|
2013-05-22 08:39:46 +03:00
|
|
|
using System.Threading;
|
|
|
|
using System.Threading.Tasks;
|
2013-05-11 02:53:50 +03:00
|
|
|
using NLog;
|
2013-03-05 08:51:07 +03:00
|
|
|
using NzbDrone.Core.Lifecycle;
|
2013-09-14 09:42:09 +03:00
|
|
|
using NzbDrone.Core.Messaging.Commands;
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
2013-05-22 08:39:46 +03:00
|
|
|
using Timer = System.Timers.Timer;
|
2013-07-12 09:10:34 +03:00
|
|
|
using NzbDrone.Common.TPL;
|
2013-03-05 08:51:07 +03:00
|
|
|
|
|
|
|
namespace NzbDrone.Core.Jobs
|
|
|
|
{
|
2013-05-09 09:38:20 +03:00
|
|
|
public class Scheduler :
|
2013-04-19 07:46:18 +03:00
|
|
|
IHandle<ApplicationStartedEvent>,
|
|
|
|
IHandle<ApplicationShutdownRequested>
|
2013-03-05 08:51:07 +03:00
|
|
|
{
|
2013-05-09 09:38:20 +03:00
|
|
|
private readonly ITaskManager _taskManager;
|
2013-09-14 09:36:07 +03:00
|
|
|
private readonly ICommandExecutor _commandExecutor;
|
2013-05-11 02:53:50 +03:00
|
|
|
private readonly Logger _logger;
|
2013-05-09 09:38:20 +03:00
|
|
|
private static readonly Timer Timer = new Timer();
|
2013-05-22 08:39:46 +03:00
|
|
|
private static CancellationTokenSource _cancellationTokenSource;
|
2013-03-05 08:51:07 +03:00
|
|
|
|
2013-09-14 09:36:07 +03:00
|
|
|
public Scheduler(ITaskManager taskManager, ICommandExecutor commandExecutor, Logger logger)
|
2013-03-05 08:51:07 +03:00
|
|
|
{
|
2013-05-09 09:38:20 +03:00
|
|
|
_taskManager = taskManager;
|
2013-09-14 09:36:07 +03:00
|
|
|
_commandExecutor = commandExecutor;
|
2013-05-11 02:53:50 +03:00
|
|
|
_logger = logger;
|
2013-03-05 08:51:07 +03:00
|
|
|
}
|
|
|
|
|
2013-05-07 03:39:33 +03:00
|
|
|
private void ExecuteCommands()
|
|
|
|
{
|
2013-05-12 02:38:41 +03:00
|
|
|
try
|
|
|
|
{
|
|
|
|
Timer.Enabled = false;
|
2013-05-07 03:39:33 +03:00
|
|
|
|
2013-05-12 02:38:41 +03:00
|
|
|
var tasks = _taskManager.GetPending();
|
2013-05-11 08:59:42 +03:00
|
|
|
|
2013-05-12 02:38:41 +03:00
|
|
|
_logger.Trace("Pending Tasks: {0}", tasks.Count);
|
2013-05-11 02:53:50 +03:00
|
|
|
|
2013-05-12 02:38:41 +03:00
|
|
|
foreach (var task in tasks)
|
2013-05-11 02:53:50 +03:00
|
|
|
{
|
2013-05-22 08:39:46 +03:00
|
|
|
_cancellationTokenSource.Token.ThrowIfCancellationRequested();
|
|
|
|
|
2013-05-12 02:38:41 +03:00
|
|
|
try
|
|
|
|
{
|
2013-09-14 09:36:07 +03:00
|
|
|
_commandExecutor.PublishCommand(task.TypeName);
|
2013-05-12 02:38:41 +03:00
|
|
|
}
|
|
|
|
catch (Exception e)
|
|
|
|
{
|
2014-02-27 09:06:24 +03:00
|
|
|
_logger.ErrorException("Error occurred while executing task " + task.TypeName, e);
|
2013-05-12 02:38:41 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
finally
|
|
|
|
{
|
2013-05-22 08:39:46 +03:00
|
|
|
if (!_cancellationTokenSource.IsCancellationRequested)
|
|
|
|
{
|
|
|
|
Timer.Enabled = true;
|
|
|
|
}
|
2013-05-07 03:39:33 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-02-04 10:11:36 +03:00
|
|
|
public void Handle(ApplicationStartedEvent message)
|
|
|
|
{
|
|
|
|
_cancellationTokenSource = new CancellationTokenSource();
|
|
|
|
Timer.Interval = 1000 * 30;
|
|
|
|
Timer.Elapsed += (o, args) => Task.Factory.StartNew(ExecuteCommands, _cancellationTokenSource.Token)
|
|
|
|
.LogExceptions();
|
|
|
|
|
|
|
|
Timer.Start();
|
|
|
|
}
|
|
|
|
|
2013-04-19 07:46:18 +03:00
|
|
|
public void Handle(ApplicationShutdownRequested message)
|
|
|
|
{
|
2014-02-04 10:11:36 +03:00
|
|
|
_logger.Info("Shutting down scheduler");
|
2013-05-22 08:39:46 +03:00
|
|
|
_cancellationTokenSource.Cancel(true);
|
2013-05-09 09:38:20 +03:00
|
|
|
Timer.Stop();
|
2013-04-19 07:46:18 +03:00
|
|
|
}
|
2013-03-05 08:51:07 +03:00
|
|
|
}
|
|
|
|
}
|