2872: Merge branch 'master' into 2872-folder-nav
[arvados.git] / apps / workbench / app / controllers / pipeline_instances_controller.rb
index 500927bdb62ba240301382cc0239a50f308d34ab..a4a9d69bef8205c7df6fd652546f52fd9ad0b6a7 100644 (file)
@@ -3,6 +3,42 @@ class PipelineInstancesController < ApplicationController
   before_filter :find_objects_by_uuid, only: :compare
   include PipelineInstancesHelper
 
+  def copy
+    @object = @object.dup
+    @object.components.each do |cname, component|
+      component.delete :job
+    end
+    @object.state = 'New'
+    super
+  end
+
+  def update
+    @updates ||= params[@object.class.to_s.underscore.singularize.to_sym]
+    if (components = @updates[:components])
+      components.each do |cname, component|
+        if component[:script_parameters]
+          component[:script_parameters].each do |param, value_info|
+            if value_info.is_a? Hash
+              if resource_class_for_uuid(value_info[:value]) == Link
+                # Use the link target, not the link itself, as script
+                # parameter; but keep the link info around as well.
+                link = Link.find value_info[:value]
+                value_info[:value] = link.head_uuid
+                value_info[:link_uuid] = link.uuid
+                value_info[:link_name] = link.name
+              else
+                # Delete stale link_uuid and link_name data.
+                value_info[:link_uuid] = nil
+                value_info[:link_name] = nil
+              end
+            end
+          end
+        end
+      end
+    end
+    super
+  end
+
   def graph(pipelines)
     return nil, nil if params['tab_pane'] != "Graph"
 
@@ -143,13 +179,17 @@ class PipelineInstancesController < ApplicationController
       :combine_jobs => :script_and_version,
       :script_version_nodes => true,
       :pips => pips }
+    @object = @objects.first
   end
 
   def show_pane_list
-    panes = %w(Components Graph Attributes Metadata JSON API)
+    panes = %w(Components Graph Advanced)
     if @object and @object.state.in? ['New', 'Ready']
       panes = %w(Inputs) + panes
     end
+    if not @object.components.values.collect { |x| x[:job] }.compact.any?
+      panes -= ['Graph']
+    end
     panes
   end