class JobsController < ApplicationController
+ skip_around_filter :require_thread_api_token, if: proc { |ctrl|
+ Rails.configuration.anonymous_user_token and
+ 'show' == ctrl.action_name
+ }
def generate_provenance(jobs)
return if params['tab_pane'] != "Provenance"
- nodes = []
+ nodes = {}
collections = []
+ hashes = []
jobs.each do |j|
- nodes << j
- collections << j[:output]
- collections.concat(ProvenanceHelper::find_collections(j[:script_parameters]))
- nodes << {:uuid => j[:script_version]}
+ nodes[j[:uuid]] = j
+ hashes << j[:output]
+ ProvenanceHelper::find_collections(j[:script_parameters]) do |hash, uuid|
+ collections << uuid if uuid
+ hashes << hash if hash
+ end
+ nodes[j[:script_version]] = {:uuid => j[:script_version]}
end
Collection.where(uuid: collections).each do |c|
- nodes << c
+ nodes[c[:portable_data_hash]] = c
+ end
+
+ Collection.where(portable_data_hash: hashes).each do |c|
+ nodes[c[:portable_data_hash]] = c
end
@svg = ProvenanceHelper::create_provenance_graph nodes, "provenance_svg", {
if params[:uuid]
@objects = Job.where(uuid: params[:uuid])
generate_provenance(@objects)
+ render_index
else
@limit = 20
+ super
end
- super
end
def cancel
@object.cancel
- redirect_to @object
+ if params[:return_to]
+ redirect_to params[:return_to]
+ else
+ redirect_to @object
+ end
end
def show
super
end
+ 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
+
def index_pane_list
if params[:uuid]
%w(Recent Provenance)
end
def show_pane_list
- %w(Status Attributes Provenance Metadata JSON API)
+ %w(Status Log Details Provenance Advanced)
end
end