diff --git a/MediaBrowser.Api/LibraryService.cs b/MediaBrowser.Api/LibraryService.cs new file mode 100644 index 0000000000..a6e7598aaa --- /dev/null +++ b/MediaBrowser.Api/LibraryService.cs @@ -0,0 +1,100 @@ +using MediaBrowser.Controller.Persistence; +using MediaBrowser.Model.Querying; +using ServiceStack.ServiceHost; +using System; +using System.Linq; +using System.Threading.Tasks; + +namespace MediaBrowser.Api +{ + /// + /// Class GetCriticReviews + /// + [Route("/Items/{Id}/CriticReviews", "GET")] + [Api(Description = "Gets critic reviews for an item")] + public class GetCriticReviews : IReturn + { + /// + /// Gets or sets the id. + /// + /// The id. + [ApiMember(Name = "Id", Description = "Item Id", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] + public string Id { get; set; } + + /// + /// Skips over a given number of items within the results. Use for paging. + /// + /// The start index. + [ApiMember(Name = "StartIndex", Description = "Optional. The record index to start at. All items with a lower index will be dropped from the results.", IsRequired = false, DataType = "int", ParameterType = "query", Verb = "GET")] + public int? StartIndex { get; set; } + + /// + /// The maximum number of items to return + /// + /// The limit. + [ApiMember(Name = "Limit", Description = "Optional. The maximum number of records to return", IsRequired = false, DataType = "int", ParameterType = "query", Verb = "GET")] + public int? Limit { get; set; } + } + + /// + /// Class LibraryService + /// + public class LibraryService : BaseApiService + { + /// + /// The _item repo + /// + private readonly IItemRepository _itemRepo; + + /// + /// Initializes a new instance of the class. + /// + /// The item repo. + public LibraryService(IItemRepository itemRepo) + { + _itemRepo = itemRepo; + } + + /// + /// Gets the specified request. + /// + /// The request. + /// System.Object. + public object Get(GetCriticReviews request) + { + var result = GetCriticReviewsAsync(request).Result; + + return ToOptimizedResult(result); + } + + /// + /// Gets the critic reviews async. + /// + /// The request. + /// Task{ItemReviewsResult}. + private async Task GetCriticReviewsAsync(GetCriticReviews request) + { + var reviews = await _itemRepo.GetCriticReviews(new Guid(request.Id)).ConfigureAwait(false); + + var reviewsArray = reviews.ToArray(); + + var result = new ItemReviewsResult + { + TotalRecordCount = reviewsArray.Length + }; + + if (request.StartIndex.HasValue) + { + reviewsArray = reviewsArray.Skip(request.StartIndex.Value).ToArray(); + } + if (request.Limit.HasValue) + { + reviewsArray = reviewsArray.Take(request.Limit.Value).ToArray(); + } + + result.ItemReviews = reviewsArray; + + return result; + } + } +} diff --git a/MediaBrowser.Api/MediaBrowser.Api.csproj b/MediaBrowser.Api/MediaBrowser.Api.csproj index 7ed030a873..e994f253f0 100644 --- a/MediaBrowser.Api/MediaBrowser.Api.csproj +++ b/MediaBrowser.Api/MediaBrowser.Api.csproj @@ -68,6 +68,7 @@ + diff --git a/MediaBrowser.Model/MediaBrowser.Model.csproj b/MediaBrowser.Model/MediaBrowser.Model.csproj index 979e0d55e3..dc7f09f2d6 100644 --- a/MediaBrowser.Model/MediaBrowser.Model.csproj +++ b/MediaBrowser.Model/MediaBrowser.Model.csproj @@ -54,6 +54,7 @@ + diff --git a/MediaBrowser.Model/Querying/ItemReviewsResult.cs b/MediaBrowser.Model/Querying/ItemReviewsResult.cs new file mode 100644 index 0000000000..6a29827a91 --- /dev/null +++ b/MediaBrowser.Model/Querying/ItemReviewsResult.cs @@ -0,0 +1,30 @@ +using MediaBrowser.Model.Entities; + +namespace MediaBrowser.Model.Querying +{ + /// + /// Class ItemReviewsResult + /// + public class ItemReviewsResult + { + /// + /// Gets or sets the item reviews. + /// + /// The item reviews. + public ItemReview[] ItemReviews { get; set; } + + /// + /// The total number of records available + /// + /// The total record count. + public int TotalRecordCount { get; set; } + + /// + /// Initializes a new instance of the class. + /// + public ItemReviewsResult() + { + ItemReviews = new ItemReview[] { }; + } + } +}