ActivityManager.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  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)
  35. {
  36. if (item.UserId == Guid.Empty)
  37. {
  38. continue;
  39. }
  40. var user = _userManager.GetUserById(item.UserId);
  41. if (user != null)
  42. {
  43. var dto = _userManager.GetUserDto(user);
  44. item.UserPrimaryImageTag = dto.PrimaryImageTag;
  45. }
  46. }
  47. return result;
  48. }
  49. public QueryResult<ActivityLogEntry> GetActivityLogEntries(DateTime? minDate, int? startIndex, int? limit)
  50. {
  51. return GetActivityLogEntries(minDate, null, startIndex, limit);
  52. }
  53. }
  54. }