IItemRepository.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. #nullable disable
  2. #pragma warning disable CS1591
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Threading;
  6. using System.Threading.Tasks;
  7. using Jellyfin.Data.Enums;
  8. using MediaBrowser.Controller.Entities;
  9. using MediaBrowser.Model.Dto;
  10. using MediaBrowser.Model.Querying;
  11. namespace MediaBrowser.Controller.Persistence;
  12. /// <summary>
  13. /// Provides an interface to implement an Item repository.
  14. /// </summary>
  15. public interface IItemRepository
  16. {
  17. /// <summary>
  18. /// Deletes the item.
  19. /// </summary>
  20. /// <param name="id">The identifier.</param>
  21. void DeleteItem(Guid id);
  22. /// <summary>
  23. /// Saves the items.
  24. /// </summary>
  25. /// <param name="items">The items.</param>
  26. /// <param name="cancellationToken">The cancellation token.</param>
  27. void SaveItems(IReadOnlyList<BaseItem> items, CancellationToken cancellationToken);
  28. void SaveImages(BaseItem item);
  29. /// <summary>
  30. /// Retrieves the item.
  31. /// </summary>
  32. /// <param name="id">The id.</param>
  33. /// <returns>BaseItem.</returns>
  34. BaseItem RetrieveItem(Guid id);
  35. /// <summary>
  36. /// Gets the items.
  37. /// </summary>
  38. /// <param name="filter">The query.</param>
  39. /// <returns>QueryResult&lt;BaseItem&gt;.</returns>
  40. QueryResult<BaseItem> GetItems(InternalItemsQuery filter);
  41. /// <summary>
  42. /// Gets the item ids list.
  43. /// </summary>
  44. /// <param name="filter">The query.</param>
  45. /// <returns>List&lt;Guid&gt;.</returns>
  46. IReadOnlyList<Guid> GetItemIdsList(InternalItemsQuery filter);
  47. /// <summary>
  48. /// Gets the item list.
  49. /// </summary>
  50. /// <param name="filter">The query.</param>
  51. /// <returns>List&lt;BaseItem&gt;.</returns>
  52. IReadOnlyList<BaseItem> GetItemList(InternalItemsQuery filter);
  53. /// <summary>
  54. /// Gets the item list. Used mainly by the Latest api endpoint.
  55. /// </summary>
  56. /// <param name="filter">The query.</param>
  57. /// <param name="collectionType">Collection Type.</param>
  58. /// <returns>List&lt;BaseItem&gt;.</returns>
  59. IReadOnlyList<BaseItem> GetLatestItemList(InternalItemsQuery filter, CollectionType collectionType);
  60. /// <summary>
  61. /// Gets the list of series presentation keys for next up.
  62. /// </summary>
  63. /// <param name="filter">The query.</param>
  64. /// <param name="dateCutoff">The minimum date for a series to have been most recently watched.</param>
  65. /// <returns>The list of keys.</returns>
  66. IReadOnlyList<string> GetNextUpSeriesKeys(InternalItemsQuery filter, DateTime dateCutoff);
  67. /// <summary>
  68. /// Updates the inherited values.
  69. /// </summary>
  70. void UpdateInheritedValues();
  71. int GetCount(InternalItemsQuery filter);
  72. QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery filter);
  73. QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery filter);
  74. QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery filter);
  75. QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery filter);
  76. QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery filter);
  77. QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery filter);
  78. IReadOnlyList<string> GetMusicGenreNames();
  79. IReadOnlyList<string> GetStudioNames();
  80. IReadOnlyList<string> GetGenreNames();
  81. IReadOnlyList<string> GetAllArtistNames();
  82. /// <summary>
  83. /// Checks if an item has been persisted to the database.
  84. /// </summary>
  85. /// <param name="id">The id to check.</param>
  86. /// <returns>True if the item exists, otherwise false.</returns>
  87. Task<bool> ItemExistsAsync(Guid id);
  88. }