jellyfin-server/MediaBrowser.Api/UserLibrary/YearsService.cs

118 lines
3.9 KiB
C#
Raw Normal View History

2013-04-22 04:38:03 +00:00
using MediaBrowser.Controller.Dto;
using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Library;
2014-07-02 18:34:08 +00:00
using MediaBrowser.Controller.Net;
using MediaBrowser.Controller.Persistence;
2013-04-22 04:38:03 +00:00
using MediaBrowser.Model.Dto;
using MediaBrowser.Model.Querying;
2013-12-07 15:52:38 +00:00
using ServiceStack;
2013-04-22 04:38:03 +00:00
using System;
2013-02-21 01:33:05 +00:00
using System.Collections.Generic;
using System.Linq;
namespace MediaBrowser.Api.UserLibrary
{
/// <summary>
/// Class GetYears
/// </summary>
[Route("/Years", "GET", Summary = "Gets all years from a given item, folder, or the entire library")]
2013-02-21 01:33:05 +00:00
public class GetYears : GetItemsByName
{
}
2013-04-22 04:38:03 +00:00
/// <summary>
/// Class GetYear
/// </summary>
[Route("/Years/{Year}", "GET", Summary = "Gets a year")]
2013-04-22 04:38:03 +00:00
public class GetYear : IReturn<BaseItemDto>
{
/// <summary>
/// Gets or sets the year.
/// </summary>
/// <value>The year.</value>
[ApiMember(Name = "Year", Description = "The year", IsRequired = true, DataType = "int", ParameterType = "path", Verb = "GET")]
public int Year { get; set; }
/// <summary>
/// Gets or sets the user id.
/// </summary>
/// <value>The user id.</value>
[ApiMember(Name = "UserId", Description = "Optional. Filter by user id, and attach user data", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")]
2015-05-29 23:51:33 +00:00
public string UserId { get; set; }
2013-04-22 04:38:03 +00:00
}
2013-02-21 01:33:05 +00:00
/// <summary>
/// Class YearsService
/// </summary>
2014-07-02 18:34:08 +00:00
[Authenticated]
2013-02-21 01:33:05 +00:00
public class YearsService : BaseItemsByNameService<Year>
{
2013-10-02 16:08:58 +00:00
public YearsService(IUserManager userManager, ILibraryManager libraryManager, IUserDataManager userDataRepository, IItemRepository itemRepo, IDtoService dtoService)
2013-09-04 17:02:19 +00:00
: base(userManager, libraryManager, userDataRepository, itemRepo, dtoService)
{
}
2013-04-22 04:38:03 +00:00
/// <summary>
/// Gets the specified request.
/// </summary>
/// <param name="request">The request.</param>
/// <returns>System.Object.</returns>
public object Get(GetYear request)
{
2013-09-17 02:44:06 +00:00
var result = GetItem(request);
2013-04-22 04:38:03 +00:00
return ToOptimizedSerializedResultUsingCache(result);
2013-04-22 04:38:03 +00:00
}
/// <summary>
/// Gets the item.
/// </summary>
/// <param name="request">The request.</param>
/// <returns>Task{BaseItemDto}.</returns>
2013-09-17 02:44:06 +00:00
private BaseItemDto GetItem(GetYear request)
2013-04-22 04:38:03 +00:00
{
var item = LibraryManager.GetYear(request.Year);
2013-04-22 04:38:03 +00:00
2015-01-24 19:03:55 +00:00
var dtoOptions = GetDtoOptions(request);
2015-05-29 23:51:33 +00:00
if (!string.IsNullOrWhiteSpace(request.UserId))
2013-04-22 04:38:03 +00:00
{
2015-05-29 23:51:33 +00:00
var user = UserManager.GetUserById(request.UserId);
2013-04-22 04:38:03 +00:00
2014-12-27 05:08:39 +00:00
return DtoService.GetBaseItemDto(item, dtoOptions, user);
2013-04-22 04:38:03 +00:00
}
2014-12-27 05:08:39 +00:00
return DtoService.GetBaseItemDto(item, dtoOptions);
2013-04-22 04:38:03 +00:00
}
2013-02-21 01:33:05 +00:00
/// <summary>
/// Gets the specified request.
/// </summary>
/// <param name="request">The request.</param>
/// <returns>System.Object.</returns>
public object Get(GetYears request)
{
2013-09-27 12:24:28 +00:00
var result = GetResult(request);
2013-02-21 01:33:05 +00:00
return ToOptimizedSerializedResultUsingCache(result);
2013-02-21 01:33:05 +00:00
}
/// <summary>
/// Gets all items.
/// </summary>
/// <param name="request">The request.</param>
/// <param name="items">The items.</param>
/// <returns>IEnumerable{Tuple{System.StringFunc{System.Int32}}}.</returns>
2015-08-15 03:15:25 +00:00
protected override IEnumerable<BaseItem> GetAllItems(GetItemsByName request, IEnumerable<BaseItem> items)
2013-02-21 01:33:05 +00:00
{
var itemsList = items.Where(i => i.ProductionYear != null).ToList();
return itemsList
2014-01-16 17:56:50 +00:00
.Select(i => i.ProductionYear ?? 0)
.Where(i => i > 0)
2013-02-21 01:33:05 +00:00
.Distinct()
.Select(year => LibraryManager.GetYear(year));
2013-02-21 01:33:05 +00:00
}
}
}