OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/config/initializers/secure_headers.rb

59 lines
1.8 KiB

SecureHeaders::Configuration.default do |config|
config.cookies = {
secure: true,
httponly: true
}
# Add "; preload" and submit the site to hstspreload.org for best protection.
config.hsts = "max-age=#{20.years.to_i}; includeSubdomains"
config.x_frame_options = "SAMEORIGIN"
config.x_content_type_options = "nosniff"
config.x_xss_protection = "1; mode=block"
config.x_permitted_cross_domain_policies = "none"
config.referrer_policy = "origin-when-cross-origin"
# Valid for assets
assets_src = ["'self'"]
asset_host = OpenProject::Configuration.rails_asset_host
assets_src << asset_host if asset_host.present?
# Valid for iframes
frame_src = %w['self' https://player.vimeo.com]
# Default src
default_src = %w('self')
# Allow requests to CLI in dev mode
connect_src = default_src
if FrontendAssetHelper.assets_proxied?
connect_src += %w[ws://localhost:4200 http://localhost:4200]
assets_src += %w[ws://localhost:4200 http://localhost:4200]
end
config.csp = {
preserve_schemes: true,
# Fallback when no value is defined
default_src: default_src,
# Allowed uri in <base> tag
base_uri: %w('self'),
# Allow fonts from self, asset host, or DATA uri
font_src: assets_src + %w(data:),
# Form targets can only be self
form_action: %w('self'),
# Allow iframe from vimeo (welcome video)
frame_src: frame_src + %w('self'),
frame_ancestors: %w('self'),
# Allow images from anywhere
img_src: %w(* data:),
# Allow scripts from self (not inline, but)
# for now require unsafe-eval for Angular JIT
script_src: assets_src + %w('unsafe-eval'),
# Allow unsafe-inline styles
style_src: assets_src + %w('unsafe-inline'),
# Connect sources for CLI in dev mode
connect_src: connect_src
}
end