Class: Decidim::Admin::OfficializationsController

Inherits:
ApplicationController show all
Defined in:
app/controllers/decidim/admin/officializations_controller.rb

Overview

Controller that allows managing user officializations at the admin panel.

Instance Method Summary collapse

Methods inherited from ApplicationController

#permission_class_chain, #permission_scope, #user_has_no_permission_path, #user_not_authorized_path

Instance Method Details

#createObject



29
30
31
32
33
34
35
36
37
38
39
40
41
# File 'app/controllers/decidim/admin/officializations_controller.rb', line 29

def create
  enforce_permission_to :create, :officialization

  @form = form(OfficializationForm).from_params(params)

  OfficializeUser.call(@form) do
    on(:ok) do |user|
      notice = I18n.t("officializations.create.success", scope: "decidim.admin")

      redirect_to officializations_path(q: user.name), notice: notice
    end
  end
end

#destroyObject



43
44
45
46
47
48
49
50
51
52
53
# File 'app/controllers/decidim/admin/officializations_controller.rb', line 43

def destroy
  enforce_permission_to :destroy, :officialization

  UnofficializeUser.call(user, current_user) do
    on(:ok) do
      notice = I18n.t("officializations.destroy.success", scope: "decidim.admin")

      redirect_to officializations_path(q: user.name), notice: notice
    end
  end
end

#indexObject



13
14
15
16
17
18
19
20
21
# File 'app/controllers/decidim/admin/officializations_controller.rb', line 13

def index
  enforce_permission_to :read, :officialization
  @query = params[:q]
  @state = params[:state]

  @users = Decidim::Admin::UserFilter.for(current_organization.users.not_deleted, @query, @state)
                                     .page(params[:page])
                                     .per(15)
end

#newObject



23
24
25
26
27
# File 'app/controllers/decidim/admin/officializations_controller.rb', line 23

def new
  enforce_permission_to :create, :officialization

  @form = form(OfficializationForm).from_model(user)
end