123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- using System.Globalization;
- using System.Threading.Tasks;
- using Jellyfin.Data.Entities;
- using MediaBrowser.Controller.Plugins;
- using MediaBrowser.Controller.Session;
- using MediaBrowser.Model.Activity;
- using MediaBrowser.Model.Globalization;
- namespace Emby.Server.Implementations.Activity
- {
- /// <summary>
- /// Entry point for the activity logger.
- /// </summary>
- public sealed class ActivityLogEntryPoint : IServerEntryPoint
- {
- private readonly ISessionManager _sessionManager;
- private readonly IActivityManager _activityManager;
- private readonly ILocalizationManager _localization;
- /// <summary>
- /// Initializes a new instance of the <see cref="ActivityLogEntryPoint"/> class.
- /// </summary>
- /// <param name="sessionManager">The session manager.</param>
- /// <param name="activityManager">The activity manager.</param>
- /// <param name="localization">The localization manager.</param>
- public ActivityLogEntryPoint(
- ISessionManager sessionManager,
- IActivityManager activityManager,
- ILocalizationManager localization)
- {
- _sessionManager = sessionManager;
- _activityManager = activityManager;
- _localization = localization;
- }
- /// <inheritdoc />
- public Task RunAsync()
- {
- _sessionManager.SessionEnded += OnSessionEnded;
- return Task.CompletedTask;
- }
- private async void OnSessionEnded(object sender, SessionEventArgs e)
- {
- var session = e.SessionInfo;
- if (string.IsNullOrEmpty(session.UserName))
- {
- return;
- }
- await CreateLogEntry(new ActivityLog(
- string.Format(
- CultureInfo.InvariantCulture,
- _localization.GetLocalizedString("UserOfflineFromDevice"),
- session.UserName,
- session.DeviceName),
- "SessionEnded",
- session.UserId)
- {
- ShortOverview = string.Format(
- CultureInfo.InvariantCulture,
- _localization.GetLocalizedString("LabelIpAddressValue"),
- session.RemoteEndPoint),
- }).ConfigureAwait(false);
- }
- private async Task CreateLogEntry(ActivityLog entry)
- => await _activityManager.CreateAsync(entry).ConfigureAwait(false);
- /// <inheritdoc />
- public void Dispose()
- {
- _sessionManager.SessionEnded -= OnSessionEnded;
- }
- }
- }
|