ActivityLogEntryPoint.cs 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. using System.Globalization;
  2. using System.Threading.Tasks;
  3. using Jellyfin.Data.Entities;
  4. using MediaBrowser.Controller.Plugins;
  5. using MediaBrowser.Controller.Session;
  6. using MediaBrowser.Model.Activity;
  7. using MediaBrowser.Model.Globalization;
  8. namespace Emby.Server.Implementations.Activity
  9. {
  10. /// <summary>
  11. /// Entry point for the activity logger.
  12. /// </summary>
  13. public sealed class ActivityLogEntryPoint : IServerEntryPoint
  14. {
  15. private readonly ISessionManager _sessionManager;
  16. private readonly IActivityManager _activityManager;
  17. private readonly ILocalizationManager _localization;
  18. /// <summary>
  19. /// Initializes a new instance of the <see cref="ActivityLogEntryPoint"/> class.
  20. /// </summary>
  21. /// <param name="sessionManager">The session manager.</param>
  22. /// <param name="activityManager">The activity manager.</param>
  23. /// <param name="localization">The localization manager.</param>
  24. public ActivityLogEntryPoint(
  25. ISessionManager sessionManager,
  26. IActivityManager activityManager,
  27. ILocalizationManager localization)
  28. {
  29. _sessionManager = sessionManager;
  30. _activityManager = activityManager;
  31. _localization = localization;
  32. }
  33. /// <inheritdoc />
  34. public Task RunAsync()
  35. {
  36. _sessionManager.SessionEnded += OnSessionEnded;
  37. return Task.CompletedTask;
  38. }
  39. private async void OnSessionEnded(object sender, SessionEventArgs e)
  40. {
  41. var session = e.SessionInfo;
  42. if (string.IsNullOrEmpty(session.UserName))
  43. {
  44. return;
  45. }
  46. await CreateLogEntry(new ActivityLog(
  47. string.Format(
  48. CultureInfo.InvariantCulture,
  49. _localization.GetLocalizedString("UserOfflineFromDevice"),
  50. session.UserName,
  51. session.DeviceName),
  52. "SessionEnded",
  53. session.UserId)
  54. {
  55. ShortOverview = string.Format(
  56. CultureInfo.InvariantCulture,
  57. _localization.GetLocalizedString("LabelIpAddressValue"),
  58. session.RemoteEndPoint),
  59. }).ConfigureAwait(false);
  60. }
  61. private async Task CreateLogEntry(ActivityLog entry)
  62. => await _activityManager.CreateAsync(entry).ConfigureAwait(false);
  63. /// <inheritdoc />
  64. public void Dispose()
  65. {
  66. _sessionManager.SessionEnded -= OnSessionEnded;
  67. }
  68. }
  69. }