Sha256: a96271a75e7adafb6bbb95cb82e805e3cfacac7252ac237ad27639c1e5618c1c

Contents?: true

Size: 1.55 KB

Versions: 7

Compression:

Stored size: 1.55 KB

Contents

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

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

      def themings_allowed_for(accounts)
        if user.admin?
          scope.all
        else
          accounts_ids = accounts.try(:id) || accounts.try(:length) && accounts.map(&:id)
          scope.joins(publisher_memberships_for_accounts(user, accounts_ids))
            .where(membership_is_present)
        end
      end

      private

      def publisher_memberships_for_accounts(user, accounts_ids)
        sanitize_sql_array(['LEFT OUTER JOIN pageflow_memberships ON ' \
                            'pageflow_memberships.user_id = :user_id AND ' \
                            'pageflow_themings.account_id IN (:accounts_ids) AND ' \
                            'pageflow_memberships.entity_id IN (:accounts_ids) AND ' \
                            'pageflow_memberships.entity_type = \'Pageflow::Account\' AND ' \
                            'pageflow_memberships.role IN (\'publisher\', \'manager\')',
                            user_id: user.id, accounts_ids: accounts_ids])
      end

      def membership_is_present
        'pageflow_memberships.entity_id IS NOT NULL'
      end
    end

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

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

    private

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

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
pageflow-15.8.0 app/policies/pageflow/theming_policy.rb
pageflow-15.7.1 app/policies/pageflow/theming_policy.rb
pageflow-15.7.0 app/policies/pageflow/theming_policy.rb
pageflow-15.6.1 app/policies/pageflow/theming_policy.rb
pageflow-15.6.0 app/policies/pageflow/theming_policy.rb
pageflow-15.5.0 app/policies/pageflow/theming_policy.rb
pageflow-15.4.0 app/policies/pageflow/theming_policy.rb