Class: Decidim::Verifications::AuthorizationsController

Inherits:
ApplicationController show all
Includes:
HtmlSafeFlash, UserProfile, Renewable
Defined in:
decidim-verifications/app/controllers/decidim/verifications/authorizations_controller.rb

Overview

This controller allows users to create and destroy their authorizations. It should not be necessary to expand it to add new authorization schemes.

Instance Method Summary collapse

Methods included from UserProfile

#available_verification_workflows

Methods included from UserGroups

#enforce_user_groups_enabled

Methods inherited from ApplicationController

#renew

Methods included from RegistersPermissions

register_permissions

Methods included from UserBlockedChecker

#check_user_block_status, #check_user_not_blocked

Methods included from NeedsSnippets

#snippets

Methods included from Headers::HttpCachingDisabler

#disable_http_caching

Methods included from HasStoredPath

#skip_store_location?

Methods included from NeedsOrganization

enhance_controller, extended, included

Instance Method Details

#createObject



38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
# File 'decidim-verifications/app/controllers/decidim/verifications/authorizations_controller.rb', line 38

def create
  AuthorizeUser.call(handler, current_organization) do
    on(:ok) do
      flash[:notice] = t("authorizations.create.success", scope: "decidim.verifications")
      redirect_to redirect_url || authorizations_path
    end

    on(:transferred) do |transfer|
      message = t("authorizations.create.success", scope: "decidim.verifications")
      if transfer.records.any?
        flash[:html_safe] = true
        message = <<~HTML
          <p>#{CGI.escapeHTML(message)}</p>
          <p>#{CGI.escapeHTML(t("authorizations.create.transferred", scope: "decidim.verifications"))}</p>
          #{transfer.presenter.records_list_html}
        HTML
      end

      flash[:notice] = message
      redirect_to redirect_url || authorizations_path
    end

    on(:invalid) do
      flash[:alert] = t("authorizations.create.error", scope: "decidim.verifications")
      render action: :new
    end
  end
end

#first_loginObject



28
29
30
31
32
33
34
35
36
# File 'decidim-verifications/app/controllers/decidim/verifications/authorizations_controller.rb', line 28

def 
  if unauthorized_methods.length == 1
    redirect_to(
      action: :new,
      handler: unauthorized_methods.first.name,
      redirect_url: decidim.
    )
  end
end

#indexObject



23
24
25
26
# File 'decidim-verifications/app/controllers/decidim/verifications/authorizations_controller.rb', line 23

def index
  @granted_authorizations = granted_authorizations
  @pending_authorizations = pending_authorizations
end

#newObject



21
# File 'decidim-verifications/app/controllers/decidim/verifications/authorizations_controller.rb', line 21

def new; end