SessionEndedLogger.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. using System.Globalization;
  2. using System.Threading.Tasks;
  3. using Jellyfin.Data.Entities;
  4. using MediaBrowser.Controller.Events;
  5. using MediaBrowser.Controller.Events.Session;
  6. using MediaBrowser.Model.Activity;
  7. using MediaBrowser.Model.Globalization;
  8. namespace Jellyfin.Server.Implementations.Events.Consumers.Session
  9. {
  10. /// <summary>
  11. /// Creates an entry in the activity log whenever a session ends.
  12. /// </summary>
  13. public class SessionEndedLogger : IEventConsumer<SessionEndedEventArgs>
  14. {
  15. private readonly ILocalizationManager _localizationManager;
  16. private readonly IActivityManager _activityManager;
  17. /// <summary>
  18. /// Initializes a new instance of the <see cref="SessionEndedLogger"/> class.
  19. /// </summary>
  20. /// <param name="localizationManager">The localization manager.</param>
  21. /// <param name="activityManager">The activity manager.</param>
  22. public SessionEndedLogger(ILocalizationManager localizationManager, IActivityManager activityManager)
  23. {
  24. _localizationManager = localizationManager;
  25. _activityManager = activityManager;
  26. }
  27. /// <inheritdoc />
  28. public async Task OnEvent(SessionEndedEventArgs eventArgs)
  29. {
  30. if (string.IsNullOrEmpty(eventArgs.Argument.UserName))
  31. {
  32. return;
  33. }
  34. await _activityManager.CreateAsync(new ActivityLog(
  35. string.Format(
  36. CultureInfo.InvariantCulture,
  37. _localizationManager.GetLocalizedString("UserOfflineFromDevice"),
  38. eventArgs.Argument.UserName,
  39. eventArgs.Argument.DeviceName),
  40. "SessionEnded",
  41. eventArgs.Argument.UserId)
  42. {
  43. ShortOverview = string.Format(
  44. CultureInfo.InvariantCulture,
  45. _localizationManager.GetLocalizedString("LabelIpAddressValue"),
  46. eventArgs.Argument.RemoteEndPoint),
  47. }).ConfigureAwait(false);
  48. }
  49. }
  50. }