Sha256: c55fa9ec15d2eb31af91397568ebe939e434edd920111bf4f2c9d26e28c0b871
Contents?: true
Size: 1001 Bytes
Versions: 49
Compression:
Stored size: 1001 Bytes
Contents
# frozen_string_literal: true module Decidim module Admin # A Rails routes constraint to only allow access to an Organization admin to # the organization dashboard. class OrganizationDashboardConstraint # Initializes the contraint. # # request [Rack::Request] def initialize(request) @request = request end # Checks if the user can access the organization dashboard. # # Returns boolean. def matches? user && user.organization == organization && ability.can?(:read, :admin_dashboard) end private attr_reader :request def organization request.env["decidim.current_organization"] end def user return unless request.env["warden"].authenticate!(scope: :user) @user ||= request.env["warden"].user("user") end def ability Decidim::Admin::Abilities::BaseAbility.new(user, current_organization: organization) end end end end
Version data entries
49 entries across 49 versions & 2 rubygems