X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/0e7cfa403cb80fc68d6c10c4c912e4d618fa085a..f102390c598ec819f31fdccc603f19c39eb9e1c8:/apps/workbench/app/controllers/jobs_controller.rb diff --git a/apps/workbench/app/controllers/jobs_controller.rb b/apps/workbench/app/controllers/jobs_controller.rb index 31bbfa9615..b90210f6a9 100644 --- a/apps/workbench/app/controllers/jobs_controller.rb +++ b/apps/workbench/app/controllers/jobs_controller.rb @@ -1,4 +1,10 @@ class JobsController < ApplicationController + skip_around_filter :require_thread_api_token, if: proc { |ctrl| + Rails.configuration.anonymous_user_token and + 'show' == ctrl.action_name + } + + include JobsHelper def generate_provenance(jobs) return if params['tab_pane'] != "Provenance" @@ -56,9 +62,17 @@ class JobsController < ApplicationController super end - def push_logs - @push_logs = stderr_log_records([@object.uuid]).select do |log_record| - log_record.properties[:text] =~ /crunchstat: (mem.*swap.*rss|.*-- interval)/ + def logs + @logs = Log.select(%w(event_type object_uuid event_at properties)) + .order('event_at DESC') + .filter([["event_type", "=", "stderr"], + ["object_uuid", "in", [@object.uuid]]]) + .limit(500) + .results + .to_a + .map{ |e| e.serializable_hash.merge({ 'prepend' => true }) } + respond_to do |format| + format.json { render json: @logs } end end @@ -71,6 +85,8 @@ class JobsController < ApplicationController end def show_pane_list - %w(Status Log Details Provenance Advanced) + panes = %w(Status Log Details Provenance Advanced) + panes.delete 'Log' if !current_user + panes end end