ActivityLogWebSocketListener.cs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. using System;
  2. using System.Threading.Tasks;
  3. using Jellyfin.Data;
  4. using Jellyfin.Data.Enums;
  5. using Jellyfin.Data.Events;
  6. using MediaBrowser.Controller.Authentication;
  7. using MediaBrowser.Controller.Net;
  8. using MediaBrowser.Model.Activity;
  9. using MediaBrowser.Model.Session;
  10. using Microsoft.Extensions.Logging;
  11. namespace Jellyfin.Api.WebSocketListeners;
  12. /// <summary>
  13. /// Class ActivityLogWebSocketListener.
  14. /// </summary>
  15. public class ActivityLogWebSocketListener : BasePeriodicWebSocketListener<ActivityLogEntry[], WebSocketListenerState>
  16. {
  17. /// <summary>
  18. /// The _kernel.
  19. /// </summary>
  20. private readonly IActivityManager _activityManager;
  21. private bool _disposed;
  22. /// <summary>
  23. /// Initializes a new instance of the <see cref="ActivityLogWebSocketListener"/> class.
  24. /// </summary>
  25. /// <param name="logger">Instance of the <see cref="ILogger{ActivityLogWebSocketListener}"/> interface.</param>
  26. /// <param name="activityManager">Instance of the <see cref="IActivityManager"/> interface.</param>
  27. public ActivityLogWebSocketListener(ILogger<ActivityLogWebSocketListener> logger, IActivityManager activityManager)
  28. : base(logger)
  29. {
  30. _activityManager = activityManager;
  31. _activityManager.EntryCreated += OnEntryCreated;
  32. }
  33. /// <inheritdoc />
  34. protected override SessionMessageType Type => SessionMessageType.ActivityLogEntry;
  35. /// <inheritdoc />
  36. protected override SessionMessageType StartType => SessionMessageType.ActivityLogEntryStart;
  37. /// <inheritdoc />
  38. protected override SessionMessageType StopType => SessionMessageType.ActivityLogEntryStop;
  39. /// <summary>
  40. /// Gets the data to send.
  41. /// </summary>
  42. /// <returns>Task{SystemInfo}.</returns>
  43. protected override Task<ActivityLogEntry[]> GetDataToSend()
  44. {
  45. return Task.FromResult(Array.Empty<ActivityLogEntry>());
  46. }
  47. /// <inheritdoc />
  48. protected override async ValueTask DisposeAsyncCore()
  49. {
  50. if (!_disposed)
  51. {
  52. _activityManager.EntryCreated -= OnEntryCreated;
  53. _disposed = true;
  54. }
  55. await base.DisposeAsyncCore().ConfigureAwait(false);
  56. }
  57. /// <summary>
  58. /// Starts sending messages over an activity log web socket.
  59. /// </summary>
  60. /// <param name="message">The message.</param>
  61. protected override void Start(WebSocketMessageInfo message)
  62. {
  63. if (!message.Connection.AuthorizationInfo.User.HasPermission(PermissionKind.IsAdministrator))
  64. {
  65. throw new AuthenticationException("Only admin users can retrieve the activity log.");
  66. }
  67. base.Start(message);
  68. }
  69. private void OnEntryCreated(object? sender, GenericEventArgs<ActivityLogEntry> e)
  70. {
  71. SendData(true);
  72. }
  73. }