Module: ActionController::PermissionsPolicy::ClassMethods
Relationships & Source Files | |
Defined in: | actionpack/lib/action_controller/metal/permissions_policy.rb |
Instance Method Summary
-
#permissions_policy(**options, &block)
Overrides parts of the globally configured
Feature-Policy
header:
Instance Method Details
#permissions_policy(**options, &block)
Overrides parts of the globally configured Feature-Policy
header:
class PagesController < ApplicationController
do |policy|
policy.geolocation "https://example.com"
end
end
Options can be passed similar to before_action
. For example, pass ‘only: :index` to override the header on the index action only:
class PagesController < ApplicationController
(only: :index) do |policy|
policy.camera :self
end
end
Requires a global policy defined in an initializer, which can be empty:
Rails.application.config. do |policy|
# policy.gyroscope :none
end
# File 'actionpack/lib/action_controller/metal/permissions_policy.rb', line 33
def (**, &block) before_action( ) do unless request.respond_to?(: ) raise "Cannot override permissions_policy if no global permissions_policy configured." end if block_given? policy = request. .clone instance_exec(policy, &block) request. = policy end end end