X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/94b5a59631f22e4e57561a6244c24b93db77f589..498f3130928f58e830be3abe74b20d06904af3cd:/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 fd4ebc4cd4..7c68ce9f7b 100644 --- a/apps/workbench/app/controllers/actions_controller.rb +++ b/apps/workbench/app/controllers/actions_controller.rb @@ -1,5 +1,8 @@ class ActionsController < ApplicationController + skip_filter :require_thread_api_token, only: [:report_issue_popup, :report_issue] + skip_filter :check_user_agreements, only: [:report_issue_popup, :report_issue] + @@exposed_actions = {} def self.expose_action method, &block @@exposed_actions[method] = true @@ -89,7 +92,16 @@ class ActionsController < ApplicationController def arv_normalize mt, *opts r = "" - IO.popen(['arv-normalize'] + opts, 'w+b') do |io| + env = Hash[ENV]. + merge({'ARVADOS_API_HOST' => + arvados_api_client.arvados_v1_base. + sub(/\/arvados\/v1/, ''). + sub(/^https?:\/\//, ''), + 'ARVADOS_API_TOKEN' => 'x', + 'ARVADOS_API_HOST_INSECURE' => + Rails.configuration.arvados_insecure_https ? 'true' : 'false' + }) + IO.popen([env, 'arv-normalize'] + opts, 'w+b') do |io| io.write mt io.close_write while buf = io.read(2**16) @@ -139,46 +151,42 @@ class ActionsController < ApplicationController end normalized = arv_normalize combined - normalized_stripped = arv_normalize combined, '--strip' - - require 'digest/md5' - - d = Digest::MD5.new() - d << normalized_stripped - newuuid = "#{d.hexdigest}+#{normalized_stripped.length}" - - env = Hash[ENV]. - merge({ - 'ARVADOS_API_HOST' => - arvados_api_client.arvados_v1_base. - sub(/\/arvados\/v1/, ''). - sub(/^https?:\/\//, ''), - 'ARVADOS_API_TOKEN' => Thread.current[:arvados_api_token], - 'ARVADOS_API_HOST_INSECURE' => - Rails.configuration.arvados_insecure_https ? 'true' : 'false' - }) - - IO.popen([env, 'arv-put', '--raw'], 'w+b') do |io| - io.write normalized_stripped - io.close_write - while buf = io.read(2**16) - end - end - - newc = Collection.new({:uuid => newuuid, :manifest_text => normalized}) + newc = Collection.new({:manifest_text => normalized}) newc.save! chash.each do |k,v| l = Link.new({ tail_uuid: k, - head_uuid: newuuid, + head_uuid: newc.uuid, link_class: "provenance", name: "provided" }) l.save! end - redirect_to controller: 'collections', action: :show, id: newc.uuid + if params["show_project"] + respond_to do |format| + format.js {render inline: "location.reload();" } + end + else + redirect_to controller: 'collections', action: :show, id: newc.uuid + end + end + + def report_issue_popup + respond_to do |format| + format.js + format.html + end + end + + def report_issue + logger.warn "report_issue: #{params.inspect}" + + respond_to do |format| + IssueReporter.send_report(current_user, params).deliver + format.js {render nothing: true} + end end end