X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/effb1b7f4170bb7244c4dfffcbe6134fe00e2bc4..2fc70be734fb6439b1eef340d396af62965817df:/app/controllers/reports_controller.rb diff --git a/app/controllers/reports_controller.rb b/app/controllers/reports_controller.rb index 6c62deb30..4d2220a26 100644 --- a/app/controllers/reports_controller.rb +++ b/app/controllers/reports_controller.rb @@ -5,11 +5,11 @@ class ReportsController < ApplicationController before_action :require_user def new - if create_new_report_params.present? + if required_new_report_params_present? @report = Report.new @report.issue = Issue.find_or_initialize_by(create_new_report_params) - path = "issues.report_strings." + @report.issue.reportable.class.name.to_s - @report_strings_yaml = t(path) + else + redirect_to root_path, :notice => t("reports.new.missing_params") end end @@ -19,8 +19,7 @@ class ReportsController < ApplicationController if @report.save @report.issue.save - # FIXME: reopen issue if necessary - # FIXME: new issue notification (or via model observer) + @report.issue.reopen! unless @report.issue.open? redirect_to root_path, :notice => t("issues.create.successful_report") else redirect_to new_report_path(:reportable_type => @report.issue.reportable_type, :reportable_id => @report.issue.reportable_id), :notice => t("issues.create.provide_details") @@ -29,11 +28,15 @@ class ReportsController < ApplicationController private + def required_new_report_params_present? + create_new_report_params['reportable_id'].present? && create_new_report_params['reportable_type'].present? + end + def create_new_report_params params.permit(:reportable_id, :reportable_type) end def report_params - params[:report].permit(:details) + params[:report].permit(:details, :category) end end