Class: Rails::Application::Configuration

Inherits:
Engine::Configuration show all
Defined in:
lib/rails/application/configuration.rb

Defined Under Namespace

Classes: Custom

Instance Attribute Summary collapse

Attributes inherited from Engine::Configuration

#autoload_once_paths, #autoload_paths, #eager_load_paths, #javascript_path, #middleware, #root

Instance Method Summary collapse

Methods inherited from Engine::Configuration

#generators

Methods inherited from Railtie::Configuration

#after_initialize, #app_generators, #app_middleware, #before_configuration, #before_eager_load, #before_initialize, eager_load_namespaces, #eager_load_namespaces, #respond_to?, #to_prepare, #to_prepare_blocks, #watchable_dirs, #watchable_files

Constructor Details

#initializeConfiguration

Returns a new instance of Configuration.



29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
# File 'lib/rails/application/configuration.rb', line 29

def initialize(*)
  super
  self.encoding                            = Encoding::UTF_8
  @allow_concurrency                       = nil
  @consider_all_requests_local             = false
  @filter_parameters                       = []
  @filter_redirect                         = []
  @helpers_paths                           = []
  if Rails.env.development?
    @hosts = ActionDispatch::HostAuthorization::ALLOWED_HOSTS_IN_DEVELOPMENT.dup
  else
    @hosts = []
  end
  @host_authorization                      = {}
  @public_file_server                      = ActiveSupport::OrderedOptions.new
  @public_file_server.enabled              = true
  @public_file_server.index_name           = "index"
  @force_ssl                               = false
  @ssl_options                             = {}
  @session_store                           = nil
  @time_zone                               = "UTC"
  @beginning_of_week                       = :monday
  @log_level                               = :debug
  @generators                              = app_generators
  @cache_store                             = [ :file_store, "#{root}/tmp/cache/" ]
  @railties_order                          = [:all]
  @relative_url_root                       = ENV["RAILS_RELATIVE_URL_ROOT"]
  @reload_classes_only_on_change           = true
  @file_watcher                            = ActiveSupport::FileUpdateChecker
  @exceptions_app                          = nil
  @autoflush_log                           = true
  @log_formatter                           = ActiveSupport::Logger::SimpleFormatter.new
  @eager_load                              = nil
  @secret_key_base                         = nil
  @api_only                                = false
  @debug_exception_response_format         = nil
  @x                                       = Custom.new
  @enable_dependency_loading               = false
  @read_encrypted_secrets                  = false
  @content_security_policy                 = nil
  @content_security_policy_report_only     = false
  @content_security_policy_nonce_generator = nil
  @content_security_policy_nonce_directives = nil
  @require_master_key                      = false
  @loaded_config_version                   = nil
  @credentials                             = ActiveSupport::OrderedOptions.new
  @credentials.content_path                = default_credentials_content_path
  @credentials.key_path                    = default_credentials_key_path
  @autoloader                              = :classic
  @disable_sandbox                         = false
  @add_autoload_paths_to_load_path         = true
  @permissions_policy                      = nil
  @rake_eager_load                         = false
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class Rails::Railtie::Configuration

Instance Attribute Details

#add_autoload_paths_to_load_pathObject

Returns the value of attribute add_autoload_paths_to_load_path.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def add_autoload_paths_to_load_path
  @add_autoload_paths_to_load_path
end

#allow_concurrencyObject

Returns the value of attribute allow_concurrency.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def allow_concurrency
  @allow_concurrency
end

#api_onlyObject

Returns the value of attribute api_only.



27
28
29
# File 'lib/rails/application/configuration.rb', line 27

def api_only
  @api_only
end

#asset_hostObject

Returns the value of attribute asset_host.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def asset_host
  @asset_host
end

#autoflush_logObject

Returns the value of attribute autoflush_log.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def autoflush_log
  @autoflush_log
end

#autoloaderObject

Returns the value of attribute autoloader.



27
28
29
# File 'lib/rails/application/configuration.rb', line 27

def autoloader
  @autoloader
end

#beginning_of_weekObject

Returns the value of attribute beginning_of_week.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def beginning_of_week
  @beginning_of_week
end

#cache_classesObject

Returns the value of attribute cache_classes.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def cache_classes
  @cache_classes
end

#cache_storeObject

Returns the value of attribute cache_store.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def cache_store
  @cache_store
