|
@@ -6,7 +6,7 @@ using MediaBrowser.Model.Events;
|
|
|
using MediaBrowser.Model.Tasks;
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
|
-namespace MediaBrowser.Api.ScheduledTasks
|
|
|
+namespace Jellyfin.Api.WebSocketListeners
|
|
|
{
|
|
|
/// <summary>
|
|
|
/// Class ScheduledTasksWebSocketListener.
|
|
@@ -17,42 +17,27 @@ namespace MediaBrowser.Api.ScheduledTasks
|
|
|
/// Gets or sets the task manager.
|
|
|
/// </summary>
|
|
|
/// <value>The task manager.</value>
|
|
|
- private ITaskManager TaskManager { get; set; }
|
|
|
+ private readonly ITaskManager _taskManager;
|
|
|
|
|
|
/// <summary>
|
|
|
- /// Gets the name.
|
|
|
- /// </summary>
|
|
|
- /// <value>The name.</value>
|
|
|
- protected override string Name => "ScheduledTasksInfo";
|
|
|
-
|
|
|
- /// <summary>
|
|
|
- /// Initializes a new instance of the <see cref="ScheduledTasksWebSocketListener" /> class.
|
|
|
+ /// Initializes a new instance of the <see cref="ScheduledTasksWebSocketListener"/> class.
|
|
|
/// </summary>
|
|
|
+ /// <param name="logger">Instance of the <see cref="ILogger{ScheduledTasksWebSocketListener}"/> interface.</param>
|
|
|
+ /// <param name="taskManager">Instance of the <see cref="ITaskManager"/> interface.</param>
|
|
|
public ScheduledTasksWebSocketListener(ILogger<ScheduledTasksWebSocketListener> logger, ITaskManager taskManager)
|
|
|
: base(logger)
|
|
|
{
|
|
|
- TaskManager = taskManager;
|
|
|
+ _taskManager = taskManager;
|
|
|
|
|
|
- TaskManager.TaskExecuting += TaskManager_TaskExecuting;
|
|
|
- TaskManager.TaskCompleted += TaskManager_TaskCompleted;
|
|
|
+ _taskManager.TaskExecuting += OnTaskExecuting;
|
|
|
+ _taskManager.TaskCompleted += OnTaskCompleted;
|
|
|
}
|
|
|
|
|
|
- void TaskManager_TaskCompleted(object sender, TaskCompletionEventArgs e)
|
|
|
- {
|
|
|
- SendData(true);
|
|
|
- e.Task.TaskProgress -= Argument_TaskProgress;
|
|
|
- }
|
|
|
-
|
|
|
- void TaskManager_TaskExecuting(object sender, GenericEventArgs<IScheduledTaskWorker> e)
|
|
|
- {
|
|
|
- SendData(true);
|
|
|
- e.Argument.TaskProgress += Argument_TaskProgress;
|
|
|
- }
|
|
|
-
|
|
|
- void Argument_TaskProgress(object sender, GenericEventArgs<double> e)
|
|
|
- {
|
|
|
- SendData(false);
|
|
|
- }
|
|
|
+ /// <summary>
|
|
|
+ /// Gets the name.
|
|
|
+ /// </summary>
|
|
|
+ /// <value>The name.</value>
|
|
|
+ protected override string Name => "ScheduledTasksInfo";
|
|
|
|
|
|
/// <summary>
|
|
|
/// Gets the data to send.
|
|
@@ -60,18 +45,36 @@ namespace MediaBrowser.Api.ScheduledTasks
|
|
|
/// <returns>Task{IEnumerable{TaskInfo}}.</returns>
|
|
|
protected override Task<IEnumerable<TaskInfo>> GetDataToSend()
|
|
|
{
|
|
|
- return Task.FromResult(TaskManager.ScheduledTasks
|
|
|
+ return Task.FromResult(_taskManager.ScheduledTasks
|
|
|
.OrderBy(i => i.Name)
|
|
|
.Select(ScheduledTaskHelpers.GetTaskInfo)
|
|
|
.Where(i => !i.IsHidden));
|
|
|
}
|
|
|
|
|
|
+ /// <inheritdoc />
|
|
|
protected override void Dispose(bool dispose)
|
|
|
{
|
|
|
- TaskManager.TaskExecuting -= TaskManager_TaskExecuting;
|
|
|
- TaskManager.TaskCompleted -= TaskManager_TaskCompleted;
|
|
|
+ _taskManager.TaskExecuting -= OnTaskExecuting;
|
|
|
+ _taskManager.TaskCompleted -= OnTaskCompleted;
|
|
|
|
|
|
base.Dispose(dispose);
|
|
|
}
|
|
|
+
|
|
|
+ private void OnTaskCompleted(object sender, TaskCompletionEventArgs e)
|
|
|
+ {
|
|
|
+ SendData(true);
|
|
|
+ e.Task.TaskProgress -= OnTaskProgress;
|
|
|
+ }
|
|
|
+
|
|
|
+ private void OnTaskExecuting(object sender, GenericEventArgs<IScheduledTaskWorker> e)
|
|
|
+ {
|
|
|
+ SendData(true);
|
|
|
+ e.Argument.TaskProgress += OnTaskProgress;
|
|
|
+ }
|
|
|
+
|
|
|
+ private void OnTaskProgress(object sender, GenericEventArgs<double> e)
|
|
|
+ {
|
|
|
+ SendData(false);
|
|
|
+ }
|
|
|
}
|
|
|
}
|