X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/41d7b9bb8a45b0d80fb2bf15af4c9e7b3d77a467..09a2e88c51e5432e607f2a38466e55b4ba15e887:/apps/workbench/app/controllers/application_controller.rb diff --git a/apps/workbench/app/controllers/application_controller.rb b/apps/workbench/app/controllers/application_controller.rb index d8dc852ca2..ee3ac4d681 100644 --- a/apps/workbench/app/controllers/application_controller.rb +++ b/apps/workbench/app/controllers/application_controller.rb @@ -13,6 +13,7 @@ class ApplicationController < ActionController::Base # Methods that don't require login should # skip_around_filter :require_thread_api_token around_filter :require_thread_api_token, except: ERROR_ACTIONS + before_filter :ensure_arvados_api_exists, only: [:index, :show] before_filter :set_cache_buster before_filter :accept_uuid_as_id_param, except: ERROR_ACTIONS before_filter :check_user_agreements, except: ERROR_ACTIONS @@ -213,6 +214,13 @@ class ApplicationController < ActionController::Base end end + def ensure_arvados_api_exists + if model_class.is_a?(Class) && model_class < ArvadosBase && !model_class.api_exists?(params['action'].to_sym) + @errors = ["#{params['action']} method is not supported for #{params['controller']}"] + return render_error(status: 404) + end + end + def index find_objects_for_index if !@objects render_index @@ -526,16 +534,17 @@ class ApplicationController < ActionController::Base begin if not model_class @object = nil - elsif not params[:uuid].is_a?(String) - @object = object_for_dataclass(model_class, params[:uuid]) - elsif params[:uuid].empty? + elsif params[:uuid].nil? or params[:uuid].empty? @object = nil + elsif not params[:uuid].is_a?(String) + @object = model_class.where(uuid: params[:uuid]).first elsif (model_class != Link and resource_class_for_uuid(params[:uuid]) == Link) @name_link = Link.find(params[:uuid]) @object = model_class.find(@name_link.head_uuid) else - @object = object_for_dataclass(model_class, params[:uuid]) + @object = model_class.find(params[:uuid]) + load_preloaded_objects [@object] end rescue ArvadosApiClient::NotFoundException, ArvadosApiClient::NotLoggedInException, RuntimeError => error if error.is_a?(RuntimeError) and (error.message !~ /^argument to find\(/) @@ -759,7 +768,11 @@ class ApplicationController < ActionController::Base } @@notification_tests.push lambda { |controller, current_user| - PipelineInstance.limit(1).where(created_by: current_user.uuid).each do + if PipelineInstance.api_exists?(:index) + PipelineInstance.limit(1).where(created_by: current_user.uuid).each do + return nil + end + else return nil end return lambda { |view| @@ -855,12 +868,14 @@ class ApplicationController < ActionController::Base def recent_processes lim lim = 12 if lim.nil? - cols = %w(uuid owner_uuid created_at modified_at pipeline_template_uuid name state started_at finished_at) - pipelines = PipelineInstance.select(cols).limit(lim).order(["created_at desc"]) + procs = {} + if PipelineInstance.api_exists?(:index) + cols = %w(uuid owner_uuid created_at modified_at pipeline_template_uuid name state started_at finished_at) + pipelines = PipelineInstance.select(cols).limit(lim).order(["created_at desc"]) + pipelines.results.each { |pi| procs[pi] = pi.created_at } + end crs = ContainerRequest.limit(lim).order(["created_at desc"]).filter([["requesting_container_uuid", "=", nil]]) - procs = {} - pipelines.results.each { |pi| procs[pi] = pi.created_at } crs.results.each { |c| procs[c] = c.created_at } Hash[procs.sort_by {|key, value| value}].keys.reverse.first(lim) @@ -892,7 +907,7 @@ class ApplicationController < ActionController::Base # from the top three levels. # That is: get toplevel projects under home, get subprojects of # these projects, and so on until we hit the limit. - def my_wanted_projects user, page_size=100 + def my_wanted_projects(user, page_size=100) return @my_wanted_projects if @my_wanted_projects from_top = [] @@ -907,7 +922,7 @@ class ApplicationController < ActionController::Base break if current_level.results.size == 0 @too_many_projects = true if current_level.items_available > current_level.results.size from_top.concat current_level.results - uuids = current_level.results.collect { |x| x.uuid } + uuids = current_level.results.collect(&:uuid) depth += 1 if depth >= 3 @reached_level_limit = true @@ -918,12 +933,12 @@ class ApplicationController < ActionController::Base end helper_method :my_wanted_projects_tree - def my_wanted_projects_tree user, page_size=100 - build_my_wanted_projects_tree user, page_size + def my_wanted_projects_tree(user, page_size=100) + build_my_wanted_projects_tree(user, page_size) [@my_wanted_projects_tree, @too_many_projects, @reached_level_limit] end - def build_my_wanted_projects_tree user, page_size=100 + def build_my_wanted_projects_tree(user, page_size=100) return @my_wanted_projects_tree if @my_wanted_projects_tree parent_of = {user.uuid => 'me'}