X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/4898ba78d5cc0783a319f0742bb8bc0b4c15d7be..c58a2c83fa6338358962b8161c576e5391d7bf2b:/apps/workbench/app/controllers/search_controller.rb diff --git a/apps/workbench/app/controllers/search_controller.rb b/apps/workbench/app/controllers/search_controller.rb index 510ba6f35f..9e2ff1b00b 100644 --- a/apps/workbench/app/controllers/search_controller.rb +++ b/apps/workbench/app/controllers/search_controller.rb @@ -1,6 +1,28 @@ class SearchController < ApplicationController def find_objects_for_index - @objects = Group.contents(limit: @limit, offset: @offset, filters: @filters) + search_what = Group + if params[:project_uuid] + # Special case for "search all things in project": + @filters = @filters.select do |attr, operator, operand| + not (attr == 'owner_uuid' and operator == '=') + end + # Special case for project_uuid is a user uuid: + if ArvadosBase::resource_class_for_uuid(params[:project_uuid]) == User + search_what = User.find params[:project_uuid] + else + search_what = Group.find params[:project_uuid] + end + end + @objects = search_what.contents(limit: @limit, + offset: @offset, + filters: @filters, + include_linked: true) super end + + def next_page_href with_params={} + super with_params.merge(last_object_class: @objects.last.class.to_s, + project_uuid: params[:project_uuid], + filters: @filters.to_json) + end end