diff options
author | ThibG <thib@sitedethib.com> | 2018-10-11 20:35:46 +0200 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2018-10-11 20:35:46 +0200 |
commit | 2d27c110610a848d30fe150c58bbd60ebf6fab7c (patch) | |
tree | 3121a45cd249fd477cee659a51a655a02404688d /config/initializers/1_hosts.rb | |
parent | 9ece873d62a483abd86221fb9780ed4f65243e96 (diff) |
Set Content-Security-Policy rules through RoR's config (#8957)
* Set CSP rules in RoR's configuration * Override CSP setting in the embed controller to allow frames
Diffstat (limited to 'config/initializers/1_hosts.rb')
-rw-r--r-- | config/initializers/1_hosts.rb | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/config/initializers/1_hosts.rb b/config/initializers/1_hosts.rb new file mode 100644 index 000000000..757f1f735 --- /dev/null +++ b/config/initializers/1_hosts.rb @@ -0,0 +1,29 @@ +# frozen_string_literal: true + +port = ENV.fetch('PORT') { 3000 } +host = ENV.fetch('LOCAL_DOMAIN') { "localhost:#{port}" } +web_host = ENV.fetch('WEB_DOMAIN') { host } + +alternate_domains = ENV.fetch('ALTERNATE_DOMAINS') { '' } + +Rails.application.configure do + https = Rails.env.production? || ENV['LOCAL_HTTPS'] == 'true' + + config.x.local_domain = host + config.x.web_domain = web_host + config.x.use_https = https + config.x.use_s3 = ENV['S3_ENABLED'] == 'true' + config.x.use_swift = ENV['SWIFT_ENABLED'] == 'true' + + config.x.alternate_domains = alternate_domains.split(/\s*,\s*/) + + config.action_mailer.default_url_options = { host: web_host, protocol: https ? 'https://' : 'http://', trailing_slash: false } + + config.x.streaming_api_base_url = ENV.fetch('STREAMING_API_BASE_URL') do + if Rails.env.production? + "ws#{https ? 's' : ''}://#{web_host}" + else + "ws://#{ENV['REMOTE_DEV'] == 'true' ? host.split(':').first : 'localhost'}:4000" + end + end +end |