IItemRepository.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. using MediaBrowser.Controller.Entities;
  2. using MediaBrowser.Model.Entities;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Threading;
  7. using System.Threading.Tasks;
  8. namespace MediaBrowser.Controller.Persistence
  9. {
  10. /// <summary>
  11. /// Provides an interface to implement an Item repository
  12. /// </summary>
  13. public interface IItemRepository : IRepository
  14. {
  15. /// <summary>
  16. /// Opens the connection to the repository
  17. /// </summary>
  18. /// <returns>Task.</returns>
  19. Task Initialize();
  20. /// <summary>
  21. /// Saves an item
  22. /// </summary>
  23. /// <param name="item">The item.</param>
  24. /// <param name="cancellationToken">The cancellation token.</param>
  25. /// <returns>Task.</returns>
  26. Task SaveItem(BaseItem item, CancellationToken cancellationToken);
  27. /// <summary>
  28. /// Gets the critic reviews.
  29. /// </summary>
  30. /// <param name="itemId">The item id.</param>
  31. /// <returns>Task{IEnumerable{ItemReview}}.</returns>
  32. Task<IEnumerable<ItemReview>> GetCriticReviews(Guid itemId);
  33. /// <summary>
  34. /// Saves the critic reviews.
  35. /// </summary>
  36. /// <param name="itemId">The item id.</param>
  37. /// <param name="criticReviews">The critic reviews.</param>
  38. /// <returns>Task.</returns>
  39. Task SaveCriticReviews(Guid itemId, IEnumerable<ItemReview> criticReviews);
  40. /// <summary>
  41. /// Saves the items.
  42. /// </summary>
  43. /// <param name="items">The items.</param>
  44. /// <param name="cancellationToken">The cancellation token.</param>
  45. /// <returns>Task.</returns>
  46. Task SaveItems(IEnumerable<BaseItem> items, CancellationToken cancellationToken);
  47. /// <summary>
  48. /// Retrieves the item.
  49. /// </summary>
  50. /// <param name="id">The id.</param>
  51. /// <param name="type">The type.</param>
  52. /// <returns>BaseItem.</returns>
  53. BaseItem RetrieveItem(Guid id, Type type);
  54. /// <summary>
  55. /// Gets chapters for an item
  56. /// </summary>
  57. /// <param name="id"></param>
  58. /// <returns></returns>
  59. IEnumerable<ChapterInfo> GetChapters(Guid id);
  60. /// <summary>
  61. /// Gets a single chapter for an item
  62. /// </summary>
  63. /// <param name="id"></param>
  64. /// <param name="index"></param>
  65. /// <returns></returns>
  66. ChapterInfo GetChapter(Guid id, int index);
  67. /// <summary>
  68. /// Saves the chapters.
  69. /// </summary>
  70. /// <param name="id">The id.</param>
  71. /// <param name="chapters">The chapters.</param>
  72. /// <param name="cancellationToken">The cancellation token.</param>
  73. /// <returns>Task.</returns>
  74. Task SaveChapters(Guid id, IEnumerable<ChapterInfo> chapters, CancellationToken cancellationToken);
  75. /// <summary>
  76. /// Gets the children.
  77. /// </summary>
  78. /// <param name="parentId">The parent id.</param>
  79. /// <returns>IEnumerable{ChildDefinition}.</returns>
  80. IEnumerable<ChildDefinition> GetChildren(Guid parentId);
  81. /// <summary>
  82. /// Saves the children.
  83. /// </summary>
  84. /// <param name="parentId">The parent id.</param>
  85. /// <param name="children">The children.</param>
  86. /// <param name="cancellationToken">The cancellation token.</param>
  87. /// <returns>Task.</returns>
  88. Task SaveChildren(Guid parentId, IEnumerable<ChildDefinition> children, CancellationToken cancellationToken);
  89. }
  90. /// <summary>
  91. /// Class ItemRepositoryExtensions
  92. /// </summary>
  93. public static class ItemRepositoryExtensions
  94. {
  95. /// <summary>
  96. /// Retrieves the item.
  97. /// </summary>
  98. /// <typeparam name="T"></typeparam>
  99. /// <param name="repository">The repository.</param>
  100. /// <param name="id">The id.</param>
  101. /// <returns>``0.</returns>
  102. public static T RetrieveItem<T>(this IItemRepository repository, Guid id)
  103. where T : BaseItem, new()
  104. {
  105. return repository.RetrieveItem(id, typeof(T)) as T;
  106. }
  107. /// <summary>
  108. /// Retrieves the item.
  109. /// </summary>
  110. /// <typeparam name="T"></typeparam>
  111. /// <param name="repository">The repository.</param>
  112. /// <param name="idList">The id list.</param>
  113. /// <returns>IEnumerable{``0}.</returns>
  114. public static IEnumerable<T> RetrieveItems<T>(this IItemRepository repository, IEnumerable<Guid> idList)
  115. where T : BaseItem, new()
  116. {
  117. return idList.Select(repository.RetrieveItem<T>).Where(i => i != null);
  118. }
  119. }
  120. }