end

#consider_all_requests_localObject

Returns the value of attribute consider_all_requests_local.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def consider_all_requests_local
  @consider_all_requests_local
end

#consoleObject

Returns the value of attribute console.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def console
  @console
end

#content_security_policy_nonce_directivesObject

Returns the value of attribute content_security_policy_nonce_directives.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def content_security_policy_nonce_directives
  @content_security_policy_nonce_directives
end

#content_security_policy_nonce_generatorObject

Returns the value of attribute content_security_policy_nonce_generator.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def content_security_policy_nonce_generator
  @content_security_policy_nonce_generator
end

#content_security_policy_report_onlyObject

Returns the value of attribute content_security_policy_report_only.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def content_security_policy_report_only
  @content_security_policy_report_only
end

#credentialsObject

Returns the value of attribute credentials.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def credentials
  @credentials
end

#debug_exception_response_formatObject



230
231
232
# File 'lib/rails/application/configuration.rb', line 230

def debug_exception_response_format
  @debug_exception_response_format || :default
end

#disable_sandboxObject

Returns the value of attribute disable_sandbox.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def disable_sandbox
  @disable_sandbox
end

#eager_loadObject

Returns the value of attribute eager_load.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def eager_load
  @eager_load
end

#enable_dependency_loadingObject

Returns the value of attribute enable_dependency_loading.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def enable_dependency_loading
  @enable_dependency_loading
end

#encodingObject

Returns the value of attribute encoding.



27
28
29
# File 'lib/rails/application/configuration.rb', line 27

def encoding
  @encoding
end

#exceptions_appObject

Returns the value of attribute exceptions_app.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def exceptions_app
  @exceptions_app
end

#file_watcherObject

Returns the value of attribute file_watcher.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def file_watcher
  @file_watcher
end

#filter_parametersObject

Returns the value of attribute filter_parameters.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def filter_parameters
  @filter_parameters
end

#filter_redirectObject

Returns the value of attribute filter_redirect.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def filter_redirect
  @filter_redirect
end

#force_sslObject

Returns the value of attribute force_ssl.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def force_ssl
  @force_ssl
end

#helpers_pathsObject

Returns the value of attribute helpers_paths.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def helpers_paths
  @helpers_paths
end

#host_authorizationObject

Returns the value of attribute host_authorization.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def host_authorization
  @host_authorization
end

#hostsObject

Returns the value of attribute hosts.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def hosts
  @hosts
end

#loaded_config_versionObject (readonly)

Returns the value of attribute loaded_config_version.



27
28
29
# File 'lib/rails/application/configuration.rb', line 27

def loaded_config_version
  @loaded_config_version
end

#log_formatterObject

Returns the value of attribute log_formatter.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def log_formatter
  @log_formatter
end

#log_levelObject

Returns the value of attribute log_level.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def log_level
  @log_level
end

#log_tagsObject

Returns the value of attribute log_tags.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def log_tags
  @log_tags
end

#loggerObject

Returns the value of attribute logger.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def logger
  @logger
end

#public_file_serverObject

Returns the value of attribute public_file_server.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def public_file_server
  @public_file_server
end

#railties_orderObject

Returns the value of attribute railties_order.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def railties_order
  @railties_order
end

#rake_eager_loadObject

Returns the value of attribute rake_eager_load.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def rake_eager_load
  @rake_eager_load
end

#read_encrypted_secretsObject

Returns the value of attribute read_encrypted_secrets.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def read_encrypted_secrets
  @read_encrypted_secrets
end

#relative_url_rootObject

Returns the value of attribute relative_url_root.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def relative_url_root
  @relative_url_root
end

#reload_classes_only_on_changeObject

Returns the value of attribute reload_classes_only_on_change.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def reload_classes_only_on_change
  @reload_classes_only_on_change
end

#require_master_keyObject

Returns the value of attribute require_master_key.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def require_master_key
  @require_master_key
end

#secret_key_baseObject

Returns the value of attribute secret_key_base.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def secret_key_base
  @secret_key_base
end

#session_optionsObject

Returns the value of attribute session_options.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def session_options
  @session_options
end

#ssl_optionsObject

Returns the value of attribute ssl_options.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def ssl_options
  @ssl_options
end

#time_zoneObject

Returns the value of attribute time_zone.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def time_zone
  @time_zone
end

#xObject

