diff options
author | Rémy Coutable <remy@rymai.me> | 2016-09-09 15:16:26 +0200 |
---|---|---|
committer | Rémy Coutable <remy@rymai.me> | 2016-09-12 10:34:03 +0200 |
commit | 3a58dd2d8ffd0baf7a6a8f342d703cbdc34400bb (patch) | |
tree | 895b4aec21e9543f29021da987c6285463722062 /lib/api | |
parent | 874ad681cd98616e560fb633e7c3867361faf46c (diff) | |
download | gitlab-ce-3a58dd2d8ffd0baf7a6a8f342d703cbdc34400bb.tar.gz |
Use Search::GlobalService.new in the `GET /projects/search/:query` endpointrc-api-use-search-globalservice-in-projects-search-api
Also streamline the sorting part while we're at it.
That being done, there's currently a duplication between
`GET /projects/search/:query` and `GET /projects?search=:search`
so we might want to keep only the latter for 9.0...
Signed-off-by: Rémy Coutable <remy@rymai.me>
Diffstat (limited to 'lib/api')
-rw-r--r-- | lib/api/projects.rb | 15 |
1 files changed, 3 insertions, 12 deletions
diff --git a/lib/api/projects.rb b/lib/api/projects.rb index b76be145a14..644d836ed0b 100644 --- a/lib/api/projects.rb +++ b/lib/api/projects.rb @@ -428,18 +428,9 @@ module API # Example Request: # GET /projects/search/:query get "/search/:query" do - ids = current_user.authorized_projects.map(&:id) - visibility_levels = [ Gitlab::VisibilityLevel::INTERNAL, Gitlab::VisibilityLevel::PUBLIC ] - projects = Project.where("(id in (?) OR visibility_level in (?)) AND (LOWER(name) LIKE LOWER((?)))", ids, visibility_levels, "%#{params[:query]}%") - sort = params[:sort] == 'desc' ? 'desc' : 'asc' - - projects = case params["order_by"] - when 'id' then projects.order("id #{sort}") - when 'name' then projects.order("name #{sort}") - when 'created_at' then projects.order("created_at #{sort}") - when 'last_activity_at' then projects.order("last_activity_at #{sort}") - else projects - end + search_service = Search::GlobalService.new(current_user, search: params[:query]).execute + projects = search_service.objects('projects', params[:page]) + projects = projects.reorder(project_order_by => project_sort) present paginate(projects), with: Entities::Project end |