| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 | using System.Globalization;using System.Threading.Tasks;using Jellyfin.Data.Entities;using MediaBrowser.Controller.Events;using MediaBrowser.Controller.Events.Session;using MediaBrowser.Model.Activity;using MediaBrowser.Model.Globalization;namespace Jellyfin.Server.Implementations.Events.Consumers.Session{    /// <summary>    /// Creates an entry in the activity log when a session is started.    /// </summary>    public class SessionStartedLogger : IEventConsumer<SessionStartedEventArgs>    {        private readonly ILocalizationManager _localizationManager;        private readonly IActivityManager _activityManager;        /// <summary>        /// Initializes a new instance of the <see cref="SessionStartedLogger"/> class.        /// </summary>        /// <param name="localizationManager">The localization manager.</param>        /// <param name="activityManager">The activity manager.</param>        public SessionStartedLogger(ILocalizationManager localizationManager, IActivityManager activityManager)        {            _localizationManager = localizationManager;            _activityManager = activityManager;        }        /// <inheritdoc />        public async Task OnEvent(SessionStartedEventArgs eventArgs)        {            if (string.IsNullOrEmpty(eventArgs.Argument.UserName))            {                return;            }            await _activityManager.CreateAsync(new ActivityLog(                string.Format(                    CultureInfo.InvariantCulture,                    _localizationManager.GetLocalizedString("UserOnlineFromDevice"),                    eventArgs.Argument.UserName,                    eventArgs.Argument.DeviceName),                "SessionStarted",                eventArgs.Argument.UserId)            {                ShortOverview = string.Format(                    CultureInfo.InvariantCulture,                    _localizationManager.GetLocalizedString("LabelIpAddressValue"),                    eventArgs.Argument.RemoteEndPoint)            }).ConfigureAwait(false);        }    }}
 |