ActivityLogWebSocketListener.cs 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. using System;
  2. using System.Threading.Tasks;
  3. using Jellyfin.Data;
  4. using Jellyfin.Data.Events;
  5. using Jellyfin.Database.Implementations.Enums;
  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.IsApiKey
  64. && (message.Connection.AuthorizationInfo.User is null
  65. || !message.Connection.AuthorizationInfo.User.HasPermission(PermissionKind.IsAdministrator)))
  66. {
  67. throw new AuthenticationException("Only admin users can retrieve the activity log.");
  68. }
  69. base.Start(message);
  70. }
  71. private void OnEntryCreated(object? sender, GenericEventArgs<ActivityLogEntry> e)
  72. {
  73. SendData(true);
  74. }
  75. }