|  | @@ -36,19 +36,19 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |          /// Gets or sets the json serializer.
 |  |          /// Gets or sets the json serializer.
 | 
											
												
													
														|  |          /// </summary>
 |  |          /// </summary>
 | 
											
												
													
														|  |          /// <value>The json serializer.</value>
 |  |          /// <value>The json serializer.</value>
 | 
											
												
													
														|  | -        private IJsonSerializer JsonSerializer { get; set; }
 |  | 
 | 
											
												
													
														|  | 
 |  | +        private readonly IJsonSerializer _jsonSerializer;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          /// <summary>
 |  |          /// <summary>
 | 
											
												
													
														|  |          /// Gets or sets the application paths.
 |  |          /// Gets or sets the application paths.
 | 
											
												
													
														|  |          /// </summary>
 |  |          /// </summary>
 | 
											
												
													
														|  |          /// <value>The application paths.</value>
 |  |          /// <value>The application paths.</value>
 | 
											
												
													
														|  | -        private IApplicationPaths ApplicationPaths { get; set; }
 |  | 
 | 
											
												
													
														|  | 
 |  | +        private readonly IApplicationPaths _applicationPaths;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          /// <summary>
 |  |          /// <summary>
 | 
											
												
													
														|  |          /// Gets the logger.
 |  |          /// Gets the logger.
 | 
											
												
													
														|  |          /// </summary>
 |  |          /// </summary>
 | 
											
												
													
														|  |          /// <value>The logger.</value>
 |  |          /// <value>The logger.</value>
 | 
											
												
													
														|  | -        private ILogger Logger { get; set; }
 |  | 
 | 
											
												
													
														|  | 
 |  | +        private readonly ILogger _logger;
 | 
											
												
													
														|  |          private readonly IFileSystem _fileSystem;
 |  |          private readonly IFileSystem _fileSystem;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          /// <summary>
 |  |          /// <summary>
 | 
											
										
											
												
													
														|  | @@ -57,19 +57,19 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |          /// <param name="applicationPaths">The application paths.</param>
 |  |          /// <param name="applicationPaths">The application paths.</param>
 | 
											
												
													
														|  |          /// <param name="jsonSerializer">The json serializer.</param>
 |  |          /// <param name="jsonSerializer">The json serializer.</param>
 | 
											
												
													
														|  |          /// <param name="loggerFactory">The logger factory.</param>
 |  |          /// <param name="loggerFactory">The logger factory.</param>
 | 
											
												
													
														|  | -        /// <exception cref="System.ArgumentException">kernel</exception>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        /// <param name="fileSystem">The filesystem manager.</param>
 | 
											
												
													
														|  |          public TaskManager(
 |  |          public TaskManager(
 | 
											
												
													
														|  |              IApplicationPaths applicationPaths,
 |  |              IApplicationPaths applicationPaths,
 | 
											
												
													
														|  |              IJsonSerializer jsonSerializer,
 |  |              IJsonSerializer jsonSerializer,
 | 
											
												
													
														|  |              ILoggerFactory loggerFactory,
 |  |              ILoggerFactory loggerFactory,
 | 
											
												
													
														|  |              IFileSystem fileSystem)
 |  |              IFileSystem fileSystem)
 | 
											
												
													
														|  |          {
 |  |          {
 | 
											
												
													
														|  | -            ApplicationPaths = applicationPaths;
 |  | 
 | 
											
												
													
														|  | -            JsonSerializer = jsonSerializer;
 |  | 
 | 
											
												
													
														|  | -            Logger = loggerFactory.CreateLogger(nameof(TaskManager));
 |  | 
 | 
											
												
													
														|  | 
 |  | +            _applicationPaths = applicationPaths;
 | 
											
												
													
														|  | 
 |  | +            _jsonSerializer = jsonSerializer;
 | 
											
												
													
														|  | 
 |  | +            _logger = loggerFactory.CreateLogger(nameof(TaskManager));
 | 
											
												
													
														|  |              _fileSystem = fileSystem;
 |  |              _fileSystem = fileSystem;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -            ScheduledTasks = new IScheduledTaskWorker[] { };
 |  | 
 | 
											
												
													
														|  | 
 |  | +            ScheduledTasks = Array.Empty<IScheduledTaskWorker>();
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          /// <summary>
 |  |          /// <summary>
 | 
											
										
											
												
													
														|  | @@ -78,7 +78,7 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |          /// <typeparam name="T"></typeparam>
 |  |          /// <typeparam name="T"></typeparam>
 | 
											
												
													
														|  |          /// <param name="options">Task options.</param>
 |  |          /// <param name="options">Task options.</param>
 | 
											
												
													
														|  |          public void CancelIfRunningAndQueue<T>(TaskOptions options)
 |  |          public void CancelIfRunningAndQueue<T>(TaskOptions options)
 | 
											
												
													
														|  | -                 where T : IScheduledTask
 |  | 
 | 
											
												
													
														|  | 
 |  | +            where T : IScheduledTask
 | 
											
												
													
														|  |          {
 |  |          {
 | 
											
												
													
														|  |              var task = ScheduledTasks.First(t => t.ScheduledTask.GetType() == typeof(T));
 |  |              var task = ScheduledTasks.First(t => t.ScheduledTask.GetType() == typeof(T));
 | 
											
												
													
														|  |              ((ScheduledTaskWorker)task).CancelIfRunning();
 |  |              ((ScheduledTaskWorker)task).CancelIfRunning();
 | 
											
										
											
												
													
														|  | @@ -115,7 +115,7 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              if (scheduledTask == null)
 |  |              if (scheduledTask == null)
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
												
													
														|  | -                Logger.LogError("Unable to find scheduled task of type {0} in QueueScheduledTask.", typeof(T).Name);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                _logger.LogError("Unable to find scheduled task of type {0} in QueueScheduledTask.", typeof(T).Name);
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |              else
 |  |              else
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
										
											
												
													
														|  | @@ -147,13 +147,13 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              if (scheduledTask == null)
 |  |              if (scheduledTask == null)
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
												
													
														|  | -                Logger.LogError("Unable to find scheduled task of type {0} in Execute.", typeof(T).Name);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                _logger.LogError("Unable to find scheduled task of type {0} in Execute.", typeof(T).Name);
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |              else
 |  |              else
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
												
													
														|  |                  var type = scheduledTask.ScheduledTask.GetType();
 |  |                  var type = scheduledTask.ScheduledTask.GetType();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -                Logger.LogInformation("Queueing task {0}", type.Name);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                _logger.LogInformation("Queueing task {0}", type.Name);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |                  lock (_taskQueue)
 |  |                  lock (_taskQueue)
 | 
											
												
													
														|  |                  {
 |  |                  {
 | 
											
										
											
												
													
														|  | @@ -176,7 +176,7 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              if (scheduledTask == null)
 |  |              if (scheduledTask == null)
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
												
													
														|  | -                Logger.LogError("Unable to find scheduled task of type {0} in QueueScheduledTask.", task.GetType().Name);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                _logger.LogError("Unable to find scheduled task of type {0} in QueueScheduledTask.", task.GetType().Name);
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |              else
 |  |              else
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
										
											
												
													
														|  | @@ -193,7 +193,7 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |          {
 |  |          {
 | 
											
												
													
														|  |              var type = task.ScheduledTask.GetType();
 |  |              var type = task.ScheduledTask.GetType();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -            Logger.LogInformation("Queueing task {0}", type.Name);
 |  | 
 | 
											
												
													
														|  | 
 |  | +            _logger.LogInformation("Queueing task {0}", type.Name);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              lock (_taskQueue)
 |  |              lock (_taskQueue)
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
										
											
												
													
														|  | @@ -213,7 +213,7 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |          /// <param name="tasks">The tasks.</param>
 |  |          /// <param name="tasks">The tasks.</param>
 | 
											
												
													
														|  |          public void AddTasks(IEnumerable<IScheduledTask> tasks)
 |  |          public void AddTasks(IEnumerable<IScheduledTask> tasks)
 | 
											
												
													
														|  |          {
 |  |          {
 | 
											
												
													
														|  | -            var list = tasks.Select(t => new ScheduledTaskWorker(t, ApplicationPaths, this, JsonSerializer, Logger, _fileSystem));
 |  | 
 | 
											
												
													
														|  | 
 |  | +            var list = tasks.Select(t => new ScheduledTaskWorker(t, _applicationPaths, this, _jsonSerializer, _logger, _fileSystem));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              ScheduledTasks = ScheduledTasks.Concat(list).ToArray();
 |  |              ScheduledTasks = ScheduledTasks.Concat(list).ToArray();
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
										
											
												
													
														|  | @@ -281,7 +281,7 @@ namespace Emby.Server.Implementations.ScheduledTasks
 | 
											
												
													
														|  |          /// </summary>
 |  |          /// </summary>
 | 
											
												
													
														|  |          private void ExecuteQueuedTasks()
 |  |          private void ExecuteQueuedTasks()
 | 
											
												
													
														|  |          {
 |  |          {
 | 
											
												
													
														|  | -            Logger.LogInformation("ExecuteQueuedTasks");
 |  | 
 | 
											
												
													
														|  | 
 |  | +            _logger.LogInformation("ExecuteQueuedTasks");
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              // Execute queued tasks
 |  |              // Execute queued tasks
 | 
											
												
													
														|  |              lock (_taskQueue)
 |  |              lock (_taskQueue)
 |