ActivityLogEntryPoint.cs 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. using System;
  2. using System.Globalization;
  3. using System.Threading.Tasks;
  4. using Jellyfin.Data.Entities;
  5. using Jellyfin.Data.Events;
  6. using MediaBrowser.Common.Plugins;
  7. using MediaBrowser.Common.Updates;
  8. using MediaBrowser.Controller.Authentication;
  9. using MediaBrowser.Controller.Plugins;
  10. using MediaBrowser.Controller.Session;
  11. using MediaBrowser.Model.Activity;
  12. using MediaBrowser.Model.Globalization;
  13. using MediaBrowser.Model.Notifications;
  14. using MediaBrowser.Model.Updates;
  15. namespace Emby.Server.Implementations.Activity
  16. {
  17. /// <summary>
  18. /// Entry point for the activity logger.
  19. /// </summary>
  20. public sealed class ActivityLogEntryPoint : IServerEntryPoint
  21. {
  22. private readonly IInstallationManager _installationManager;
  23. private readonly ISessionManager _sessionManager;
  24. private readonly IActivityManager _activityManager;
  25. private readonly ILocalizationManager _localization;
  26. /// <summary>
  27. /// Initializes a new instance of the <see cref="ActivityLogEntryPoint"/> class.
  28. /// </summary>
  29. /// <param name="sessionManager">The session manager.</param>
  30. /// <param name="activityManager">The activity manager.</param>
  31. /// <param name="localization">The localization manager.</param>
  32. /// <param name="installationManager">The installation manager.</param>
  33. public ActivityLogEntryPoint(
  34. ISessionManager sessionManager,
  35. IActivityManager activityManager,
  36. ILocalizationManager localization,
  37. IInstallationManager installationManager)
  38. {
  39. _sessionManager = sessionManager;
  40. _activityManager = activityManager;
  41. _localization = localization;
  42. _installationManager = installationManager;
  43. }
  44. /// <inheritdoc />
  45. public Task RunAsync()
  46. {
  47. _installationManager.PluginInstalled += OnPluginInstalled;
  48. _installationManager.PluginUninstalled += OnPluginUninstalled;
  49. _installationManager.PluginUpdated += OnPluginUpdated;
  50. _installationManager.PackageInstallationFailed += OnPackageInstallationFailed;
  51. _sessionManager.SessionStarted += OnSessionStarted;
  52. _sessionManager.AuthenticationSucceeded += OnAuthenticationSucceeded;
  53. _sessionManager.SessionEnded += OnSessionEnded;
  54. return Task.CompletedTask;
  55. }
  56. private async void OnSessionEnded(object sender, SessionEventArgs e)
  57. {
  58. var session = e.SessionInfo;
  59. if (string.IsNullOrEmpty(session.UserName))
  60. {
  61. return;
  62. }
  63. await CreateLogEntry(new ActivityLog(
  64. string.Format(
  65. CultureInfo.InvariantCulture,
  66. _localization.GetLocalizedString("UserOfflineFromDevice"),
  67. session.UserName,
  68. session.DeviceName),
  69. "SessionEnded",
  70. session.UserId)
  71. {
  72. ShortOverview = string.Format(
  73. CultureInfo.InvariantCulture,
  74. _localization.GetLocalizedString("LabelIpAddressValue"),
  75. session.RemoteEndPoint),
  76. }).ConfigureAwait(false);
  77. }
  78. private async void OnAuthenticationSucceeded(object sender, GenericEventArgs<AuthenticationResult> e)
  79. {
  80. var user = e.Argument.User;
  81. await CreateLogEntry(new ActivityLog(
  82. string.Format(
  83. CultureInfo.InvariantCulture,
  84. _localization.GetLocalizedString("AuthenticationSucceededWithUserName"),
  85. user.Name),
  86. "AuthenticationSucceeded",
  87. user.Id)
  88. {
  89. ShortOverview = string.Format(
  90. CultureInfo.InvariantCulture,
  91. _localization.GetLocalizedString("LabelIpAddressValue"),
  92. e.Argument.SessionInfo.RemoteEndPoint),
  93. }).ConfigureAwait(false);
  94. }
  95. private async void OnSessionStarted(object sender, SessionEventArgs e)
  96. {
  97. var session = e.SessionInfo;
  98. if (string.IsNullOrEmpty(session.UserName))
  99. {
  100. return;
  101. }
  102. await CreateLogEntry(new ActivityLog(
  103. string.Format(
  104. CultureInfo.InvariantCulture,
  105. _localization.GetLocalizedString("UserOnlineFromDevice"),
  106. session.UserName,
  107. session.DeviceName),
  108. "SessionStarted",
  109. session.UserId)
  110. {
  111. ShortOverview = string.Format(
  112. CultureInfo.InvariantCulture,
  113. _localization.GetLocalizedString("LabelIpAddressValue"),
  114. session.RemoteEndPoint)
  115. }).ConfigureAwait(false);
  116. }
  117. private async void OnPluginUpdated(object sender, InstallationInfo e)
  118. {
  119. await CreateLogEntry(new ActivityLog(
  120. string.Format(
  121. CultureInfo.InvariantCulture,
  122. _localization.GetLocalizedString("PluginUpdatedWithName"),
  123. e.Name),
  124. NotificationType.PluginUpdateInstalled.ToString(),
  125. Guid.Empty)
  126. {
  127. ShortOverview = string.Format(
  128. CultureInfo.InvariantCulture,
  129. _localization.GetLocalizedString("VersionNumber"),
  130. e.Version),
  131. Overview = e.Changelog
  132. }).ConfigureAwait(false);
  133. }
  134. private async void OnPluginUninstalled(object sender, IPlugin e)
  135. {
  136. await CreateLogEntry(new ActivityLog(
  137. string.Format(
  138. CultureInfo.InvariantCulture,
  139. _localization.GetLocalizedString("PluginUninstalledWithName"),
  140. e.Name),
  141. NotificationType.PluginUninstalled.ToString(),
  142. Guid.Empty))
  143. .ConfigureAwait(false);
  144. }
  145. private async void OnPluginInstalled(object sender, InstallationInfo e)
  146. {
  147. await CreateLogEntry(new ActivityLog(
  148. string.Format(
  149. CultureInfo.InvariantCulture,
  150. _localization.GetLocalizedString("PluginInstalledWithName"),
  151. e.Name),
  152. NotificationType.PluginInstalled.ToString(),
  153. Guid.Empty)
  154. {
  155. ShortOverview = string.Format(
  156. CultureInfo.InvariantCulture,
  157. _localization.GetLocalizedString("VersionNumber"),
  158. e.Version)
  159. }).ConfigureAwait(false);
  160. }
  161. private async void OnPackageInstallationFailed(object sender, InstallationFailedEventArgs e)
  162. {
  163. var installationInfo = e.InstallationInfo;
  164. await CreateLogEntry(new ActivityLog(
  165. string.Format(
  166. CultureInfo.InvariantCulture,
  167. _localization.GetLocalizedString("NameInstallFailed"),
  168. installationInfo.Name),
  169. NotificationType.InstallationFailed.ToString(),
  170. Guid.Empty)
  171. {
  172. ShortOverview = string.Format(
  173. CultureInfo.InvariantCulture,
  174. _localization.GetLocalizedString("VersionNumber"),
  175. installationInfo.Version),
  176. Overview = e.Exception.Message
  177. }).ConfigureAwait(false);
  178. }
  179. private async Task CreateLogEntry(ActivityLog entry)
  180. => await _activityManager.CreateAsync(entry).ConfigureAwait(false);
  181. /// <inheritdoc />
  182. public void Dispose()
  183. {
  184. _installationManager.PluginInstalled -= OnPluginInstalled;
  185. _installationManager.PluginUninstalled -= OnPluginUninstalled;
  186. _installationManager.PluginUpdated -= OnPluginUpdated;
  187. _installationManager.PackageInstallationFailed -= OnPackageInstallationFailed;
  188. _sessionManager.SessionStarted -= OnSessionStarted;
  189. _sessionManager.AuthenticationSucceeded -= OnAuthenticationSucceeded;
  190. _sessionManager.SessionEnded -= OnSessionEnded;
  191. }
  192. }
  193. }