|
|
@ -12,6 +12,7 @@ using MediaBrowser.Controller.Library;
|
|
|
|
namespace MediaBrowser.Api
|
|
|
|
namespace MediaBrowser.Api
|
|
|
|
{
|
|
|
|
{
|
|
|
|
[Route("/Users/{UserId}/Suggestions", "GET", Summary = "Gets items based on a query.")]
|
|
|
|
[Route("/Users/{UserId}/Suggestions", "GET", Summary = "Gets items based on a query.")]
|
|
|
|
|
|
|
|
[Route("/Users/{UserId}/Suggestions", "POST", Summary = "Gets items based on a query.")]
|
|
|
|
public class GetSuggestedItems : IReturn<QueryResult<BaseItem>>
|
|
|
|
public class GetSuggestedItems : IReturn<QueryResult<BaseItem>>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public string MediaType { get; set; }
|
|
|
|
public string MediaType { get; set; }
|
|
|
@ -20,6 +21,7 @@ namespace MediaBrowser.Api
|
|
|
|
public bool EnableTotalRecordCount { get; set; }
|
|
|
|
public bool EnableTotalRecordCount { get; set; }
|
|
|
|
public int? StartIndex { get; set; }
|
|
|
|
public int? StartIndex { get; set; }
|
|
|
|
public int? Limit { get; set; }
|
|
|
|
public int? Limit { get; set; }
|
|
|
|
|
|
|
|
public string Name { get; set; }
|
|
|
|
|
|
|
|
|
|
|
|
public string[] GetMediaTypes()
|
|
|
|
public string[] GetMediaTypes()
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -54,6 +56,13 @@ namespace MediaBrowser.Api
|
|
|
|
return ToOptimizedResult(result);
|
|
|
|
return ToOptimizedResult(result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public async Task<object> Post(GetSuggestedItems request)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var result = await GetResultItems(request).ConfigureAwait(false);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToOptimizedResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private async Task<QueryResult<BaseItemDto>> GetResultItems(GetSuggestedItems request)
|
|
|
|
private async Task<QueryResult<BaseItemDto>> GetResultItems(GetSuggestedItems request)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var user = !string.IsNullOrWhiteSpace(request.UserId) ? _userManager.GetUserById(request.UserId) : null;
|
|
|
|
var user = !string.IsNullOrWhiteSpace(request.UserId) ? _userManager.GetUserById(request.UserId) : null;
|
|
|
@ -77,28 +86,42 @@ namespace MediaBrowser.Api
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<BaseItem> GetItems(GetSuggestedItems request, User user, DtoOptions dtoOptions)
|
|
|
|
private QueryResult<BaseItem> GetItems(GetSuggestedItems request, User user, DtoOptions dtoOptions)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var query = new InternalItemsQuery(user)
|
|
|
|
BaseItem similarToItem = null;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrWhiteSpace(request.Name))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// get item by name, then get similar items from that
|
|
|
|
|
|
|
|
similarToItem = _libraryManager.GetItemList(new InternalItemsQuery(user)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
SortBy = new string[] {ItemSortBy.Random},
|
|
|
|
SortBy = new string[] {ItemSortBy.Random},
|
|
|
|
MediaTypes = request.GetMediaTypes(),
|
|
|
|
MediaTypes = request.GetMediaTypes(),
|
|
|
|
IncludeItemTypes = request.GetIncludeItemTypes(),
|
|
|
|
IncludeItemTypes = request.GetIncludeItemTypes(),
|
|
|
|
IsVirtualItem = false,
|
|
|
|
IsVirtualItem = false,
|
|
|
|
StartIndex = request.StartIndex,
|
|
|
|
Name = request.Name,
|
|
|
|
Limit = request.Limit,
|
|
|
|
Recursive = true,
|
|
|
|
DtoOptions = dtoOptions
|
|
|
|
Limit = 1
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (request.EnableTotalRecordCount)
|
|
|
|
}).FirstOrDefault();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (similarToItem == null)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return _libraryManager.GetItemsResult(query);
|
|
|
|
return new QueryResult<BaseItem>();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var items = _libraryManager.GetItemList(query).ToArray();
|
|
|
|
return _libraryManager.GetItemsResult(new InternalItemsQuery(user)
|
|
|
|
|
|
|
|
|
|
|
|
return new QueryResult<BaseItem>
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Items = items
|
|
|
|
SortBy = new string[] { ItemSortBy.Random },
|
|
|
|
};
|
|
|
|
MediaTypes = request.GetMediaTypes(),
|
|
|
|
|
|
|
|
IncludeItemTypes = request.GetIncludeItemTypes(),
|
|
|
|
|
|
|
|
IsVirtualItem = false,
|
|
|
|
|
|
|
|
StartIndex = request.StartIndex,
|
|
|
|
|
|
|
|
Limit = request.Limit,
|
|
|
|
|
|
|
|
DtoOptions = dtoOptions,
|
|
|
|
|
|
|
|
EnableTotalRecordCount = request.EnableTotalRecordCount,
|
|
|
|
|
|
|
|
Recursive = true,
|
|
|
|
|
|
|
|
SimilarTo = similarToItem
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|