X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/4304baee8e6cc9483a0cae397149526a0e8356fb..fbe39c0c33a9c9c3451ad6bf8ec4b336e7e3b24f:/apps/workbench/app/controllers/work_units_controller.rb diff --git a/apps/workbench/app/controllers/work_units_controller.rb b/apps/workbench/app/controllers/work_units_controller.rb index e375689660..1e57e7caab 100644 --- a/apps/workbench/app/controllers/work_units_controller.rb +++ b/apps/workbench/app/controllers/work_units_controller.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + class WorkUnitsController < ApplicationController skip_around_filter :require_thread_api_token, if: proc { |ctrl| Rails.configuration.anonymous_user_token and @@ -14,12 +18,16 @@ class WorkUnitsController < ApplicationController @filters = @filters || [] # get next page of pipeline_instances - filters = @filters + [["uuid", "is_a", ["arvados#pipelineInstance"]]] - pipelines = PipelineInstance.limit(@limit).order(["created_at desc"]).filter(filters) + if PipelineInstance.api_exists?(:index) + filters = @filters + [["uuid", "is_a", ["arvados#pipelineInstance"]]] + pipelines = PipelineInstance.limit(@limit).order(["created_at desc"]).filter(filters) + end # get next page of jobs - filters = @filters + [["uuid", "is_a", ["arvados#job"]]] - jobs = Job.limit(@limit).order(["created_at desc"]).filter(filters) + if Job.api_exists?(:index) + filters = @filters + [["uuid", "is_a", ["arvados#job"]]] + jobs = Job.limit(@limit).order(["created_at desc"]).filter(filters) + end # get next page of container_requests filters = @filters + [["uuid", "is_a", ["arvados#containerRequest"]]] @@ -53,7 +61,7 @@ class WorkUnitsController < ApplicationController workflow = Workflow.find? template_uuid if workflow.definition begin - wf_json = YAML::load(workflow.definition) + wf_json = ActiveSupport::HashWithIndifferentAccess.new YAML::load(workflow.definition) rescue => e logger.error "Error converting definition yaml to json: #{e.message}" raise ArgumentError, "Error converting definition yaml to json: #{e.message}" @@ -73,11 +81,21 @@ class WorkUnitsController < ApplicationController attrs['cwd'] = "/var/spool/cwl" attrs['output_path'] = "/var/spool/cwl" + input_defaults = {} + if wf_json + inputs = get_cwl_inputs(wf_json) + inputs.each do |input| + if input[:default] + input_defaults[cwl_shortname(input[:id])] = input[:default] + end + end + end + # mounts mounts = { "/var/lib/cwl/cwl.input.json" => { "kind" => "json", - "content" => {} + "content" => input_defaults }, "stdout" => { "kind" => "file", @@ -117,25 +135,49 @@ class WorkUnitsController < ApplicationController end end + def find_object_by_uuid + if params['object_type'] + @object = params['object_type'].constantize.find(params['uuid']) + else + super + end + end + def show_child_component data = JSON.load(params[:action_data]) - current_obj = data['current_obj'] + current_obj = {} + current_obj_uuid = data['current_obj_uuid'] + current_obj_name = data['current_obj_name'] current_obj_type = data['current_obj_type'] - if current_obj['uuid'] - resource_class = resource_class_for_uuid current_obj['uuid'] - obj = object_for_dataclass(resource_class, current_obj['uuid']) + current_obj_parent = data['current_obj_parent'] + if current_obj_uuid + resource_class = resource_class_for_uuid current_obj_uuid + obj = object_for_dataclass(resource_class, current_obj_uuid) current_obj = obj if obj end - if current_obj_type == JobWorkUnit.to_s - wu = JobWorkUnit.new(current_obj, params['name']) - elsif current_obj_type == PipelineInstanceWorkUnit.to_s - wu = PipelineInstanceWorkUnit.new(current_obj, params['name']) - elsif current_obj_type == ContainerWorkUnit.to_s - wu = ContainerWorkUnit.new(current_obj, params['name']) - end - @object ||= arvados_api_client.unpack_api_response data['main_obj'], data['main_obj_kind'] + if current_obj.is_a?(Hash) and !current_obj.any? + if current_obj_parent + resource_class = resource_class_for_uuid current_obj_parent + parent = object_for_dataclass(resource_class, current_obj_parent) + parent_wu = parent.work_unit + children = parent_wu.children + if current_obj_uuid + wu = children.select {|c| c.uuid == current_obj_uuid}.first + else current_obj_name + wu = children.select {|c| c.label.to_s == current_obj_name}.first + end + end + else + if current_obj_type == JobWorkUnit.to_s + wu = JobWorkUnit.new(current_obj, current_obj_name, current_obj_parent) + elsif current_obj_type == PipelineInstanceWorkUnit.to_s + wu = PipelineInstanceWorkUnit.new(current_obj, current_obj_name, current_obj_parent) + elsif current_obj_type == ContainerWorkUnit.to_s + wu = ContainerWorkUnit.new(current_obj, current_obj_name, current_obj_parent) + end + end respond_to do |f| f.html { render(partial: "show_component", locals: {wu: wu}) }