IItemRepository.cs 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. using MediaBrowser.Controller.Entities;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6. using MediaBrowser.Model.Entities;
  7. namespace MediaBrowser.Controller.Persistence
  8. {
  9. /// <summary>
  10. /// Provides an interface to implement an Item repository
  11. /// </summary>
  12. public interface IItemRepository : IRepository
  13. {
  14. /// <summary>
  15. /// Saves an item
  16. /// </summary>
  17. /// <param name="item">The item.</param>
  18. /// <param name="cancellationToken">The cancellation token.</param>
  19. /// <returns>Task.</returns>
  20. Task SaveItem(BaseItem item, CancellationToken cancellationToken);
  21. /// <summary>
  22. /// Gets an item
  23. /// </summary>
  24. /// <param name="id">The id.</param>
  25. /// <returns>BaseItem.</returns>
  26. BaseItem GetItem(Guid id);
  27. /// <summary>
  28. /// Gets children of a given Folder
  29. /// </summary>
  30. /// <param name="parent">The parent.</param>
  31. /// <returns>IEnumerable{BaseItem}.</returns>
  32. IEnumerable<BaseItem> RetrieveChildren(Folder parent);
  33. /// <summary>
  34. /// Retrieves the items.
  35. /// </summary>
  36. /// <param name="ids">The ids.</param>
  37. /// <returns>IEnumerable{BaseItem}.</returns>
  38. IEnumerable<BaseItem> GetItems(IEnumerable<Guid> ids);
  39. /// <summary>
  40. /// Saves children of a given Folder
  41. /// </summary>
  42. /// <param name="parentId">The parent id.</param>
  43. /// <param name="children">The children.</param>
  44. /// <param name="cancellationToken">The cancellation token.</param>
  45. /// <returns>Task.</returns>
  46. Task SaveChildren(Guid parentId, IEnumerable<BaseItem> children, CancellationToken cancellationToken);
  47. /// <summary>
  48. /// Gets the critic reviews.
  49. /// </summary>
  50. /// <param name="itemId">The item id.</param>
  51. /// <returns>Task{IEnumerable{ItemReview}}.</returns>
  52. Task<IEnumerable<ItemReview>> GetCriticReviews(Guid itemId);
  53. /// <summary>
  54. /// Saves the critic reviews.
  55. /// </summary>
  56. /// <param name="itemId">The item id.</param>
  57. /// <param name="criticReviews">The critic reviews.</param>
  58. /// <returns>Task.</returns>
  59. Task SaveCriticReviews(Guid itemId, IEnumerable<ItemReview> criticReviews);
  60. }
  61. }