X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/cec09589e50ced6d0b7a0d90d5ca124241d4a58a..1966eff7c92733225cd9fe1a4121ae0b8f1153d3:/apps/workbench/app/controllers/actions_controller.rb diff --git a/apps/workbench/app/controllers/actions_controller.rb b/apps/workbench/app/controllers/actions_controller.rb index c1e2617fc7..fd4ebc4cd4 100644 --- a/apps/workbench/app/controllers/actions_controller.rb +++ b/apps/workbench/app/controllers/actions_controller.rb @@ -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,12 +42,13 @@ 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. each do |resource_class| resource_class.filter([['uuid','in',uuids_to_add]]).each do |src| - if resource_class == Collection + if resource_class == Collection and not Collection.attribute_info.include?(:name) dst = Link.new(owner_uuid: @object.uuid, tail_uuid: @object.uuid, head_uuid: src.uuid, @@ -51,6 +65,9 @@ class ActionsController < ApplicationController dst.name = "Copy of unnamed #{dst.class_for_display.downcase}" end end + if resource_class == Collection + dst.manifest_text = Collection.select([:manifest_text]).where(uuid: src.uuid).first.manifest_text + end when :move dst = src else @@ -70,11 +87,33 @@ class ActionsController < ApplicationController redirect_to @object end + 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 + end + end + r + end + expose_action :combine_selected_files_into_collection do 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) @@ -93,32 +132,20 @@ class ActionsController < ApplicationController files.each do |m| mt = chash[m[1]+m[2]].manifest_text if m[4] - IO.popen(['arv-normalize', '--extract', m[4][1..-1]], 'w+b') do |io| - io.write mt - io.close_write - while buf = io.read(2**20) - combined += buf - end - end + combined += arv_normalize mt, '--extract', m[4][1..-1] else combined += chash[m[1]+m[2]].manifest_text end end - normalized = '' - IO.popen(['arv-normalize'], 'w+b') do |io| - io.write combined - io.close_write - while buf = io.read(2**20) - normalized += buf - end - end + normalized = arv_normalize combined + normalized_stripped = arv_normalize combined, '--strip' require 'digest/md5' d = Digest::MD5.new() - d << normalized - newuuid = "#{d.hexdigest}+#{normalized.length}" + d << normalized_stripped + newuuid = "#{d.hexdigest}+#{normalized_stripped.length}" env = Hash[ENV]. merge({ @@ -132,10 +159,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