diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2021-02-21 19:50:12 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-21 19:50:12 +0100 |
commit | 8331fdf7e0ea85ecc6d7dbff00b784bb6aa1f7d4 (patch) | |
tree | 044e1475cb6e31c5c33d02a4220c95f080667c59 /app/controllers/admin | |
parent | dcc7c686f3c4c85ebb8a3e6d5a861fc530c1840d (diff) |
Add server rules (#15769)
Diffstat (limited to 'app/controllers/admin')
-rw-r--r-- | app/controllers/admin/rules_controller.rb | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/app/controllers/admin/rules_controller.rb b/app/controllers/admin/rules_controller.rb new file mode 100644 index 000000000..f3bed3ad8 --- /dev/null +++ b/app/controllers/admin/rules_controller.rb @@ -0,0 +1,59 @@ +# frozen_string_literal: true + +module Admin + class RulesController < BaseController + before_action :set_rule, except: [:index, :create] + + def index + authorize :rule, :index? + + @rules = Rule.ordered + @rule = Rule.new + end + + def create + authorize :rule, :create? + + @rule = Rule.new(resource_params) + + if @rule.save + redirect_to admin_rules_path + else + @rules = Rule.ordered + render :index + end + end + + def edit + authorize @rule, :update? + end + + def update + authorize @rule, :update? + + if @rule.update(resource_params) + redirect_to admin_rules_path + else + render :edit + end + end + + def destroy + authorize @rule, :destroy? + + @rule.discard + + redirect_to admin_rules_path + end + + private + + def set_rule + @rule = Rule.find(params[:id]) + end + + def resource_params + params.require(:rule).permit(:text, :priority) + end + end +end |