diff --git a/MediaBrowser.Api/SearchService.cs b/MediaBrowser.Api/SearchService.cs
index f83c0a771e..8626709a3b 100644
--- a/MediaBrowser.Api/SearchService.cs
+++ b/MediaBrowser.Api/SearchService.cs
@@ -7,9 +7,6 @@ using MediaBrowser.Controller.Library;
using MediaBrowser.Model.Entities;
using MediaBrowser.Model.Search;
using ServiceStack;
-using System;
-using System.Collections;
-using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
@@ -41,7 +38,7 @@ namespace MediaBrowser.Api
///
/// The user id.
[ApiMember(Name = "UserId", Description = "Optional. Supply a user id to search within a user's library or omit to search all.", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")]
- public Guid? UserId { get; set; }
+ public string UserId { get; set; }
///
/// Search characters used to find items
@@ -49,6 +46,31 @@ namespace MediaBrowser.Api
/// The index by.
[ApiMember(Name = "SearchTerm", Description = "The search term to filter on", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "GET")]
public string SearchTerm { get; set; }
+
+
+ [ApiMember(Name = "IncludePeople", IsRequired = false, DataType = "bool", ParameterType = "query", Verb = "GET")]
+ public bool IncludePeople { get; set; }
+
+ [ApiMember(Name = "IncludeMedia", IsRequired = false, DataType = "bool", ParameterType = "query", Verb = "GET")]
+ public bool IncludeMedia { get; set; }
+
+ [ApiMember(Name = "IncludeGenres", IsRequired = false, DataType = "bool", ParameterType = "query", Verb = "GET")]
+ public bool IncludeGenres { get; set; }
+
+ [ApiMember(Name = "IncludeStudios", IsRequired = false, DataType = "bool", ParameterType = "query", Verb = "GET")]
+ public bool IncludeStudios { get; set; }
+
+ [ApiMember(Name = "IncludeArtists", IsRequired = false, DataType = "bool", ParameterType = "query", Verb = "GET")]
+ public bool IncludeArtists { get; set; }
+
+ public GetSearchHints()
+ {
+ IncludeArtists = true;
+ IncludeGenres = true;
+ IncludeMedia = true;
+ IncludePeople = true;
+ IncludeStudios = true;
+ }
}
///
@@ -56,10 +78,6 @@ namespace MediaBrowser.Api
///
public class SearchService : BaseApiService
{
- ///
- /// The _user manager
- ///
- private readonly IUserManager _userManager;
///
/// The _search engine
///
@@ -71,12 +89,12 @@ namespace MediaBrowser.Api
///
/// Initializes a new instance of the class.
///
- /// The user manager.
/// The search engine.
/// The library manager.
- public SearchService(IUserManager userManager, ISearchEngine searchEngine, ILibraryManager libraryManager, IDtoService dtoService, IImageProcessor imageProcessor)
+ /// The dto service.
+ /// The image processor.
+ public SearchService(ISearchEngine searchEngine, ILibraryManager libraryManager, IDtoService dtoService, IImageProcessor imageProcessor)
{
- _userManager = userManager;
_searchEngine = searchEngine;
_libraryManager = libraryManager;
_dtoService = dtoService;
@@ -102,29 +120,25 @@ namespace MediaBrowser.Api
/// Task{IEnumerable{SearchHintResult}}.
private async Task GetSearchHintsAsync(GetSearchHints request)
{
- var inputItems = GetAllLibraryItems(request.UserId, _userManager, _libraryManager);
-
- var results = await _searchEngine.GetSearchHints(inputItems, request.SearchTerm).ConfigureAwait(false);
-
- var searchResultArray = results.ToList();
-
- IEnumerable returnResults = searchResultArray;
-
- if (request.StartIndex.HasValue)
+ var result = await _searchEngine.GetSearchHints(new SearchQuery
{
- returnResults = returnResults.Skip(request.StartIndex.Value);
- }
-
- if (request.Limit.HasValue)
- {
- returnResults = returnResults.Take(request.Limit.Value);
- }
+ Limit = request.Limit,
+ SearchTerm = request.SearchTerm,
+ IncludeArtists = request.IncludeArtists,
+ IncludeGenres = request.IncludeGenres,
+ IncludeMedia = request.IncludeMedia,
+ IncludePeople = request.IncludePeople,
+ IncludeStudios = request.IncludeStudios,
+ StartIndex = request.StartIndex,
+ UserId = request.UserId
+
+ }).ConfigureAwait(false);
return new SearchHintResult
{
- TotalRecordCount = searchResultArray.Count,
+ TotalRecordCount = result.TotalRecordCount,
- SearchHints = returnResults.Select(GetSearchHintResult).ToArray()
+ SearchHints = result.Items.Select(GetSearchHintResult).ToArray()
};
}
@@ -189,7 +203,7 @@ namespace MediaBrowser.Api
var songs = album.GetRecursiveChildren().OfType