aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2013-04-17 01:36:56 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2013-04-17 01:36:56 -0400
commite8f345514c5908282545d9862d2392faaf97d523 (patch)
treeeeb792a4a91b6b56d5966fd269fbf8c48ee34a04
parent381456f81652a39f609ac86a906ea1de4aeda6ad (diff)
added item by name counts
-rw-r--r--MediaBrowser.Api/UserLibrary/PersonsService.cs61
-rw-r--r--MediaBrowser.Model/Dto/ItemByNameCounts.cs35
-rw-r--r--MediaBrowser.Model/MediaBrowser.Model.csproj1
3 files changed, 95 insertions, 2 deletions
diff --git a/MediaBrowser.Api/UserLibrary/PersonsService.cs b/MediaBrowser.Api/UserLibrary/PersonsService.cs
index fe5cf39f6..52e241318 100644
--- a/MediaBrowser.Api/UserLibrary/PersonsService.cs
+++ b/MediaBrowser.Api/UserLibrary/PersonsService.cs
@@ -1,6 +1,10 @@
using MediaBrowser.Controller.Entities;
+using MediaBrowser.Controller.Entities.Movies;
+using MediaBrowser.Controller.Entities.TV;
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Persistence;
+using MediaBrowser.Model.Dto;
+using MediaBrowser.Model.Entities;
using ServiceStack.ServiceHost;
using System;
using System.Collections.Generic;
@@ -23,12 +27,38 @@ namespace MediaBrowser.Api.UserLibrary
/// <value>The person types.</value>
public string PersonTypes { get; set; }
}
-
+
+ /// <summary>
+ /// Class GetPersonItemCounts
+ /// </summary>
+ [Route("/Users/{UserId}/Persons/{Name}/Counts", "GET")]
+ [Api(Description = "Gets item counts of library items that a person appears in")]
+ public class GetPersonItemCounts : IReturn<ItemByNameCounts>
+ {
+ /// <summary>
+ /// Gets or sets the user id.
+ /// </summary>
+ /// <value>The user id.</value>
+ public Guid UserId { get; set; }
+
+ /// <summary>
+ /// Gets or sets the name.
+ /// </summary>
+ /// <value>The name.</value>
+ public string Name { get; set; }
+ }
+
/// <summary>
/// Class PersonsService
/// </summary>
public class PersonsService : BaseItemsByNameService<Person>
{
+ /// <summary>
+ /// Initializes a new instance of the <see cref="PersonsService"/> class.
+ /// </summary>
+ /// <param name="userManager">The user manager.</param>
+ /// <param name="libraryManager">The library manager.</param>
+ /// <param name="userDataRepository">The user data repository.</param>
public PersonsService(IUserManager userManager, ILibraryManager libraryManager, IUserDataRepository userDataRepository)
: base(userManager, libraryManager, userDataRepository)
{
@@ -47,6 +77,33 @@ namespace MediaBrowser.Api.UserLibrary
}
/// <summary>
+ /// Gets the specified request.
+ /// </summary>
+ /// <param name="request">The request.</param>
+ /// <returns>System.Object.</returns>
+ public object Get(GetPersonItemCounts request)
+ {
+ var user = UserManager.GetUserById(request.UserId);
+
+ var items = user.RootFolder.GetRecursiveChildren(user).Where(i => i.People != null && i.People.Any(p => string.Equals(p.Name, request.Name, StringComparison.OrdinalIgnoreCase))).ToList();
+
+ var counts = new ItemByNameCounts
+ {
+ TotalCount = items.Count,
+
+ MovieCount = items.OfType<Movie>().Count(),
+
+ SeriesCount = items.OfType<Series>().Count(),
+
+ GameCount = items.OfType<BaseGame>().Count(),
+
+ EpisodeGuestStarCount = items.OfType<Episode>().Count(i => i.People.Any(p => string.Equals(p.Name, request.Name, StringComparison.OrdinalIgnoreCase) && string.Equals(p.Type, PersonType.GuestStar)))
+ };
+
+ return ToOptimizedResult(counts);
+ }
+
+ /// <summary>
/// Gets all items.
/// </summary>
/// <param name="request">The request.</param>
@@ -55,7 +112,7 @@ namespace MediaBrowser.Api.UserLibrary
/// <returns>IEnumerable{Tuple{System.StringFunc{System.Int32}}}.</returns>
protected override IEnumerable<IbnStub<Person>> GetAllItems(GetItemsByName request, IEnumerable<BaseItem> items, User user)
{
- var inputPersonTypes = ((GetPersons) request).PersonTypes;
+ var inputPersonTypes = ((GetPersons)request).PersonTypes;
var personTypes = string.IsNullOrEmpty(inputPersonTypes) ? new string[] { } : inputPersonTypes.Split(',');
var itemsList = items.Where(i => i.People != null).ToList();
diff --git a/MediaBrowser.Model/Dto/ItemByNameCounts.cs b/MediaBrowser.Model/Dto/ItemByNameCounts.cs
new file mode 100644
index 000000000..5175fa158
--- /dev/null
+++ b/MediaBrowser.Model/Dto/ItemByNameCounts.cs
@@ -0,0 +1,35 @@
+
+namespace MediaBrowser.Model.Dto
+{
+ /// <summary>
+ /// Class ItemByNameCounts
+ /// </summary>
+ public class ItemByNameCounts
+ {
+ /// <summary>
+ /// Gets or sets the total count.
+ /// </summary>
+ /// <value>The total count.</value>
+ public int TotalCount { get; set; }
+ /// <summary>
+ /// Gets or sets the movie count.
+ /// </summary>
+ /// <value>The movie count.</value>
+ public int MovieCount { get; set; }
+ /// <summary>
+ /// Gets or sets the series count.
+ /// </summary>
+ /// <value>The series count.</value>
+ public int SeriesCount { get; set; }
+ /// <summary>
+ /// Gets or sets the episode guest star count.
+ /// </summary>
+ /// <value>The episode guest star count.</value>
+ public int EpisodeGuestStarCount { get; set; }
+ /// <summary>
+ /// Gets or sets the game count.
+ /// </summary>
+ /// <value>The game count.</value>
+ public int GameCount { get; set; }
+ }
+}
diff --git a/MediaBrowser.Model/MediaBrowser.Model.csproj b/MediaBrowser.Model/MediaBrowser.Model.csproj
index 779fadf11..9df35463c 100644
--- a/MediaBrowser.Model/MediaBrowser.Model.csproj
+++ b/MediaBrowser.Model/MediaBrowser.Model.csproj
@@ -45,6 +45,7 @@
<Compile Include="Dto\BaseItemPerson.cs" />
<Compile Include="Dto\ChapterInfoDto.cs" />
<Compile Include="Dto\IItemDto.cs" />
+ <Compile Include="Dto\ItemByNameCounts.cs" />
<Compile Include="Entities\IByReferenceItem.cs" />
<Compile Include="Net\WebSocketMessage.cs" />
<Compile Include="Net\WebSocketMessageType.cs" />