class ActionDispatch::ContentSecurityPolicy

end
policy.report_uri “/csp-violation-report-endpoint”
# Specify URI for violation reports
policy.style_src :self, :https
policy.script_src :self, :https
policy.object_src :none
policy.img_src :self, :https, :data
policy.font_src :self, :https, :data
policy.default_src :self, :https
Rails.application.config.content_security_policy do |policy|
Example global policy:
response header to help protect against XSS and injection attacks.
Configures the HTTP
:nodoc:

def apply_mapping(source)

def apply_mapping(source)
  MAPPINGS.fetch(source) do
    raise ArgumentError, "Unknown content security policy source mapping: #{source.inspect}"
  end
end

def apply_mappings(sources)

def apply_mappings(sources)
  sources.map do |source|
    case source
    when Symbol
      apply_mapping(source)
    when String, Proc
      source
    else
      raise ArgumentError, "Invalid content security policy source: #{source.inspect}"
    end
  end
end

def block_all_mixed_content(enabled = true)


policy.block_all_mixed_content false

Pass +false+ to allow it again:

policy.block_all_mixed_content

HTTP when the page uses HTTPS:
Specify whether to prevent the user agent from loading any assets over
def block_all_mixed_content(enabled = true)
  if enabled
    @directives["block-all-mixed-content"] = true
  else
    @directives.delete("block-all-mixed-content")
  end
end

def build(context = nil, nonce = nil, nonce_directives = nil)

def build(context = nil, nonce = nil, nonce_directives = nil)
  nonce_directives = DEFAULT_NONCE_DIRECTIVES if nonce_directives.nil?
  build_directives(context, nonce, nonce_directives).compact.join("; ")
end

def build_directive(sources, context)

def build_directive(sources, context)
  sources.map { |source| resolve_source(source, context) }
end

def build_directives(context, nonce, nonce_directives)

def build_directives(context, nonce, nonce_directives)
  @directives.map do |directive, sources|
    if sources.is_a?(Array)
      if nonce && nonce_directive?(directive, nonce_directives)
        "#{directive} #{build_directive(sources, context).join(' ')} 'nonce-#{nonce}'"
      else
        "#{directive} #{build_directive(sources, context).join(' ')}"
      end
    elsif sources
      directive
    else
      nil
    end
  end
end

def initialize

def initialize
  @directives = {}
  yield self if block_given?
end

def initialize_copy(other)

def initialize_copy(other)
  @directives = other.directives.deep_dup
end

def nonce_directive?(directive, nonce_directives)

def nonce_directive?(directive, nonce_directives)
  nonce_directives.include?(directive)
end

def plugin_types(*types)


policy.plugin_types

Leave empty to allow all plugins:

policy.plugin_types "application/x-shockwave-flash"

Restricts the set of plugins that can be embedded:
def plugin_types(*types)
  if types.first
    @directives["plugin-types"] = types
  else
    @directives.delete("plugin-types")
  end
end

def report_uri(uri)


policy.report_uri "/csp-violation-report-endpoint"

directive. Violation reports will be sent to the specified URI:
Enable the {report-uri}[https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/report-uri]
def report_uri(uri)
  @directives["report-uri"] = [uri]
end

def require_sri_for(*types)


policy.require_sri_for

Leave empty to not require Subresource Integrity:

policy.require_sri_for :script, :style

is required:
Specify asset types for which {Subresource Integrity}[https://developer.mozilla.org/en-US/docs/Web/Security/Subresource_Integrity]
def require_sri_for(*types)
  if types.first
    @directives["require-sri-for"] = types
  else
    @directives.delete("require-sri-for")
  end
end

def resolve_source(source, context)

def resolve_source(source, context)
  case source
  when String
    source
  when Symbol
    source.to_s
  when Proc
    if context.nil?
      raise RuntimeError, "Missing context for the dynamic content security policy source: #{source.inspect}"
    else
      resolved = context.instance_exec(&source)
      apply_mappings(Array.wrap(resolved))
    end
  else
    raise RuntimeError, "Unexpected content security policy source: #{source.inspect}"
  end
end

def sandbox(*values)


policy.sandbox false

Pass +false+ to disable the sandbox:

policy.sandbox "allow-scripts", "allow-modals"

Values can be passed as arguments:

policy.sandbox

should be enabled for the requested resource:
Specify whether a {sandbox}[https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy/sandbox]
def sandbox(*values)
  if values.empty?
    @directives["sandbox"] = true
  elsif values.first
    @directives["sandbox"] = values
  else
    @directives.delete("sandbox")
  end
end

def upgrade_insecure_requests(enabled = true)


policy.upgrade_insecure_requests false

Pass +false+ to disable it:

policy.upgrade_insecure_requests

Specify whether user agents should treat any assets over HTTP as HTTPS:
def upgrade_insecure_requests(enabled = true)
  if enabled
    @directives["upgrade-insecure-requests"] = true
  else
    @directives.delete("upgrade-insecure-requests")
  end
end