dryer-config 7.1.0 → 8.0.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 544f1ae9a3f4fc1ca6f8db135da6c84ef4037f51748f28320092a0f64e6d21ce
4
- data.tar.gz: 7bad8361981a43f151c5a5c9d2d1754df713a8122c981b4866d7a0a6429ae4a0
3
+ metadata.gz: 3089a32c00a953af578d467ebb8f8eb1fa721ca7515decbd6bb9c7c37395f3d2
4
+ data.tar.gz: d5e5ce985a8e98bf59979cf30ba6dde8ef790f0019946ca224e0761169418b15
5
5
  SHA512:
6
- metadata.gz: 70db039f17d65d4ccd0f7cfe337ab12e99361a07d129d0436712c48ebd06325d412f70a135cf0e11d11097c8739b51f61f0cd2406f4bdca15f9129c042c67f3f
7
- data.tar.gz: 9405afb279831775d4e71a8619cb7cd9934d4babdcf44961cd88ab76ff2e9eb4a054d938e77cb7e43df5337a847076c9215448eb352be206f7246baa577ff588
6
+ metadata.gz: 84ea5dab3735213b563e8113c9a930aad85e4eec20803bb6859d6566a987108c05805d082300205689c280f155762243951fa50527f11d18c9c91e0012ca593f
7
+ data.tar.gz: 87b9d38910b12dc0a4dab30c40140f307abed688e0e213f220796b28596cbaf9be1da719bcea4ff9d42ee5fa884aaa59c6cc7086e1db4bb02fe96b29a99cc893
data/.ruby-gemset CHANGED
@@ -1 +1 @@
1
- rails-7.1
1
+ rails-8.0
data/.ruby-version CHANGED
@@ -1 +1 @@
1
- ruby-3.2.2
1
+ ruby-3.3.6
data/MIT-LICENSE CHANGED
@@ -1,6 +1,4 @@
1
- The MIT License (MIT)
2
-
3
- Copyright (c) 2016-2023 Dittmar Krall (www.matiq.com)
1
+ Copyright (c) 2016-2024 Dittmar Krall (www.matiq.com)
4
2
 
5
3
  Permission is hereby granted, free of charge, to any person obtaining
