Sha256: 753d1fdeb03e952bb78c8f10105d8db13e0dad201f6ed5bc092b5b1fd3d8d305

Contents?: true

Size: 1.17 KB

Versions: 5

Compression:

Stored size: 1.17 KB

Contents

require 'pundit'

module ActiveAdmin

  class PunditAdapter < AuthorizationAdapter

    def authorized?(action, subject = nil)
      policy = retreive_policy(subject)
      action = format_action(action, subject)

      policy.class.method_defined?(action) && policy.send(action)
    end

    def scope_collection(collection, action = Auth::READ)
      # scoping is appliable only to read/index action
      # which means there is no way how to scope other actions
      Pundit.policy_scope!(user, collection)
    end


    def retreive_policy(subject)
      case subject
      when nil   then Pundit.policy!(user, resource)
      when Class then Pundit.policy!(user, subject.new)
      else Pundit.policy!(user, subject)
      end
    end

    def format_action(action, subject)
      # https://github.com/elabs/pundit/blob/master/lib/generators/pundit/install/templates/application_policy.rb
      case action
      when Auth::CREATE  then :create?
      when Auth::UPDATE  then :update?
      when Auth::READ    then subject.is_a?(Class) ? :index? : :show?
      when Auth::DESTROY then subject.is_a?(Class) ? :destroy_all? : :destroy?
      else "#{action}?"
      end
    end

  end

end

Version data entries

5 entries across 5 versions & 2 rubygems

Version Path
active_administration-0.0.3 lib/active_admin/pundit_adapter.rb
activeadministration-0.0.2 lib/active_admin/pundit_adapter.rb
active_administration-0.0.2 lib/active_admin/pundit_adapter.rb
activeadministration-0.0.1 lib/active_admin/pundit_adapter.rb
active_administration-0.0.1 lib/active_admin/pundit_adapter.rb