3114: When current user, show root/home project rather than user attributes when...
[arvados.git] / apps / workbench / app / controllers / actions_controller.rb
index bd182d4e889dc8d6902a1b82e4e03e5a696cd2f9..265cff456ce760a1c850582def2bd709d3e750fb 100644 (file)
@@ -10,6 +10,19 @@ class ActionsController < ApplicationController
     ArvadosBase::resource_class_for_uuid(params[:uuid])
   end
 
+  def show
+    @object = model_class.andand.find(params[:uuid])
+    if @object.is_a? Link and
+        @object.link_class == 'name' and
+        ArvadosBase::resource_class_for_uuid(@object.head_uuid) == Collection
+      redirect_to collection_path(id: @object.uuid)
+    elsif @object
+      redirect_to @object
+    else
+      raise ActiveRecord::RecordNotFound
+    end
+  end
+
   def post
     params.keys.collect(&:to_sym).each do |param|
       if @@exposed_actions[param]
@@ -29,6 +42,7 @@ class ActionsController < ApplicationController
 
   def move_or_copy action
     uuids_to_add = params["selection"]
+    uuids_to_add = [ uuids_to_add ] unless uuids_to_add.is_a? Array
     uuids_to_add.
       collect { |x| ArvadosBase::resource_class_for_uuid(x) }.
       uniq.
@@ -73,10 +87,11 @@ class ActionsController < ApplicationController
   def arv_normalize mt, *opts
     r = ""
     IO.popen(['arv-normalize'] + opts, 'w+b') do |io|
-    io.write mt
-    io.close_write
-    while buf = io.read(2**16)
-      r += buf
+      io.write mt
+      io.close_write
+      while buf = io.read(2**16)
+        r += buf
+      end
     end
     r
   end
@@ -85,7 +100,17 @@ class ActionsController < ApplicationController
     lst = []
     files = []
     params["selection"].each do |s|
-      m = CollectionsHelper.match(s)
+      a = ArvadosBase::resource_class_for_uuid s
+      m = nil
+      if a == Link
+        begin
+          m = CollectionsHelper.match(Link.find(s).head_uuid)
+        rescue
+        end
+      else
+        m = CollectionsHelper.match(s)
+      end
+
       if m and m[1] and m[2]
         lst.append(m[1] + m[2])
         files.append(m)
@@ -117,7 +142,7 @@ class ActionsController < ApplicationController
 
     d = Digest::MD5.new()
     d << normalized_stripped
-    newuuid = "#{d.hexdigest}+#{normalized.length}"
+    newuuid = "#{d.hexdigest}+#{normalized_stripped.length}"
 
     env = Hash[ENV].
       merge({
@@ -131,10 +156,9 @@ class ActionsController < ApplicationController
             })
 
     IO.popen([env, 'arv-put', '--raw'], 'w+b') do |io|
-      io.write normalized
+      io.write normalized_stripped
       io.close_write
-      while buf = io.read(2**20)
-
+      while buf = io.read(2**16)
       end
     end