layout "site"
before_action :authorize_web
- before_action :require_user
+ before_action :set_locale
+ before_action :check_database_readable
+
+ authorize_resource
+
+ before_action :check_database_writable, :only => [:new, :create]
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(".missing_params")
end
end
def create
@report = current_user.reports.new(report_params)
- @report.issue = Issue.find_or_initialize_by(:reportable_id => params[:report][:issue][:reportable_id], :reportable_type => params[:report][:issue][:reportable_type])
+ @report.issue = Issue
+ .create_with(:assigned_role => default_assigned_role)
+ .find_or_initialize_by(issue_params)
if @report.save
- @report.issue.save
- # FIXME: reopen issue if necessary
- # FIXME: new issue notification (or via model observer)
- redirect_to root_path, :notice => t("issues.create.successful_report")
+ @report.issue.assigned_role = "administrator" if default_assigned_role == "administrator"
+ @report.issue.reopen unless @report.issue.open?
+ @report.issue.save!
+
+ redirect_to helpers.reportable_url(@report.issue.reportable), :notice => t(".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")
+ flash.now[:notice] = t(".provide_details")
+ render :action => "new"
end
end
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.require(:report).permit(:details, :category)
+ end
+
+ def issue_params
+ params.require(:report).require(:issue).permit(:reportable_id, :reportable_type)
+ end
+
+ def default_assigned_role
+ case issue_params[:reportable_type]
+ when "Note"
+ "moderator"
+ when "User"
+ case report_params[:category]
+ when "vandal" then "moderator"
+ else "administrator"
+ end
+ else
+ "administrator"
+ end
end
end