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[] { };
+ }
+ }
+}