X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/fca805a18c671ccbb03cef640c15172d1f02ffe3..5338c3fe0abbc6599aa290085be13eecfb0044e9:/apps/workbench/app/controllers/container_requests_controller.rb diff --git a/apps/workbench/app/controllers/container_requests_controller.rb b/apps/workbench/app/controllers/container_requests_controller.rb index fd29cd3f70..8ce068198e 100644 --- a/apps/workbench/app/controllers/container_requests_controller.rb +++ b/apps/workbench/app/controllers/container_requests_controller.rb @@ -1,6 +1,10 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + class ContainerRequestsController < ApplicationController - skip_around_filter :require_thread_api_token, if: proc { |ctrl| - Rails.configuration.anonymous_user_token and + skip_around_action :require_thread_api_token, if: proc { |ctrl| + !Rails.configuration.Users.AnonymousUserToken.empty? and 'show' == ctrl.action_name } @@ -8,18 +12,50 @@ class ContainerRequestsController < ApplicationController return if params['tab_pane'] != "Provenance" nodes = {} - nodes[cr[:uuid]] = cr + child_crs = [] + col_uuids = [] + col_pdhs = [] + col_uuids << cr[:output_uuid] if cr[:output_uuid] + col_pdhs += ProvenanceHelper::cr_input_pdhs(cr) + + # Search for child CRs if cr[:container_uuid] - ContainerRequest.where(requesting_container_uuid: cr[:container_uuid]).each do |child| + child_crs = ContainerRequest.where(requesting_container_uuid: cr[:container_uuid]).with_count("none") + + child_crs.each do |child| nodes[child[:uuid]] = child + col_uuids << child[:output_uuid] if child[:output_uuid] + col_pdhs += ProvenanceHelper::cr_input_pdhs(child) end end - @svg = ProvenanceHelper::create_provenance_graph nodes, - "provenance_svg", - { - :request => request, - :direction => :top_down, - } + + if nodes.length == 0 + nodes[cr[:uuid]] = cr + end + + pdh_to_col = {} # Indexed by PDH + output_pdhs = [] + + # Batch requests to get all related collections + # First fetch output collections by UUID. + Collection.filter([['uuid', 'in', col_uuids.uniq]]).with_count("none").each do |c| + output_pdhs << c[:portable_data_hash] + pdh_to_col[c[:portable_data_hash]] = c + nodes[c[:uuid]] = c + end + # Next, get input collections by PDH. + Collection.filter( + [['portable_data_hash', 'in', col_pdhs - output_pdhs]]).with_count("none").each do |c| + nodes[c[:portable_data_hash]] = c + end + + @svg = ProvenanceHelper::create_provenance_graph( + nodes, "provenance_svg", + { + :request => request, + :pdh_to_uuid => pdh_to_col, + } + ) end def show_pane_list @@ -36,6 +72,17 @@ class ContainerRequestsController < ApplicationController end def cancel + if @object.container_uuid + c = Container.select(['state']).where(uuid: @object.container_uuid).with_count("none").first + if c && c.state != 'Running' + # If the container hasn't started yet, setting priority=0 + # leaves our request in "Committed" state and doesn't cancel + # the container (even if no other requests are giving it + # priority). To avoid showing this container request as "on + # hold" after hitting the Cancel button, set state=Final too. + @object.state = 'Final' + end + end @object.update_attributes! priority: 0 if params[:return_to] redirect_to params[:return_to] @@ -68,7 +115,7 @@ class ContainerRequestsController < ApplicationController c = Collection.find(re[1]) input_obj[param_id] = {"class" => primary_type, "location" => "keep:#{c.portable_data_hash}#{re[4]}", - "arv:collection" => input_obj[param_id]} + "http://arvados.org/cwl#collectionUUID" => re[1]} end end end @@ -128,4 +175,10 @@ class ContainerRequestsController < ApplicationController super end + + def index + @limit = 20 + super + end + end