Returns the value of attribute x.



14
15
16
# File 'lib/rails/application/configuration.rb', line 14

def x
  @x
end

Instance Method Details

#annotationsObject



342
343
344
# File 'lib/rails/application/configuration.rb', line 342

def annotations
  Rails::SourceAnnotationExtractor::Annotation
end

#colorize_loggingObject



302
303
304
# File 'lib/rails/application/configuration.rb', line 302

def colorize_logging
  ActiveSupport::LogSubscriber.colorize_logging
end

#colorize_logging=(val) ⇒ Object



306
307
308
309
# File 'lib/rails/application/configuration.rb', line 306

def colorize_logging=(val)
  ActiveSupport::LogSubscriber.colorize_logging = val
  generators.colorize_logging = val
end

#content_security_policy(&block) ⇒ Object



346
347
348
349
350
351
352
# File 'lib/rails/application/configuration.rb', line 346

def content_security_policy(&block)
  if block_given?
    @content_security_policy = ActionDispatch::ContentSecurityPolicy.new(&block)
  else
    @content_security_policy
  end
end

#database_configurationObject

Loads and returns the entire raw configuration of database from values stored in config/database.yml.



277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
# File 'lib/rails/application/configuration.rb', line 277

def database_configuration
  path = paths["config/database"].existent.first
  yaml = Pathname.new(path) if path

  config = if yaml&.exist?
    loaded_yaml = ActiveSupport::ConfigurationFile.parse(yaml)
    if (shared = loaded_yaml.delete("shared"))
      loaded_yaml.each do |_k, values|
        values.reverse_merge!(shared)
      end
    end
    Hash.new(shared).merge(loaded_yaml)
  elsif ENV["DATABASE_URL"]
    # Value from ENV['DATABASE_URL'] is set to default database connection
    # by Active Record.
    {}
  else
    raise "Could not load database configuration. No such file - #{paths["config/database"].instance_variable_get(:@paths)}"
  end

  config
rescue => e
  raise e, "Cannot load database configuration:\n#{e.message}", e.backtrace
end

#default_log_fileObject



374
375
376
377
378
379
380
381
382
383
384
# File 'lib/rails/application/configuration.rb', line 374

def default_log_file
  path = paths["log"].first
  unless File.exist? File.dirname path
    FileUtils.mkdir_p File.dirname path
  end

  f = File.open path, "a"
  f.binmode
  f.sync = autoflush_log # if true make sure every write flushes
  f
end

#load_database_yamlObject

Load the database YAML without evaluating ERB. This allows us to create the rake tasks for multiple databases without filling in the configuration values or loading the environment. Do not use this method.

This uses a DummyERB custom compiler so YAML can ignore the ERB tags and load the database.yml for the rake tasks.



259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
# File 'lib/rails/application/configuration.rb', line 259

def load_database_yaml # :nodoc:
  if path = paths["config/database"].existent.first
    require "rails/application/dummy_erb_compiler"

    yaml = DummyERB.new(Pathname.new(path).read).result

    if YAML.respond_to?(:unsafe_load)
      YAML.unsafe_load(yaml) || {}
    else
      YAML.load(yaml) || {}
    end
  else
    {}
  end
end

#load_defaults(target_version) ⇒ Object

Loads default configurations. See the result of the method for each version.



85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
# File 'lib/rails/application/configuration.rb', line 85

