class CaseLogsController < ApplicationController skip_before_action :verify_authenticity_token, if: :json_api_request? before_action :authenticate, if: :json_api_request? def index @completed_case_logs = CaseLog.completed @in_progress_case_logs = CaseLog.not_completed end def create case_log = CaseLog.create(api_case_log_params) respond_to do |format| format.html { redirect_to case_log } format.json do if case_log.persisted? render json: case_log, status: :created else render json: { errors: case_log.errors.messages }, status: :unprocessable_entity end end end end def update if (case_log = CaseLog.find_by(id: params[:id])) if case_log.update(api_case_log_params) render json: case_log, status: :ok else render json: { errors: case_log.errors.messages }, status: :unprocessable_entity end else render json: { error: "Case Log #{params[:id]} not found" }, status: :not_found end end def show respond_to do |format| # We don't have a dedicated non-editable show view format.html { edit } format.json do if (case_log = CaseLog.find_by(id: params[:id])) render json: case_log, status: :ok else render json: { error: "Case Log #{params[:id]} not found" }, status: :not_found end end end end def edit @form = FormHandler.instance.get_form("2021_2022") @case_log = CaseLog.find(params[:id]) render :edit end def submit_form form = FormHandler.instance.get_form("2021_2022") @case_log = CaseLog.find(params[:id]) @case_log.page = params[:case_log][:page] responses_for_page = responses_for_page(@case_log.page) if @case_log.update(responses_for_page) && @case_log.has_no_unresolved_soft_errors? redirect_path = form.next_page_redirect_path(@case_log.page, @case_log) redirect_to(send(redirect_path, @case_log)) else page_info = form.all_pages[@case_log.page] render "form/page", locals: { form: form, page_key: @case_log.page, page_info: page_info }, status: :unprocessable_entity end end def destroy if (case_log = CaseLog.find_by(id: params[:id])) if case_log.discard head :no_content else render json: { errors: case_log.errors.messages }, status: :unprocessable_entity end else render json: { error: "Case Log #{params[:id]} not found" }, status: :not_found end end def check_answers form = FormHandler.instance.get_form("2021_2022") @case_log = CaseLog.find(params[:case_log_id]) current_url = request.env["PATH_INFO"] subsection = current_url.split("/")[-2] render "form/check_answers", locals: { subsection: subsection, form: form } end form = FormHandler.instance.get_form("2021_2022") form.all_pages.map do |page_key, page_info| define_method(page_key) do |_errors = {}| @case_log = CaseLog.find(params[:case_log_id]) render "form/page", locals: { form: form, page_key: page_key, page_info: page_info } end end private API_ACTIONS = %w[create show update destroy].freeze def responses_for_page(page) form = FormHandler.instance.get_form("2021_2022") form.expected_responses_for_page(page).each_with_object({}) do |(question_key, question_info), result| question_params = params["case_log"][question_key] if question_info["type"] == "date" day = params["case_log"]["#{question_key}(3i)"] month = params["case_log"]["#{question_key}(2i)"] year = params["case_log"]["#{question_key}(1i)"] next unless [day, month, year].any?(&:present?) result[question_key] = if day.to_i.between?(1, 31) && month.to_i.between?(1, 12) && year.to_i.between?(2000, 2200) Date.new(year.to_i, month.to_i, day.to_i) else Date.new(0, 1, 1) end end next unless question_params if %w[checkbox validation_override].include?(question_info["type"]) question_info["answer_options"].keys.reject { |x| x.match(/divider/) }.each do |option| result[option] = question_params.include?(option) ? 1 : 0 end else result[question_key] = question_params end result end end def json_api_request? API_ACTIONS.include?(request["action"]) && request.format.json? end def authenticate http_basic_authenticate_or_request_with name: ENV["API_USER"], password: ENV["API_KEY"] end def api_case_log_params return {} unless params[:case_log] params.require(:case_log).permit(CaseLog.editable_fields) end end