X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/912464ad82bad38f1ce7984b6d4b19734a9816a9..976f560ab04bf570ed58664d97b8b6069b314941:/apps/workbench/app/controllers/pipeline_instances_controller.rb diff --git a/apps/workbench/app/controllers/pipeline_instances_controller.rb b/apps/workbench/app/controllers/pipeline_instances_controller.rb index b4cce9be03..e84d990479 100644 --- a/apps/workbench/app/controllers/pipeline_instances_controller.rb +++ b/apps/workbench/app/controllers/pipeline_instances_controller.rb @@ -284,6 +284,60 @@ class PipelineInstancesController < ApplicationController %w(Compare Graph) end + helper_method :unreadable_inputs_present? + def unreadable_inputs_present? + unless @unreadable_inputs_present.nil? + @unreadable_inputs_present + end + + input_uuids = [] + input_pdhs = [] + @object.components.each do |k, component| + next if !component + component[:script_parameters].andand.each do |p, tv| + if (tv.is_a? Hash) and (tv[:dataclass] == "Collection") + if tv[:value] + value = tv[:value] + elsif tv[:default] + value = tv[:default] + end + if value + split = value.split '/' + if CollectionsHelper.match(split[0]) + input_pdhs << split[0] + else + input_uuids << split[0] + end + end + end + end + end + + input_pdhs = input_pdhs.uniq + input_uuids = input_uuids.uniq + + preload_collections_for_objects input_uuids if input_uuids.any? + preload_for_pdhs input_pdhs if input_pdhs.any? + + @unreadable_inputs_present = false + input_uuids.each do |uuid| + if !collections_for_object(uuid).any? + @unreadable_inputs_present = true + break + end + end + if !@unreadable_inputs_present + input_pdhs.each do |pdh| + if !collection_for_pdh(pdh).any? + @unreadable_inputs_present = true + break + end + end + end + + @unreadable_inputs_present + end + protected def for_comparison v if v.is_a? Hash or v.is_a? Array