mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-09-14 17:14:54 +08:00
70 lines
2.4 KiB
Ruby
70 lines
2.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class StepResultsController < ApplicationController
|
|
before_action :load_steps
|
|
before_action :load_results
|
|
before_action :load_step_results
|
|
before_action :check_manage_permissions
|
|
|
|
def link_results
|
|
ActiveRecord::Base.transaction do
|
|
@step_results.where.not(result: @results).destroy_all
|
|
@results.where.not(id: @step_results.select(:result_id)).each do |result|
|
|
StepResult.create!(step: @steps.first, result: result, created_by: current_user)
|
|
end
|
|
render json: { results: @steps.first.results.map { |r| { id: r.id, name: r.name } } }, status: :created
|
|
rescue ActiveRecord::RecordInvalid => e
|
|
Rails.logger.error e.message
|
|
render json: { message: :error }, status: :unprocessable_entity
|
|
raise ActiveRecord::Rollback
|
|
end
|
|
end
|
|
|
|
def link_steps
|
|
ActiveRecord::Base.transaction do
|
|
@step_results.where.not(step: @steps).destroy_all
|
|
@steps.where.not(id: @step_results.select(:step_id)).each do |step|
|
|
StepResult.create!(step: step, result: @results.first, created_by: current_user)
|
|
end
|
|
render json: { steps: @results.first.steps.map { |s| { id: s.id, name: s.name } } }, status: :created
|
|
rescue ActiveRecord::RecordInvalid => e
|
|
Rails.logger.error e.message
|
|
render json: { message: :error }, status: :unprocessable_entity
|
|
raise ActiveRecord::Rollback
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def load_steps
|
|
@steps = Step.where(id: params[:step_ids])
|
|
|
|
render_404 and return if (action_name == 'link_results') && @steps.size != 1
|
|
|
|
render_403 and return if @steps.pluck(:protocol_id).uniq.size > 1
|
|
end
|
|
|
|
def load_results
|
|
@results = Result.where(id: params[:result_ids])
|
|
|
|
render_404 and return if (action_name == 'link_steps') && @results.size != 1
|
|
|
|
render_403 and return if @results.pluck(:my_module_id).uniq.size > 1
|
|
end
|
|
|
|
def load_step_results
|
|
@step_results = StepResult.where(step: @steps) if action_name == 'link_results'
|
|
@step_results = StepResult.where(result: @results) if action_name == 'link_steps'
|
|
end
|
|
|
|
def check_manage_permissions
|
|
case action_name
|
|
when 'link_results'
|
|
render_403 and return unless can_manage_my_module?(@steps.first.my_module)
|
|
when 'link_steps'
|
|
render_403 and return unless can_manage_my_module?(@results.first.my_module)
|
|
end
|
|
|
|
render_403 and return unless (@results + @steps).map(&:my_module).uniq.one?
|
|
end
|
|
end
|