def load_defaults(target_version)
  case target_version.to_s
  when "5.0"
    if respond_to?(:action_controller)
      action_controller.per_form_csrf_tokens = true
      action_controller.forgery_protection_origin_check = true
    end

    ActiveSupport.to_time_preserves_timezone = true

    if respond_to?(:active_record)
      active_record.belongs_to_required_by_default = true
    end

    self.ssl_options = { hsts: { subdomains: true } }
  when "5.1"
    load_defaults "5.0"

    if respond_to?(:assets)
      assets.unknown_asset_fallback = false
    end

    if respond_to?(:action_view)
      action_view.form_with_generates_remote_forms = true
    end
  when "5.2"
    load_defaults "5.1"

    if respond_to?(:active_record)
      active_record.cache_versioning = true
    end

    if respond_to?(:action_dispatch)
      action_dispatch.use_authenticated_cookie_encryption = true
    end

    if respond_to?(:active_support)
      active_support.use_authenticated_message_encryption = true
      active_support.hash_digest_class = ::Digest::SHA1
    end

    if respond_to?(:action_controller)
      action_controller.default_protect_from_forgery = true
    end

    if respond_to?(:action_view)
      action_view.form_with_generates_ids = true
    end
  when "6.0"
    load_defaults "5.2"

    self.autoloader = :zeitwerk if RUBY_ENGINE == "ruby"

    if respond_to?(:action_view)
      action_view.default_enforce_utf8 = false
    end

    if respond_to?(:action_dispatch)
      action_dispatch. = true
    end

    if respond_to?(:action_mailer)
      action_mailer.delivery_job = "ActionMailer::MailDeliveryJob"
    end

    if respond_to?(:active_storage)
      active_storage.queues.analysis = :active_storage_analysis
      active_storage.queues.purge    = :active_storage_purge

      active_storage.replace_on_assign_to_many = true
    end

    if respond_to?(:active_record)
      active_record.collection_cache_versioning = true
    end
  when "6.1"
    load_defaults "6.0"

    self.autoloader = :zeitwerk if %w[ruby truffleruby].include?(RUBY_ENGINE)

    if respond_to?(:active_record)
      active_record.has_many_inversing = true
      active_record.legacy_connection_handling = false
    end

    if respond_to?(:active_storage)
      active_storage.track_variants = true
    end

    if respond_to?(:active_job)
      active_job.retry_jitter = 0.15
      active_job.skip_after_callbacks_if_terminated = true
    end

    if respond_to?(:action_dispatch)
      action_dispatch.cookies_same_site_protection = :lax
      action_dispatch.ssl_default_redirect_status = 308
    end

    if respond_to?(:action_controller)
      action_controller.urlsafe_csrf_tokens = true
    end

    if respond_to?(:action_view)
      action_view.form_with_generates_remote_forms = false
      action_view.preload_links_header = true
    end

    if respond_to?(:active_storage)
      active_storage.queues.analysis = nil
      active_storage.queues.purge = nil
    end

    if respond_to?(:action_mailbox)
      action_mailbox.queues.incineration = nil
      action_mailbox.queues.routing = nil
    end

    if respond_to?(:action_mailer)
      action_mailer.deliver_later_queue_name = nil
    end

    ActiveSupport.utc_to_local_returns_utc_offset_times = true
  else
    raise "Unknown version #{target_version.to_s.inspect}"
  end

  @loaded_config_version = target_version
end

#pathsObject



236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
# File 'lib/rails/application/configuration.rb', line 236

def paths
  @paths ||= begin
    paths = super
    paths.add "config/database",    with: "config/database.yml"
    paths.add "config/secrets",     with: "config", glob: "secrets.yml{,.enc}"
    paths.add "config/environment", with: "config/environment.rb"
    paths.add "lib/templates"
    paths.add "log",                with: "log/#{Rails.env}.log"
    paths.add "public"
    paths.add "public/javascripts"
    paths.add "public/stylesheets"
    paths.add "tmp"
    paths
  end
end

#permissions_policy(&block) ⇒ Object



354
355
356
357
358
359
360
# File 'lib/rails/application/configuration.rb', line 354

def permissions_policy(&block)
  if block_given?
    @permissions_policy = ActionDispatch::PermissionsPolicy.new(&block)
  else
    @permissions_policy
  end
end

#session_store(new_session_store = nil, **options) ⇒ Object



311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
# File 'lib/rails/application/configuration.rb', line 311

def session_store(new_session_store = nil, **options)
  if new_session_store
    if new_session_store == :active_record_store
      begin
        ActionDispatch::Session::ActiveRecordStore
      rescue NameError
        raise "`ActiveRecord::SessionStore` is extracted out of Rails into a gem. " \
          "Please add `activerecord-session_store` to your Gemfile to use it."
      end
    end

    @session_store = new_session_store
    @session_options = options || {}
  else
    case @session_store
    when :disabled
      nil
    when :active_record_store
      ActionDispatch::Session::ActiveRecordStore
    when Symbol
      ActionDispatch::Session.const_get(@session_store.to_s.camelize)
    else
      @session_store
    end
  end
end

#session_store?Boolean

:nodoc:

Returns:

  • (Boolean)


338
339
340
# File 'lib/rails/application/configuration.rb', line 338

def session_store? #:nodoc:
  @session_store
end