]> git.openstreetmap.org Git - rails.git/blob - config/environments/production.rb
Protect I18n.locale around tests which may change it
[rails.git] / config / environments / production.rb
1 require "active_support/core_ext/integer/time"
2
3 Rails.application.configure do
4   # Settings specified here will take precedence over those in config/application.rb.
5
6   # Code is not reloaded between requests.
7   config.enable_reloading = false
8
9   # Eager load code on boot for better performance and memory savings (ignored by Rake tasks).
10   config.eager_load = true
11
12   # Full error reports are disabled.
13   config.consider_all_requests_local = false
14
15   # Turn on fragment caching in view templates.
16   config.action_controller.perform_caching = true
17
18   # Cache assets for far-future expiry since they are all digest stamped.
19   config.public_file_server.headers = { "cache-control" => "public, max-age=#{1.year.to_i}" }
20
21   # Enable serving of images, stylesheets, and JavaScripts from an asset server.
22   # config.asset_host = "http://assets.example.com"
23
24   # Store uploaded files on the local file system (see config/storage.yml for options).
25   config.active_storage.service = :local
26
27   # Assume all access to the app is happening through a SSL-terminating reverse proxy.
28   config.assume_ssl = true
29
30   # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
31   config.force_ssl = true
32
33   # Skip http-to-https redirect for the default health check endpoint.
34   # config.ssl_options = { redirect: { exclude: ->(request) { request.path == "/up" } } }
35
36   # Log to STDOUT with the current request id as a default log tag.
37   config.log_tags = [:request_id]
38   config.logger   = if Settings.key?(:log_path)
39                       ActiveSupport::TaggedLogging.logger(Settings.log_path)
40                     else
41                       ActiveSupport::TaggedLogging.logger($stdout)
42                     end
43
44   # Change to "debug" to log everything (including potentially personally-identifiable information!)
45   config.log_level = ENV.fetch("RAILS_LOG_LEVEL", "info")
46
47   # Prevent health checks from clogging up the logs.
48   config.silence_healthcheck_path = "/up"
49
50   # Don't log any deprecations.
51   config.active_support.report_deprecations = false
52
53   # Replace the default in-process memory cache store with a durable alternative.
54   # config.cache_store = :mem_cache_store
55
56   # Replace the default in-process and non-durable queuing backend for Active Job.
57   # config.active_job.queue_adapter = :resque
58
59   # Configure caching of static assets
60   config.action_controller.page_cache_directory = Rails.public_path
61
62   # Ignore bad email addresses and do not raise email delivery errors.
63   # Set this to true and configure the email server for immediate delivery to raise delivery errors.
64   # config.action_mailer.raise_delivery_errors = false
65
66   # Set host to be used by links generated in mailer templates.
67   config.action_mailer.default_url_options = { :host => "example.com" }
68
69   # Specify outgoing SMTP server. Remember to add smtp/* credentials via rails credentials:edit.
70   # config.action_mailer.smtp_settings = {
71   #   user_name: Rails.application.credentials.dig(:smtp, :user_name),
72   #   password: Rails.application.credentials.dig(:smtp, :password),
73   #   address: "smtp.example.com",
74   #   port: 587,
75   #   authentication: :plain
76   # }
77
78   # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
79   # the I18n.default_locale when a translation cannot be found).
80   config.i18n.fallbacks = true
81
82   # Do not dump schema after migrations.
83   config.active_record.dump_schema_after_migration = false unless Settings.status == "database_offline"
84
85   # Only use :id for inspections in production.
86   config.active_record.attributes_for_inspect = [:id]
87
88   # Enable DNS rebinding protection and other `Host` header attacks.
89   # config.hosts = [
90   #   "example.com",     # Allow requests from example.com
91   #   /.*\.example\.com/ # Allow requests from subdomains like `www.example.com`
92   # ]
93   #
94   # Skip DNS rebinding protection for the default health check endpoint.
95   # config.host_authorization = { exclude: ->(request) { request.path == "/up" } }
96
97   # Use delayed job to queue jobs in production.
98   config.active_job.queue_adapter = :delayed_job
99 end