All checks were successful
		
		
	
	Run unit tests / rubocop (pull_request) Successful in 27s
				
			Run unit tests / check-licenses (pull_request) Successful in 41s
				
			Run unit tests / copyright_notice (pull_request) Successful in 45s
				
			Run unit tests / unit_tests (pull_request) Successful in 1m14s
				
			Run unit tests / build-static-assets (pull_request) Successful in 12m2s
				
			
		
			
				
	
	
		
			116 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # Copyright (C) 2024-2025 LibreWeddingPlanner contributors
 | |
| 
 | |
| require "active_support/core_ext/integer/time"
 | |
| 
 | |
| Rails.application.configure do
 | |
|   # Settings specified here will take precedence over those in config/application.rb.
 | |
| 
 | |
|   # Code is not reloaded between requests.
 | |
|   config.enable_reloading = false
 | |
| 
 | |
|   # Eager load code on boot. This eager loads most of Rails and
 | |
|   # your application in memory, allowing both threaded web servers
 | |
|   # and those relying on copy on write to perform better.
 | |
|   # Rake tasks automatically ignore this option for performance.
 | |
|   config.eager_load = true
 | |
| 
 | |
|   # Full error reports are disabled and caching is turned on.
 | |
|   config.consider_all_requests_local = false
 | |
|   config.action_controller.perform_caching = true
 | |
| 
 | |
|   # Ensures that a master key has been made available in ENV["RAILS_MASTER_KEY"], config/master.key, or an environment
 | |
|   # key such as config/credentials/production.key. This key is used to decrypt credentials (and other encrypted files).
 | |
|   # config.require_master_key = true
 | |
| 
 | |
|   # Disable serving static files from `public/`, relying on NGINX/Apache to do so instead.
 | |
|   # config.public_file_server.enabled = false
 | |
| 
 | |
|   # Compress CSS using a preprocessor.
 | |
|   # config.assets.css_compressor = :sass
 | |
| 
 | |
|   # Do not fall back to assets pipeline if a precompiled asset is missed.
 | |
|   config.assets.compile = false
 | |
| 
 | |
|   # Enable serving of images, stylesheets, and JavaScripts from an asset server.
 | |
|   # config.asset_host = "http://assets.example.com"
 | |
| 
 | |
|   # Specifies the header that your server uses for sending files.
 | |
|   # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for Apache
 | |
|   # config.action_dispatch.x_sendfile_header = "X-Accel-Redirect" # for NGINX
 | |
| 
 | |
|   # Store uploaded files on the local file system (see config/storage.yml for options).
 | |
|   config.active_storage.service = :local
 | |
| 
 | |
|   # Mount Action Cable outside main process or domain.
 | |
|   # config.action_cable.mount_path = nil
 | |
|   # config.action_cable.url = "wss://example.com/cable"
 | |
|   # config.action_cable.allowed_request_origins = [ "http://example.com", /http:\/\/example.*/ ]
 | |
| 
 | |
|   # Assume all access to the app is happening through a SSL-terminating reverse proxy.
 | |
|   # Can be used together with config.force_ssl for Strict-Transport-Security and secure cookies.
 | |
|   # config.assume_ssl = true
 | |
| 
 | |
|   # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
 | |
|   config.force_ssl = true
 | |
| 
 | |
|   # Log to STDOUT by default
 | |
|   config.logger = ActiveSupport::Logger.new(STDOUT)
 | |
|     .tap  { |logger| logger.formatter = ::Logger::Formatter.new }
 | |
|     .then { |logger| ActiveSupport::TaggedLogging.new(logger) }
 | |
| 
 | |
|   # Prepend all log lines with the following tags.
 | |
|   config.log_tags = [ :request_id ]
 | |
| 
 | |
|   # "info" includes generic and useful information about system operation, but avoids logging too much
 | |
|   # information to avoid inadvertent exposure of personally identifiable information (PII). If you
 | |
|   # want to log everything, set the level to "debug".
 | |
|   config.log_level = ENV.fetch("RAILS_LOG_LEVEL", "info")
 | |
| 
 | |
|   # Use a different cache store in production.
 | |
|   # config.cache_store = :mem_cache_store
 | |
| 
 | |
|   # config.active_job.queue_name_prefix = "wedding_planner_production"
 | |
| 
 | |
|   config.action_mailer.perform_caching = false
 | |
|   config.action_mailer.delivery_method = :smtp
 | |
|   config.action_mailer.smtp_settings = begin
 | |
|     {
 | |
|       address: File.read("/run/secrets/smtp_address").strip,
 | |
|       port: File.read("/run/secrets/smtp_port").strip.to_i,
 | |
|       user_name: File.read("/run/secrets/smtp_user_name").strip,
 | |
|       password: File.read("/run/secrets/smtp_password").strip,
 | |
|       authentication: File.read("/run/secrets/smtp_authentication").strip.to_sym,
 | |
|       tls: true
 | |
|     }
 | |
|   rescue Errno::ENOENT
 | |
|     {}
 | |
|   end
 | |
| 
 | |
| 
 | |
|   # Ignore bad email addresses and do not raise email delivery errors.
 | |
|   # Set this to true and configure the email server for immediate delivery to raise delivery errors.
 | |
|   # config.action_mailer.raise_delivery_errors = false
 | |
| 
 | |
|   # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
 | |
|   # the I18n.default_locale when a translation cannot be found).
 | |
|   config.i18n.fallbacks = true
 | |
| 
 | |
|   # Don't log any deprecations.
 | |
|   config.active_support.report_deprecations = false
 | |
| 
 | |
|   # Do not dump schema after migrations.
 | |
|   config.active_record.dump_schema_after_migration = false
 | |
| 
 | |
|   # Enable DNS rebinding protection and other `Host` header attacks.
 | |
|   # config.hosts = [
 | |
|   #   "example.com",     # Allow requests from example.com
 | |
|   #   /.*\.example\.com/ # Allow requests from subdomains like `www.example.com`
 | |
|   # ]
 | |
| 
 | |
|   config.hosts << "app.libreweddingplanner.org"
 | |
|   Rails.application.routes.default_url_options[:host] = "app.libreweddingplanner.org"
 | |
| 
 | |
|   # Skip DNS rebinding protection for the default health check endpoint.
 | |
|   config.host_authorization = { exclude: ->(request) { request.path == "/up" } }
 | |
| end
 |