Class: Decidim::Admin::OAuthApplicationsController

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

Overview

Controller that allows managing OAuth applications 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



23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'app/controllers/decidim/admin/oauth_applications_controller.rb', line 23

def create
  enforce_permission_to :create, :oauth_application

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

  CreateOAuthApplication.call(@form) do
    on(:ok) do
      flash[:notice] = I18n.t("oauth_applications.create.success", scope: "decidim.admin")
      redirect_to action: :index
    end

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

#destroyObject



66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# File 'app/controllers/decidim/admin/oauth_applications_controller.rb', line 66

def destroy
  @oauth_application = collection.find(params[:id])
  enforce_permission_to :destroy, :oauth_application, oauth_application: @oauth_application

  DestroyOAuthApplication.call(@oauth_application, current_user) do
    on(:ok) do
      flash[:notice] = I18n.t("oauth_applications.destroy.success", scope: "decidim.admin")
      redirect_to action: :index
    end

    on(:invalid) do
      flash.now[:error] = I18n.t("oauth_applications.destroy.error", scope: "decidim.admin")
      redirect_to :back
    end
  end
end

#editObject



41
42
43
44
45
# File 'app/controllers/decidim/admin/oauth_applications_controller.rb', line 41

def edit
  @oauth_application = collection.find(params[:id])
  enforce_permission_to :update, :oauth_application, oauth_application: @oauth_application
  @form = form(OAuthApplicationForm).from_model(@oauth_application)
end

#indexObject



8
9
10
11
# File 'app/controllers/decidim/admin/oauth_applications_controller.rb', line 8

def index
  enforce_permission_to :read, :oauth_application
  @oauth_applications = collection.page(params[:page]).per(15)
end

#newObject



18
19
20
21
# File 'app/controllers/decidim/admin/oauth_applications_controller.rb', line 18

def new
  enforce_permission_to :create, :oauth_application
  @form = form(OAuthApplicationForm).instance
end

#showObject



13
14
15
16
# File 'app/controllers/decidim/admin/oauth_applications_controller.rb', line 13

def show
  @oauth_application = collection.find(params[:id])
  enforce_permission_to :read, :oauth_application
end

#updateObject



47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# File 'app/controllers/decidim/admin/oauth_applications_controller.rb', line 47

def update
  @oauth_application = collection.find(params[:id])
  enforce_permission_to :update, :oauth_application, oauth_application: @oauth_application
  @form = form(OAuthApplicationForm).from_params({ organization_logo: @oauth_application. }.merge(params.to_unsafe_h))

  UpdateOAuthApplication.call(@oauth_application, @form, current_user) do
    on(:ok) do |_application|
      flash[:notice] = I18n.t("oauth_applications.update.success", scope: "decidim.admin")
      redirect_to action: :index
    end

    on(:invalid) do |application|
      @oauth_application = application
      flash.now[:error] = I18n.t("oauth_applications.update.error", scope: "decidim.admin")
      render action: :edit
    end
  end
end