From cfce1dba088dca44f5cf1ef3372738422a43d1c7 Mon Sep 17 00:00:00 2001 From: crobibero Date: Mon, 3 Aug 2020 13:09:32 -0600 Subject: move WebSocket listeners to Jellyfin.Api --- .../ScheduledTasksWebSocketListener.cs | 80 ++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs (limited to 'Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs') diff --git a/Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs b/Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs new file mode 100644 index 000000000..12f815ff7 --- /dev/null +++ b/Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs @@ -0,0 +1,80 @@ +using System.Collections.Generic; +using System.Linq; +using System.Threading.Tasks; +using MediaBrowser.Controller.Net; +using MediaBrowser.Model.Events; +using MediaBrowser.Model.Tasks; +using Microsoft.Extensions.Logging; + +namespace Jellyfin.Api.WebSocketListeners +{ + /// + /// Class ScheduledTasksWebSocketListener. + /// + public class ScheduledTasksWebSocketListener : BasePeriodicWebSocketListener, WebSocketListenerState> + { + /// + /// Gets or sets the task manager. + /// + /// The task manager. + private readonly ITaskManager _taskManager; + + /// + /// Initializes a new instance of the class. + /// + /// Instance of the interface. + /// Instance of the interface. + public ScheduledTasksWebSocketListener(ILogger logger, ITaskManager taskManager) + : base(logger) + { + _taskManager = taskManager; + + _taskManager.TaskExecuting += OnTaskExecuting; + _taskManager.TaskCompleted += OnTaskCompleted; + } + + /// + /// Gets the name. + /// + /// The name. + protected override string Name => "ScheduledTasksInfo"; + + /// + /// Gets the data to send. + /// + /// Task{IEnumerable{TaskInfo}}. + protected override Task> GetDataToSend() + { + return Task.FromResult(_taskManager.ScheduledTasks + .OrderBy(i => i.Name) + .Select(ScheduledTaskHelpers.GetTaskInfo) + .Where(i => !i.IsHidden)); + } + + /// + protected override void Dispose(bool dispose) + { + _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 e) + { + SendData(true); + e.Argument.TaskProgress += OnTaskProgress; + } + + private void OnTaskProgress(object sender, GenericEventArgs e) + { + SendData(false); + } + } +} -- cgit v1.2.3