ActivityManager.cs 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. using System;
  2. using System.Linq;
  3. using MediaBrowser.Controller.Library;
  4. using MediaBrowser.Model.Activity;
  5. using MediaBrowser.Model.Events;
  6. using MediaBrowser.Model.Querying;
  7. using Microsoft.Extensions.Logging;
  8. namespace Emby.Server.Implementations.Activity
  9. {
  10. public class ActivityManager : IActivityManager
  11. {
  12. public event EventHandler<GenericEventArgs<ActivityLogEntry>> EntryCreated;
  13. private readonly IActivityRepository _repo;
  14. private readonly ILogger _logger;
  15. private readonly IUserManager _userManager;
  16. public ActivityManager(
  17. ILoggerFactory loggerFactory,
  18. IActivityRepository repo,
  19. IUserManager userManager)
  20. {
  21. _logger = loggerFactory.CreateLogger(nameof(ActivityManager));
  22. _repo = repo;
  23. _userManager = userManager;
  24. }
  25. public void Create(ActivityLogEntry entry)
  26. {
  27. entry.Date = DateTime.UtcNow;
  28. _repo.Create(entry);
  29. EntryCreated?.Invoke(this, new GenericEventArgs<ActivityLogEntry>(entry));
  30. }
  31. public QueryResult<ActivityLogEntry> GetActivityLogEntries(DateTime? minDate, bool? hasUserId, int? startIndex, int? limit)
  32. {
  33. var result = _repo.GetActivityLogEntries(minDate, hasUserId, startIndex, limit);
  34. foreach (var item in result.Items.Where(i => !i.UserId.Equals(Guid.Empty)))
  35. {
  36. var user = _userManager.GetUserById(item.UserId);
  37. if (user != null)
  38. {
  39. var dto = _userManager.GetUserDto(user);
  40. item.UserPrimaryImageTag = dto.PrimaryImageTag;
  41. }
  42. }
  43. return result;
  44. }
  45. public QueryResult<ActivityLogEntry> GetActivityLogEntries(DateTime? minDate, int? startIndex, int? limit)
  46. {
  47. return GetActivityLogEntries(minDate, null, startIndex, limit);
  48. }
  49. }
  50. }