6
4
  a copy of this software and associated documentation files (the
data/README.md CHANGED
@@ -1,6 +1,8 @@
1
1
  # DryerConfig
2
2
 
3
3
  [![Gem Version](https://badge.fury.io/rb/dryer-config.png)](http://badge.fury.io/rb/dryer-config)
4
+ [![GEM Downloads](https://img.shields.io/gem/dt/dryer-config?color=168AFE&logo=ruby&logoColor=FE1616)](https://rubygems.org/gems/dryer-config)
5
+ [![MIT License](https://img.shields.io/badge/license-MIT-blue.svg)](http://choosealicense.com/licenses/mit/)
4
6
 
5
7
  Contains most of the files of a pristine `rails new` `config` directories.
6
8
  They will be available to your application by
@@ -12,16 +14,16 @@ will contain just your particular requirements/options
12
14
 
13
15
  Version numbering is according to the Rails versions, e.g. use
14
16
 
15
- gem 'dryer-config', '= 6.0.0' # for a Rails 6.0.0 applications
17
+ gem 'dryer-config', '= 8.0.0' # for a Rails 8.0.0 applications
16
18
 
17
19
  or
18
20
 
19
- gem 'dryer-config', '~> 5.2' # expected to serve Rails 5.2.*
21
+ gem 'dryer-config', '~> 8.0' # expected to serve Rails 8.0.*
20
22
 
21
23
  in your `Gemfile`.
22
24
 
23
- It is expected that the version 7.0.0 is fine for the
24
- complete Rails 7 serie.
25
+ It is expected that the version 8.0.0 is fine for the
26
+ complete Rails 8 serie.
25
27
  If not, a new version of this gem will be released (hopefully).
26
28
 
27
29
  ## Why
@@ -43,10 +45,24 @@ less attention/work.
43
45
  As usual:
44
46
  ```ruby
45
47
  # Gemfile
46
- gem "dryer-config", "~> 7.1"
48
+ gem "dryer-config", "~> 8.0"
47
49
  ```
48
50
  and run `bundle install`.
49
51
 
52
+ ## Rails 8.0.0
53
+
54
+ See also "Configuration" below.
55
+
56
+ The following config file is obsolete:
57
+ ./config/initializers/permissions_policy.rb
58
+
59
+ ## Rails 7.2.1, 7.2.0
60
+
61
+ See also "Configuration" below.
62
+
63
+ The following config file is obsolete:
64
+ ./config/spring.rb
65
+
50
66
  ## Rails 7.1.0, 7.0.0, 6.0.0, 5.2.0
51
67
 
52
68
  See also "Configuration" below.
@@ -76,7 +92,6 @@ The following files may require your attention:
76
92
  ./config/cable.yml
77
93
  ./config/database.yml
78
94
  ./config/puma.rb
79
- ./config/spring.rb
80
95
  ./config/storage.yml
81
96
 
82
97
  Create/copy your owns. They are still there for inspection.
@@ -93,7 +108,5 @@ Create your own. It will run after the one from the gem.
93
108
 
94
109
  ## Miscellaneous
95
110
 
96
- Copyright (c) 2016-2023 Dittmar Krall (www.matiq.com),
97
- released under the MIT license:
98
-
99
- * https://opensource.org/licenses/MIT
111
+ Copyright (c) 2016-2024 Dittmar Krall (www.matiq.com),
112
+ released under the [MIT license](https://opensource.org/licenses/MIT).
data/config/cable.yml CHANGED
@@ -1,3 +1,7 @@
1
+ # Async adapter only works within the same process, so for manually triggering cable updates from a console,
2
+ # and seeing results in the browser, you must do so from the web console (running inside the dev process),
3
+ # not a terminal started via bin/rails console! Add "console" to any action or any ERB template view
4
+ # to make the web console appear.
1
5
  development:
2
6
  adapter: async
3
7
 
@@ -5,6 +9,9 @@ test:
5
9
  adapter: test
6
10
 
7
11
  production:
8
- adapter: redis
9
- url: <%= ENV.fetch("REDIS_URL") { "redis://localhost:6379/1" } %>
10
- channel_prefix: sample_7_1_0_production
12
+ adapter: solid_cable
13
+ connects_to:
14
+ database:
15
+ writing: cable
16
+ polling_interval: 0.1.seconds
17
+ message_retention: 1.day
data/config/database.yml CHANGED
@@ -20,6 +20,22 @@ test:
20
20
  <<: *default
21
21
  database: storage/test.sqlite3
22
22
 
23
+
24
+ # Store production database in the storage/ directory, which by default
25
+ # is mounted as a persistent Docker volume in config/deploy.yml.
23
26
  production:
24
- <<: *default
25
- database: storage/production.sqlite3
27
+ primary:
28
+ <<: *default
29
+ database: storage/production.sqlite3
30
+ cache:
31
+ <<: *default
32
+ database: storage/production_cache.sqlite3
33
+ migrations_paths: db/cache_migrate
34
+ queue:
35
+ <<: *default
36
+ database: storage/production_queue.sqlite3
37
+ migrations_paths: db/queue_migrate
38
+ cable:
39
+ <<: *default
40
+ database: storage/production_cable.sqlite3
41
+ migrations_paths: db/cable_migrate
@@ -3,9 +3,7 @@ require "active_support/core_ext/integer/time"
3
3
  Rails.application.configure do
4
4
  # Settings specified here will take precedence over those in config/application.rb.
5
5
 
6
- # In the development environment your application's code is reloaded any time
7
- # it changes. This slows down response time but is perfect for development
8
- # since you don't have to restart the web server when you make code changes.
6
+ # Make code changes take effect immediately without server restart.
9
7
  config.enable_reloading = true
10
8
 
11
9
  # Do not eager load code on boot.
@@ -14,63 +12,61 @@ Rails.application.configure do
14
12
  # Show full error reports.
15
13
  config.consider_all_requests_local = true
16
14
 
17
- # Enable server timing
15
+ # Enable server timing.
18
16
  config.server_timing = true
19
17
 
20
- # Enable/disable caching. By default caching is disabled.
21
- # Run rails dev:cache to toggle caching.
18
+ # Enable/disable Action Controller caching. By default Action Controller caching is disabled.
19
+ # Run rails dev:cache to toggle Action Controller caching.
22
20
  if Rails.root.join("tmp/caching-dev.txt").exist?
23
21
  config.action_controller.perform_caching = true
24
22
  config.action_controller.enable_fragment_cache_logging = true
25
-
26
- config.cache_store = :memory_store
27
- config.public_file_server.headers = {
28
- "Cache-Control" => "public, max-age=#{2.days.to_i}"
29
- }
23
+ config.public_file_server.headers = { "cache-control" => "public, max-age=#{2.days.to_i}" }
30
24
  else
31
25
  config.action_controller.perform_caching = false
32
-
33
- config.cache_store = :null_store
34
26
  end
35
27
 
28
+ # Change to :null_store to avoid any caching.
29
+ config.cache_store = :memory_store
30
+
36
31
  # Store uploaded files on the local file system (see config/storage.yml for options).
37
32
  config.active_storage.service = :local
38
33
 
39
34
  # Don't care if the mailer can't send.
40
35
  config.action_mailer.raise_delivery_errors = false
41
36
 
37
+ # Make template changes take effect immediately.
42
38
  config.action_mailer.perform_caching = false
43
39
 
40
+ # Set localhost to be used by links generated in mailer templates.
41
+ config.action_mailer.default_url_options = { host: "localhost", port: 3000 }
42
+
44
43
  # Print deprecation notices to the Rails logger.
45
44
  config.active_support.deprecation = :log
46
45
 
47
- # Raise exceptions for disallowed deprecations.
48
- config.active_support.disallowed_deprecation = :raise
49
-
50
- # Tell Active Support which deprecation messages to disallow.
51
- config.active_support.disallowed_deprecation_warnings = []
52
-
53
46
  # Raise an error on page load if there are pending migrations.
54
47
  config.active_record.migration_error = :page_load
55
48
 
56
49
  # Highlight code that triggered database queries in logs.
57
50
  config.active_record.verbose_query_logs = true
58
51
 
52
+ # Append comments with runtime information tags to SQL queries in logs.
53
+ config.active_record.query_log_tags_enabled = true
54
+
59
55
  # Highlight code that enqueued background job in logs.
60
56
  config.active_job.verbose_enqueue_logs = true
61
57
 
62
- # Suppress logger output for asset requests.
63
- config.assets.quiet = true
64
-
65
58
  # Raises error for missing translations.
66
59
  # config.i18n.raise_on_missing_translations = true
67
60
 
68
61
  # Annotate rendered view with file names.
69
- # config.action_view.annotate_rendered_view_with_filenames = true
62
+ config.action_view.annotate_rendered_view_with_filenames = true
70
63
 
71
64
  # Uncomment if you wish to allow Action Cable access from any origin.
72
65
  # config.action_cable.disable_request_forgery_protection = true
73
66
 
74
- # Raise error when a before_action's only/except options reference missing actions
67
+ # Raise error when a before_action's only/except options reference missing actions.
75
68
  config.action_controller.raise_on_missing_callback_actions = true
69
+
70
+ # Apply autocorrection by RuboCop to files generated by `bin/rails generate`.
71
+ # config.generators.apply_rubocop_autocorrect_after_generate!
76
72
  end
@@ -6,92 +6,86 @@ Rails.application.configure do
6
6
  # Code is not reloaded between requests.
7
7
  config.enable_reloading = false
8
8
 
9
- # Eager load code on boot. This eager loads most of Rails and
10
- # your application in memory, allowing both threaded web servers
11
- # and those relying on copy on write to perform better.
12
- # Rake tasks automatically ignore this option for performance.
9
+ # Eager load code on boot for better performance and memory savings (ignored by Rake tasks).
13
10
  config.eager_load = true
14
11
 
15
- # Full error reports are disabled and caching is turned on.
16
- config.consider_all_requests_local = false
17
- config.action_controller.perform_caching = true
18
-
19
- # Ensures that a master key has been made available in ENV["RAILS_MASTER_KEY"], config/master.key, or an environment
20
- # key such as config/credentials/production.key. This key is used to decrypt credentials (and other encrypted files).
21
- # config.require_master_key = true
12
+ # Full error reports are disabled.
13
+ config.consider_all_requests_local = false
22
14
 
23
- # Enable static file serving from the `/public` folder (turn off if using NGINX/Apache for it).
24
- config.public_file_server.enabled = true
25
-
26
- # Compress CSS using a preprocessor.
27
- # config.assets.css_compressor = :sass
15
+ # Turn on fragment caching in view templates.
16
+ config.action_controller.perform_caching = true
28
17
 
29
- # Do not fallback to assets pipeline if a precompiled asset is missed.
30
- config.assets.compile = false
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}" }
31
20
 
32
21
  # Enable serving of images, stylesheets, and JavaScripts from an asset server.
33
22
  # config.asset_host = "http://assets.example.com"
34
23
 
35
- # Specifies the header that your server uses for sending files.
36
- # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for Apache
37
- # config.action_dispatch.x_sendfile_header = "X-Accel-Redirect" # for NGINX
38
-
39
24
  # Store uploaded files on the local file system (see config/storage.yml for options).
40
25
  config.active_storage.service = :local
41
26
 
42
- # Mount Action Cable outside main process or domain.
43
- # config.action_cable.mount_path = nil
44
- # config.action_cable.url = "wss://example.com/cable"
45
- # config.action_cable.allowed_request_origins = [ "http://example.com", /http:\/\/example.*/ ]
46
-
47
27
  # Assume all access to the app is happening through a SSL-terminating reverse proxy.
48
- # Can be used together with config.force_ssl for Strict-Transport-Security and secure cookies.
49
- # config.assume_ssl = true
28
+ config.assume_ssl = true
50
29
 
51
30
  # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
52
31
  config.force_ssl = true
53
32
 
54
- # Log to STDOUT by default
55
- config.logger = ActiveSupport::Logger.new(STDOUT)
56
- .tap { |logger| logger.formatter = ::Logger::Formatter.new }
57
- .then { |logger| ActiveSupport::TaggedLogging.new(logger) }
33
+ # Skip http-to-https redirect for the default health check endpoint.
34
+ # config.ssl_options = { redirect: { exclude: ->(request) { request.path == "/up" } } }
58
35
 
59
- # Prepend all log lines with the following tags.
36
+ # Log to STDOUT with the current request id as a default log tag.
60
37
  config.log_tags = [ :request_id ]
38
+ config.logger = ActiveSupport::TaggedLogging.logger(STDOUT)
61
39
 
62
- # Info include generic and useful information about system operation, but avoids logging too much
63
- # information to avoid inadvertent exposure of personally identifiable information (PII). If you
64
- # want to log everything, set the level to "debug".
40
+ # Change to "debug" to log everything (including potentially personally-identifiable information!)
65
41
  config.log_level = ENV.fetch("RAILS_LOG_LEVEL", "info")
66
42
 
67
- # Use a different cache store in production.
68
- # config.cache_store = :mem_cache_store
43
+ # Prevent health checks from clogging up the logs.
44
+ config.silence_healthcheck_path = "/up"
45
+
46
+ # Don't log any deprecations.
47
+ config.active_support.report_deprecations = false
48
+
49
+ # Replace the default in-process memory cache store with a durable alternative.
50
+ config.cache_store = :solid_cache_store
69
51
 
70
- # Use a real queuing backend for Active Job (and separate queues per environment).
71
- # config.active_job.queue_adapter = :resque
72
- # config.active_job.queue_name_prefix = "sample_7_1_0_production"
52
+ # Replace the default in-process and non-durable queuing backend for Active Job.
53
+ config.active_job.queue_adapter = :solid_queue
54
+ config.solid_queue.connects_to = { database: { writing: :queue } }
73
55
 
74
- config.action_mailer.perform_caching = false
75
56
 
76
57
  # Ignore bad email addresses and do not raise email delivery errors.
77
58
  # Set this to true and configure the email server for immediate delivery to raise delivery errors.
78
59
  # config.action_mailer.raise_delivery_errors = false
79
60
 
61
+ # Set host to be used by links generated in mailer templates.
62
+ config.action_mailer.default_url_options = { host: "example.com" }
63
+
64
+ # Specify outgoing SMTP server. Remember to add smtp/* credentials via rails credentials:edit.
65
+ # config.action_mailer.smtp_settings = {
66
+ # user_name: Rails.application.credentials.dig(:smtp, :user_name),
67
+ # password: Rails.application.credentials.dig(:smtp, :password),
68
+ # address: "smtp.example.com",
69
+ # port: 587,
70
+ # authentication: :plain
71
+ # }
72
+
80
73
  # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
81
74
  # the I18n.default_locale when a translation cannot be found).
82
75
  config.i18n.fallbacks = true
83
76
 
84
- # Don't log any deprecations.
85
- config.active_support.report_deprecations = false
86
-
87
77
  # Do not dump schema after migrations.
88
78
  config.active_record.dump_schema_after_migration = false
89
79
 
80
+ # Only use :id for inspections in production.
81
+ config.active_record.attributes_for_inspect = [ :id ]
82
+
90
83
  # Enable DNS rebinding protection and other `Host` header attacks.
91
84
  # config.hosts = [
92
85
  # "example.com", # Allow requests from example.com
93
86
  # /.*\.example\.com/ # Allow requests from subdomains like `www.example.com`
94
87
  # ]
88
+ #
95
89
  # Skip DNS rebinding protection for the default health check endpoint.
96
90
  # config.host_authorization = { exclude: ->(request) { request.path == "/up" } }
97
91
  end
@@ -1,5 +1,3 @@
1
- require "active_support/core_ext/integer/time"
2
-
3
1
  # The test environment is used exclusively to run your application's
4
2
  # test suite. You never need to work with it otherwise. Remember that
5
3
  # your test database is "scratch space" for the test suite and is wiped
@@ -17,18 +15,14 @@ Rails.application.configure do
17
15
  # loading is working properly before deploying your code.
18
16
  config.eager_load = ENV["CI"].present?
19
17
 
20
- # Configure public file server for tests with Cache-Control for performance.
21
- config.public_file_server.enabled = true
22
- config.public_file_server.headers = {
23
- "Cache-Control" => "public, max-age=#{1.hour.to_i}"
24
- }
18
+ # Configure public file server for tests with cache-control for performance.
19
+ config.public_file_server.headers = { "cache-control" => "public, max-age=3600" }
25
20
 
26
- # Show full error reports and disable caching.
27
- config.consider_all_requests_local = true
28
- config.action_controller.perform_caching = false
21
+ # Show full error reports.
22
+ config.consider_all_requests_local = true
29
23
  config.cache_store = :null_store
30
24
 
31
- # Raise exceptions instead of rendering exception templates.
25
+ # Render exception templates for rescuable exceptions and raise for other exceptions.
32
26
  config.action_dispatch.show_exceptions = :rescuable
33
27
 
34
28
  # Disable request forgery protection in test environment.
@@ -37,28 +31,23 @@ Rails.application.configure do
37
31
  # Store uploaded files on the local file system in a temporary directory.
38
32
  config.active_storage.service = :test
39
33
 
40
- config.action_mailer.perform_caching = false
41
-
42
34
  # Tell Action Mailer not to deliver emails to the real world.
43
35
  # The :test delivery method accumulates sent emails in the
44
36
  # ActionMailer::Base.deliveries array.
45
37
  config.action_mailer.delivery_method = :test
46
38
 
39
+ # Set host to be used by links generated in mailer templates.
40
+ config.action_mailer.default_url_options = { host: "example.com" }
41
+
47
42
  # Print deprecation notices to the stderr.
48
43
  config.active_support.deprecation = :stderr
49
44
 
50
- # Raise exceptions for disallowed deprecations.
51
- config.active_support.disallowed_deprecation = :raise
52
-
53
- # Tell Active Support which deprecation messages to disallow.
54
- config.active_support.disallowed_deprecation_warnings = []
55
-
56
45
  # Raises error for missing translations.
57
46
  # config.i18n.raise_on_missing_translations = true
58
47
 
59
48
  # Annotate rendered view with file names.
60
49
  # config.action_view.annotate_rendered_view_with_filenames = true
61
50
 
62
- # Raise error when a before_action's only/except options reference missing actions
51
+ # Raise error when a before_action's only/except options reference missing actions.
63
52
  config.action_controller.raise_on_missing_callback_actions = true
64
53
  end
data/config/importmap.rb CHANGED
@@ -1,7 +1,7 @@
1
1
  # Pin npm packages by running ./bin/importmap
2
2
 
3
- pin "application", preload: true
4
- pin "@hotwired/turbo-rails", to: "turbo.min.js", preload: true
5
- pin "@hotwired/stimulus", to: "stimulus.min.js", preload: true
6
- pin "@hotwired/stimulus-loading", to: "stimulus-loading.js", preload: true
3
+ pin "application"
4
+ pin "@hotwired/turbo-rails", to: "turbo.min.js"
5
+ pin "@hotwired/stimulus", to: "stimulus.min.js"
6
+ pin "@hotwired/stimulus-loading", to: "stimulus-loading.js"
7
7
  pin_all_from "app/javascript/controllers", under: "controllers"
@@ -5,8 +5,3 @@ Rails.application.config.assets.version = "1.0"
5
5
 
6
6
  # Add additional assets to the asset load path.
7
7
  # Rails.application.config.assets.paths << Emoji.images_path
8
-
9
- # Precompile additional assets.
10
- # application.js, application.css, and all non-JS/CSS in the app/assets
11
- # folder are already added.
12
- # Rails.application.config.assets.precompile += %w( admin.js admin.css )
@@ -1,8 +1,8 @@
1
1
  # Be sure to restart your server when you modify this file.
2
2
 
3
- # Configure parameters to be partially matched (e.g. passw matches password) and filtered from the log file.
4
- # Use this to limit dissemination of sensitive information.
3
+ # Configure parameters to be partially matched (e.g. passw matches password) and filtered from the log file.
4
+ # Use this to limit dissemination of sensitive information.
5
5
  # See the ActiveSupport::ParameterFilter documentation for supported notations and behaviors.
6
6
  Rails.application.config.filter_parameters += [
7
- :passw, :secret, :token, :_key, :crypt, :salt, :certificate, :otp, :ssn
7
+ :passw, :email, :secret, :token, :_key, :crypt, :salt, :certificate, :otp, :ssn, :cvv, :cvc
8
8
  ]
data/config/puma.rb CHANGED
@@ -1,35 +1,41 @@
1
1
  # This configuration file will be evaluated by Puma. The top-level methods that
2
2
  # are invoked here are part of Puma's configuration DSL. For more information
3
3
  # about methods provided by the DSL, see https://puma.io/puma/Puma/DSL.html.
4
-
5
- # Puma can serve each request in a thread from an internal thread pool.
6
- # The `threads` method setting takes two numbers: a minimum and maximum.
7
- # Any libraries that use thread pools should be configured to match
8
- # the maximum value specified for Puma. Default is set to 5 threads for minimum
9
- # and maximum; this matches the default thread size of Active Record.
10
- max_threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }
11
- min_threads_count = ENV.fetch("RAILS_MIN_THREADS") { max_threads_count }
12
- threads min_threads_count, max_threads_count
13
-
14
- # Specifies that the worker count should equal the number of processors in production.
15
- if ENV["RAILS_ENV"] == "production"
16
- require "concurrent-ruby"
17
- worker_count = Integer(ENV.fetch("WEB_CONCURRENCY") { Concurrent.physical_processor_count })
18
- workers worker_count if worker_count > 1
19
- end
20
-
21
- # Specifies the `worker_timeout` threshold that Puma will use to wait before
22
- # terminating a worker in development environments.
23
- worker_timeout 3600 if ENV.fetch("RAILS_ENV", "development") == "development"
4
+ #
5
+ # Puma starts a configurable number of processes (workers) and each process
6
+ # serves each request in a thread from an internal thread pool.
7
+ #
8
+ # You can control the number of workers using ENV["WEB_CONCURRENCY"]. You
9
+ # should only set this value when you want to run 2 or more workers. The
10
+ # default is already 1.
11
+ #
12
+ # The ideal number of threads per worker depends both on how much time the
13
+ # application spends waiting for IO operations and on how much you wish to
14
+ # prioritize throughput over latency.
15
+ #
16
+ # As a rule of thumb, increasing the number of threads will increase how much
17
+ # traffic a given process can handle (throughput), but due to CRuby's
18
+ # Global VM Lock (GVL) it has diminishing returns and will degrade the
19
+ # response time (latency) of the application.
20
+ #
21
+ # The default is set to 3 threads as it's deemed a decent compromise between
22
+ # throughput and latency for the average Rails application.
23
+ #
24
+ # Any libraries that use a connection pool or another resource pool should
25
+ # be configured to provide at least as many connections as the number of
26
+ # threads. This includes Active Record's `pool` parameter in `database.yml`.
27
+ threads_count = ENV.fetch("RAILS_MAX_THREADS", 3)
28
+ threads threads_count, threads_count
24
29
 
25
30
  # Specifies the `port` that Puma will listen on to receive requests; default is 3000.
26
- port ENV.fetch("PORT") { 3000 }
27
-
28
- # Specifies the `environment` that Puma will run in.
29
- environment ENV.fetch("RAILS_ENV") { "development" }
30
-
31
- # Specifies the `pidfile` that Puma will use.
32
- pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" }
31
+ port ENV.fetch("PORT", 3000)
33
32
 
34
33
  # Allow puma to be restarted by `bin/rails restart` command.
35
34
  plugin :tmp_restart
35
+
36
+ # Run the Solid Queue supervisor inside of Puma for single-server deployments
37
+ plugin :solid_queue if ENV["SOLID_QUEUE_IN_PUMA"]
38
+
39
+ # Specify the PID file. Defaults to tmp/pids/server.pid in development.
40
+ # In other environments, only set the PID file if requested.
41
+ pidfile ENV["PIDFILE"] if ENV["PIDFILE"]
@@ -1,9 +1,11 @@
1
1
  module DryerConfig
2
- VERSION = '7.1.0' # 2023-10-15
3
- # VERSION = '7.0.0' # 2021-12-18
4
- # VERSION = '6.1.4' # 2021-06-27
5
- # VERSION = '6.0.3' # 2020-05-08
6
- # VERSION = '6.0.2' # 2020-02-25
7
- # VERSION = '6.0.0' # 2019-10-07
8
- # VERSION = '5.2.0'
2
+ VERSION = '8.0.0' # 2024-11-08
3
+ # VERSION = '7.2.0' # 2024-08-23
4
+ # VERSION = '7.1.0' # 2023-10-15
5
+ # VERSION = '7.0.0' # 2021-12-18
6
+ # VERSION = '6.1.4' # 2021-06-27
7
+ # VERSION = '6.0.3' # 2020-05-08
8
+ # VERSION = '6.0.2' # 2020-02-25
9
+ # VERSION = '6.0.0' # 2019-10-07
10
+ # VERSION = '5.2.0'
9
11
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: dryer-config
3
3
  version: !ruby/object:Gem::Version
4
- version: 7.1.0
4
+ version: 8.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Dittmar Krall
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-10-15 00:00:00.000000000 Z
11
+ date: 2024-11-08 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -50,7 +50,6 @@ files:
50
50
  - config/initializers/content_security_policy.rb
51
51
  - config/initializers/filter_parameter_logging.rb
52
52
  - config/initializers/inflections.rb
53
- - config/initializers/permissions_policy.rb
54
53
  - config/puma.rb
55
54
  - config/storage.yml
56
55
  - dryer-config.gemspec
@@ -61,7 +60,7 @@ homepage: https://github.com/matique/dryer-config
61
60
  licenses:
62
61
  - MIT
63
62
  metadata: {}
64
- post_install_message:
63
+ post_install_message:
65
64
  rdoc_options: []
66
65
  require_paths:
67
66
  - lib
@@ -76,8 +75,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
76
75
  - !ruby/object:Gem::Version
77
76
  version: '0'
78
77
  requirements: []
79
- rubygems_version: 3.4.20
80
- signing_key:
78
+ rubygems_version: 3.5.22
79
+ signing_key:
81
80
  specification_version: 4
82
81
  summary: Several pristine Rails config files.
83
82
  test_files: []
@@ -1,13 +0,0 @@
1
- # Be sure to restart your server when you modify this file.
2
-
3
- # Define an application-wide HTTP permissions policy. For further
4
- # information see: https://developers.google.com/web/updates/2018/06/feature-policy
5
-
6
- # Rails.application.config.permissions_policy do |policy|
7
- # policy.camera :none
8
- # policy.gyroscope :none
9
- # policy.microphone :none
10
- # policy.usb :none
11
- # policy.fullscreen :self
12
- # policy.payment :self, "https://secure.example.com"
13
- # end