aboutsummaryrefslogtreecommitdiff
path: root/Jellyfin.Api/WebSocketListeners
diff options
context:
space:
mode:
Diffstat (limited to 'Jellyfin.Api/WebSocketListeners')
-rw-r--r--Jellyfin.Api/WebSocketListeners/ActivityLogWebSocketListener.cs85
-rw-r--r--Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs117
-rw-r--r--Jellyfin.Api/WebSocketListeners/SessionInfoWebSocketListener.cs179
3 files changed, 189 insertions, 192 deletions
diff --git a/Jellyfin.Api/WebSocketListeners/ActivityLogWebSocketListener.cs b/Jellyfin.Api/WebSocketListeners/ActivityLogWebSocketListener.cs
index 288e03fcf..3eac81419 100644
--- a/Jellyfin.Api/WebSocketListeners/ActivityLogWebSocketListener.cs
+++ b/Jellyfin.Api/WebSocketListeners/ActivityLogWebSocketListener.cs
@@ -6,59 +6,58 @@ using MediaBrowser.Model.Activity;
using MediaBrowser.Model.Session;
using Microsoft.Extensions.Logging;
-namespace Jellyfin.Api.WebSocketListeners
+namespace Jellyfin.Api.WebSocketListeners;
+
+/// <summary>
+/// Class SessionInfoWebSocketListener.
+/// </summary>
+public class ActivityLogWebSocketListener : BasePeriodicWebSocketListener<ActivityLogEntry[], WebSocketListenerState>
{
/// <summary>
- /// Class SessionInfoWebSocketListener.
+ /// The _kernel.
/// </summary>
- public class ActivityLogWebSocketListener : BasePeriodicWebSocketListener<ActivityLogEntry[], WebSocketListenerState>
- {
- /// <summary>
- /// The _kernel.
- /// </summary>
- private readonly IActivityManager _activityManager;
+ private readonly IActivityManager _activityManager;
- /// <summary>
- /// Initializes a new instance of the <see cref="ActivityLogWebSocketListener"/> class.
- /// </summary>
- /// <param name="logger">Instance of the <see cref="ILogger{ActivityLogWebSocketListener}"/> interface.</param>
- /// <param name="activityManager">Instance of the <see cref="IActivityManager"/> interface.</param>
- public ActivityLogWebSocketListener(ILogger<ActivityLogWebSocketListener> logger, IActivityManager activityManager)
- : base(logger)
- {
- _activityManager = activityManager;
- _activityManager.EntryCreated += OnEntryCreated;
- }
+ /// <summary>
+ /// Initializes a new instance of the <see cref="ActivityLogWebSocketListener"/> class.
+ /// </summary>
+ /// <param name="logger">Instance of the <see cref="ILogger{ActivityLogWebSocketListener}"/> interface.</param>
+ /// <param name="activityManager">Instance of the <see cref="IActivityManager"/> interface.</param>
+ public ActivityLogWebSocketListener(ILogger<ActivityLogWebSocketListener> logger, IActivityManager activityManager)
+ : base(logger)
+ {
+ _activityManager = activityManager;
+ _activityManager.EntryCreated += OnEntryCreated;
+ }
- /// <inheritdoc />
- protected override SessionMessageType Type => SessionMessageType.ActivityLogEntry;
+ /// <inheritdoc />
+ protected override SessionMessageType Type => SessionMessageType.ActivityLogEntry;
- /// <inheritdoc />
- protected override SessionMessageType StartType => SessionMessageType.ActivityLogEntryStart;
+ /// <inheritdoc />
+ protected override SessionMessageType StartType => SessionMessageType.ActivityLogEntryStart;
- /// <inheritdoc />
- protected override SessionMessageType StopType => SessionMessageType.ActivityLogEntryStop;
+ /// <inheritdoc />
+ protected override SessionMessageType StopType => SessionMessageType.ActivityLogEntryStop;
- /// <summary>
- /// Gets the data to send.
- /// </summary>
- /// <returns>Task{SystemInfo}.</returns>
- protected override Task<ActivityLogEntry[]> GetDataToSend()
- {
- return Task.FromResult(Array.Empty<ActivityLogEntry>());
- }
+ /// <summary>
+ /// Gets the data to send.
+ /// </summary>
+ /// <returns>Task{SystemInfo}.</returns>
+ protected override Task<ActivityLogEntry[]> GetDataToSend()
+ {
+ return Task.FromResult(Array.Empty<ActivityLogEntry>());
+ }
- /// <inheritdoc />
- protected override void Dispose(bool dispose)
- {
- _activityManager.EntryCreated -= OnEntryCreated;
+ /// <inheritdoc />
+ protected override void Dispose(bool dispose)
+ {
+ _activityManager.EntryCreated -= OnEntryCreated;
- base.Dispose(dispose);
- }
+ base.Dispose(dispose);
+ }
- private void OnEntryCreated(object? sender, GenericEventArgs<ActivityLogEntry> e)
- {
- SendData(true).GetAwaiter().GetResult();
- }
+ private void OnEntryCreated(object? sender, GenericEventArgs<ActivityLogEntry> e)
+ {
+ SendData(true).GetAwaiter().GetResult();
}
}
diff --git a/Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs b/Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs
index 7c6ce3273..a9df2d671 100644
--- a/Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs
+++ b/Jellyfin.Api/WebSocketListeners/ScheduledTasksWebSocketListener.cs
@@ -7,78 +7,77 @@ using MediaBrowser.Model.Session;
using MediaBrowser.Model.Tasks;
using Microsoft.Extensions.Logging;
-namespace Jellyfin.Api.WebSocketListeners
+namespace Jellyfin.Api.WebSocketListeners;
+
+/// <summary>
+/// Class ScheduledTasksWebSocketListener.
+/// </summary>
+public class ScheduledTasksWebSocketListener : BasePeriodicWebSocketListener<IEnumerable<TaskInfo>, WebSocketListenerState>
{
/// <summary>
- /// Class ScheduledTasksWebSocketListener.
+ /// Gets or sets the task manager.
/// </summary>
- public class ScheduledTasksWebSocketListener : BasePeriodicWebSocketListener<IEnumerable<TaskInfo>, WebSocketListenerState>
- {
- /// <summary>
- /// Gets or sets the task manager.
- /// </summary>
- /// <value>The task manager.</value>
- private readonly ITaskManager _taskManager;
+ /// <value>The task manager.</value>
+ private readonly ITaskManager _taskManager;
- /// <summary>
- /// 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;
+ /// <summary>
+ /// 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.TaskExecuting += OnTaskExecuting;
- _taskManager.TaskCompleted += OnTaskCompleted;
- }
+ _taskManager.TaskExecuting += OnTaskExecuting;
+ _taskManager.TaskCompleted += OnTaskCompleted;
+ }
- /// <inheritdoc />
- protected override SessionMessageType Type => SessionMessageType.ScheduledTasksInfo;
+ /// <inheritdoc />
+ protected override SessionMessageType Type => SessionMessageType.ScheduledTasksInfo;
- /// <inheritdoc />
- protected override SessionMessageType StartType => SessionMessageType.ScheduledTasksInfoStart;
+ /// <inheritdoc />
+ protected override SessionMessageType StartType => SessionMessageType.ScheduledTasksInfoStart;
- /// <inheritdoc />
- protected override SessionMessageType StopType => SessionMessageType.ScheduledTasksInfoStop;
+ /// <inheritdoc />
+ protected override SessionMessageType StopType => SessionMessageType.ScheduledTasksInfoStop;
- /// <summary>
- /// Gets the data to send.
- /// </summary>
- /// <returns>Task{IEnumerable{TaskInfo}}.</returns>
- protected override Task<IEnumerable<TaskInfo>> GetDataToSend()
- {
- return Task.FromResult(_taskManager.ScheduledTasks
- .OrderBy(i => i.Name)
- .Select(ScheduledTaskHelpers.GetTaskInfo)
- .Where(i => !i.IsHidden));
- }
+ /// <summary>
+ /// Gets the data to send.
+ /// </summary>
+ /// <returns>Task{IEnumerable{TaskInfo}}.</returns>
+ protected override Task<IEnumerable<TaskInfo>> GetDataToSend()
+ {
+ 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 -= OnTaskExecuting;
- _taskManager.TaskCompleted -= OnTaskCompleted;
+ /// <inheritdoc />
+ protected override void Dispose(bool dispose)
+ {
+ _taskManager.TaskExecuting -= OnTaskExecuting;
+ _taskManager.TaskCompleted -= OnTaskCompleted;
- base.Dispose(dispose);
- }
+ base.Dispose(dispose);
+ }
- private async void OnTaskCompleted(object? sender, TaskCompletionEventArgs e)
- {
- e.Task.TaskProgress -= OnTaskProgress;
- await SendData(true).ConfigureAwait(false);
- }
+ private async void OnTaskCompleted(object? sender, TaskCompletionEventArgs e)
+ {
+ e.Task.TaskProgress -= OnTaskProgress;
+ await SendData(true).ConfigureAwait(false);
+ }
- private async void OnTaskExecuting(object? sender, GenericEventArgs<IScheduledTaskWorker> e)
- {
- await SendData(true).ConfigureAwait(false);
- e.Argument.TaskProgress += OnTaskProgress;
- }
+ private async void OnTaskExecuting(object? sender, GenericEventArgs<IScheduledTaskWorker> e)
+ {
+ await SendData(true).ConfigureAwait(false);
+ e.Argument.TaskProgress += OnTaskProgress;
+ }
- private async void OnTaskProgress(object? sender, GenericEventArgs<double> e)
- {
- await SendData(false).ConfigureAwait(false);
- }
+ private async void OnTaskProgress(object? sender, GenericEventArgs<double> e)
+ {
+ await SendData(false).ConfigureAwait(false);
}
}
diff --git a/Jellyfin.Api/WebSocketListeners/SessionInfoWebSocketListener.cs b/Jellyfin.Api/WebSocketListeners/SessionInfoWebSocketListener.cs
index d996ac69f..0d8bf205c 100644
--- a/Jellyfin.Api/WebSocketListeners/SessionInfoWebSocketListener.cs
+++ b/Jellyfin.Api/WebSocketListeners/SessionInfoWebSocketListener.cs
@@ -6,99 +6,98 @@ using MediaBrowser.Controller.Session;
using MediaBrowser.Model.Session;
using Microsoft.Extensions.Logging;
-namespace Jellyfin.Api.WebSocketListeners
+namespace Jellyfin.Api.WebSocketListeners;
+
+/// <summary>
+/// Class SessionInfoWebSocketListener.
+/// </summary>
+public class SessionInfoWebSocketListener : BasePeriodicWebSocketListener<IEnumerable<SessionInfo>, WebSocketListenerState>
{
+ private readonly ISessionManager _sessionManager;
+
/// <summary>
- /// Class SessionInfoWebSocketListener.
+ /// Initializes a new instance of the <see cref="SessionInfoWebSocketListener"/> class.
/// </summary>
- public class SessionInfoWebSocketListener : BasePeriodicWebSocketListener<IEnumerable<SessionInfo>, WebSocketListenerState>
+ /// <param name="logger">Instance of the <see cref="ILogger{SessionInfoWebSocketListener}"/> interface.</param>
+ /// <param name="sessionManager">Instance of the <see cref="ISessionManager"/> interface.</param>
+ public SessionInfoWebSocketListener(ILogger<SessionInfoWebSocketListener> logger, ISessionManager sessionManager)
+ : base(logger)
+ {
+ _sessionManager = sessionManager;
+
+ _sessionManager.SessionStarted += OnSessionManagerSessionStarted;
+ _sessionManager.SessionEnded += OnSessionManagerSessionEnded;
+ _sessionManager.PlaybackStart += OnSessionManagerPlaybackStart;
+ _sessionManager.PlaybackStopped += OnSessionManagerPlaybackStopped;
+ _sessionManager.PlaybackProgress += OnSessionManagerPlaybackProgress;
+ _sessionManager.CapabilitiesChanged += OnSessionManagerCapabilitiesChanged;
+ _sessionManager.SessionActivity += OnSessionManagerSessionActivity;
+ }
+
+ /// <inheritdoc />
+ protected override SessionMessageType Type => SessionMessageType.Sessions;
+
+ /// <inheritdoc />
+ protected override SessionMessageType StartType => SessionMessageType.SessionsStart;
+
+ /// <inheritdoc />
+ protected override SessionMessageType StopType => SessionMessageType.SessionsStop;
+
+ /// <summary>
+ /// Gets the data to send.
+ /// </summary>
+ /// <returns>Task{SystemInfo}.</returns>
+ protected override Task<IEnumerable<SessionInfo>> GetDataToSend()
+ {
+ return Task.FromResult(_sessionManager.Sessions);
+ }
+
+ /// <inheritdoc />
+ protected override void Dispose(bool dispose)
+ {
+ _sessionManager.SessionStarted -= OnSessionManagerSessionStarted;
+ _sessionManager.SessionEnded -= OnSessionManagerSessionEnded;
+ _sessionManager.PlaybackStart -= OnSessionManagerPlaybackStart;
+ _sessionManager.PlaybackStopped -= OnSessionManagerPlaybackStopped;
+ _sessionManager.PlaybackProgress -= OnSessionManagerPlaybackProgress;
+ _sessionManager.CapabilitiesChanged -= OnSessionManagerCapabilitiesChanged;
+ _sessionManager.SessionActivity -= OnSessionManagerSessionActivity;
+
+ base.Dispose(dispose);
+ }
+
+ private async void OnSessionManagerSessionActivity(object? sender, SessionEventArgs e)
+ {
+ await SendData(false).ConfigureAwait(false);
+ }
+
+ private async void OnSessionManagerCapabilitiesChanged(object? sender, SessionEventArgs e)
+ {
+ await SendData(true).ConfigureAwait(false);
+ }
+
+ private async void OnSessionManagerPlaybackProgress(object? sender, PlaybackProgressEventArgs e)
+ {
+ await SendData(!e.IsAutomated).ConfigureAwait(false);
+ }
+
+ private async void OnSessionManagerPlaybackStopped(object? sender, PlaybackStopEventArgs e)
+ {
+ await SendData(true).ConfigureAwait(false);
+ }
+
+ private async void OnSessionManagerPlaybackStart(object? sender, PlaybackProgressEventArgs e)
+ {
+ await SendData(true).ConfigureAwait(false);
+ }
+
+ private async void OnSessionManagerSessionEnded(object? sender, SessionEventArgs e)
+ {
+ await SendData(true).ConfigureAwait(false);
+ }
+
+ private async void OnSessionManagerSessionStarted(object? sender, SessionEventArgs e)
{
- private readonly ISessionManager _sessionManager;
-
- /// <summary>
- /// Initializes a new instance of the <see cref="SessionInfoWebSocketListener"/> class.
- /// </summary>
- /// <param name="logger">Instance of the <see cref="ILogger{SessionInfoWebSocketListener}"/> interface.</param>
- /// <param name="sessionManager">Instance of the <see cref="ISessionManager"/> interface.</param>
- public SessionInfoWebSocketListener(ILogger<SessionInfoWebSocketListener> logger, ISessionManager sessionManager)
- : base(logger)
- {
- _sessionManager = sessionManager;
-
- _sessionManager.SessionStarted += OnSessionManagerSessionStarted;
- _sessionManager.SessionEnded += OnSessionManagerSessionEnded;
- _sessionManager.PlaybackStart += OnSessionManagerPlaybackStart;
- _sessionManager.PlaybackStopped += OnSessionManagerPlaybackStopped;
- _sessionManager.PlaybackProgress += OnSessionManagerPlaybackProgress;
- _sessionManager.CapabilitiesChanged += OnSessionManagerCapabilitiesChanged;
- _sessionManager.SessionActivity += OnSessionManagerSessionActivity;
- }
-
- /// <inheritdoc />
- protected override SessionMessageType Type => SessionMessageType.Sessions;
-
- /// <inheritdoc />
- protected override SessionMessageType StartType => SessionMessageType.SessionsStart;
-
- /// <inheritdoc />
- protected override SessionMessageType StopType => SessionMessageType.SessionsStop;
-
- /// <summary>
- /// Gets the data to send.
- /// </summary>
- /// <returns>Task{SystemInfo}.</returns>
- protected override Task<IEnumerable<SessionInfo>> GetDataToSend()
- {
- return Task.FromResult(_sessionManager.Sessions);
- }
-
- /// <inheritdoc />
- protected override void Dispose(bool dispose)
- {
- _sessionManager.SessionStarted -= OnSessionManagerSessionStarted;
- _sessionManager.SessionEnded -= OnSessionManagerSessionEnded;
- _sessionManager.PlaybackStart -= OnSessionManagerPlaybackStart;
- _sessionManager.PlaybackStopped -= OnSessionManagerPlaybackStopped;
- _sessionManager.PlaybackProgress -= OnSessionManagerPlaybackProgress;
- _sessionManager.CapabilitiesChanged -= OnSessionManagerCapabilitiesChanged;
- _sessionManager.SessionActivity -= OnSessionManagerSessionActivity;
-
- base.Dispose(dispose);
- }
-
- private async void OnSessionManagerSessionActivity(object? sender, SessionEventArgs e)
- {
- await SendData(false).ConfigureAwait(false);
- }
-
- private async void OnSessionManagerCapabilitiesChanged(object? sender, SessionEventArgs e)
- {
- await SendData(true).ConfigureAwait(false);
- }
-
- private async void OnSessionManagerPlaybackProgress(object? sender, PlaybackProgressEventArgs e)
- {
- await SendData(!e.IsAutomated).ConfigureAwait(false);
- }
-
- private async void OnSessionManagerPlaybackStopped(object? sender, PlaybackStopEventArgs e)
- {
- await SendData(true).ConfigureAwait(false);
- }
-
- private async void OnSessionManagerPlaybackStart(object? sender, PlaybackProgressEventArgs e)
- {
- await SendData(true).ConfigureAwait(false);
- }
-
- private async void OnSessionManagerSessionEnded(object? sender, SessionEventArgs e)
- {
- await SendData(true).ConfigureAwait(false);
- }
-
- private async void OnSessionManagerSessionStarted(object? sender, SessionEventArgs e)
- {
- await SendData(true).ConfigureAwait(false);
- }
+ await SendData(true).ConfigureAwait(false);
}
}