Sha256: 0c59b51288fda961cb15d7e673c5d5cbf7bce57d04c2c3929dcfe7f3d7ff8ae3

Contents?: true

Size: 1.51 KB

Versions: 15

Compression:

Stored size: 1.51 KB

Contents

module Pageflow
  class FolderPolicy < ApplicationPolicy
    class Scope < Scope
      attr_reader :user, :scope

      def initialize(user, scope)
        @user = user
        @scope = scope
      end

      def resolve
        if user.admin?
          scope.all
        else
          scope.where('account_id IN (?) OR id IN (?)',
                      accounts_where_user_is_at_least_previewer(user).map(&:id),
                      user.entries.map(&:folder_id))
        end
      end

      private

      def accounts_where_user_is_at_least_previewer(user)
        user.accounts.joins(sanitize_sql_array([
          'LEFT OUTER JOIN pageflow_memberships as pageflow_memberships_2 ON ' \
          'pageflow_memberships_2.user_id = :user_id AND ' \
          'pageflow_memberships_2.entity_type = \'Pageflow::Account\' AND ' \
          'pageflow_memberships_2.entity_id = pageflow_accounts.id AND ' \
          'pageflow_memberships_2.role IN (\'previewer\', \'editor\', \'publisher\', \'manager\')',
          user_id: user.id])).where('pageflow_memberships_2.entity_id IS NOT NULL')
      end
    end

    def initialize(user, folder)
      @user = user
      @folder = folder
    end

    def manage?
      allows?(%w(publisher manager))
    end

    def show_account_selection_on?
      (@user.admin? && Account.all.size > 1) ||
        @user.memberships.as_publisher_or_above.on_accounts.size > 1
    end

    private

    def allows?(roles)
      @user.memberships.where(role: roles, entity: @folder.account).any?
    end
  end
end

Version data entries

15 entries across 15 versions & 1 rubygems

Version Path
pageflow-17.0.4 app/policies/pageflow/folder_policy.rb
pageflow-17.0.3 app/policies/pageflow/folder_policy.rb
pageflow-17.0.2 app/policies/pageflow/folder_policy.rb
pageflow-17.0.1 app/policies/pageflow/folder_policy.rb
pageflow-17.0.0 app/policies/pageflow/folder_policy.rb
pageflow-16.2.0 app/policies/pageflow/folder_policy.rb
pageflow-16.1.0 app/policies/pageflow/folder_policy.rb
pageflow-16.0.0 app/policies/pageflow/folder_policy.rb
pageflow-15.8.0 app/policies/pageflow/folder_policy.rb
pageflow-15.7.1 app/policies/pageflow/folder_policy.rb
pageflow-15.7.0 app/policies/pageflow/folder_policy.rb
pageflow-15.6.1 app/policies/pageflow/folder_policy.rb
pageflow-15.6.0 app/policies/pageflow/folder_policy.rb
pageflow-15.5.0 app/policies/pageflow/folder_policy.rb
pageflow-15.4.0 app/policies/pageflow/folder_policy.rb