Class: Decidim::Admin::ManagedUsers::ImpersonationsController

Inherits:
ApplicationController show all
Defined in:
decidim-admin/app/controllers/decidim/admin/managed_users/impersonations_controller.rb

Overview

Controller that allows impersonating managed users at the admin panel.

Instance Method Summary collapse

Methods inherited from ApplicationController

#current_ability_klass, #user_not_authorized_path

Methods included from NeedsOrganization

enhance_controller, extended, included

Instance Method Details

#close_sessionObject



48
49
50
51
52
53
54
55
56
57
58
59
60
# File 'decidim-admin/app/controllers/decidim/admin/managed_users/impersonations_controller.rb', line 48

def close_session
  CloseSessionManagedUser.call(user, current_user) do
    on(:ok) do
      flash[:notice] = I18n.t("managed_users.close_session.success", scope: "decidim.admin")
      redirect_to managed_users_path
    end

    on(:invalid) do
      flash.now[:alert] = I18n.t("managed_users.close_session.error", scope: "decidim.admin")
      redirect_to decidim.root_path
    end
  end
end

#createObject



31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'decidim-admin/app/controllers/decidim/admin/managed_users/impersonations_controller.rb', line 31

def create
  authorize! :impersonate, user

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

  ImpersonateManagedUser.call(@form, user, current_user) do
    on(:ok) do
      redirect_to decidim.root_path
    end

    on(:invalid) do
      flash.now[:alert] = I18n.t("managed_users.impersonate.error", scope: "decidim.admin")
      render :new
    end
  end
end

#indexObject



15
16
17
# File 'decidim-admin/app/controllers/decidim/admin/managed_users/impersonations_controller.rb', line 15

def index
  @impersonation_logs = Decidim::ImpersonationLog.where(user: user).order(started_at: :desc).page(params[:page]).per(15)
end

#newObject



19
20
21
22
23
24
25
26
27
28
29
# File 'decidim-admin/app/controllers/decidim/admin/managed_users/impersonations_controller.rb', line 19

def new
  authorize! :impersonate, user

  if handler_name.present?
    @form = form(ImpersonateManagedUserForm).from_params(
      authorization: {
        handler_name: handler_name
      }
    )
  end
end