actionpack 7.0.8.7 → 7.1.0.beta1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of actionpack might be problematic. Click here for more details.

Files changed (135) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +318 -432
  3. data/MIT-LICENSE +1 -1
  4. data/README.rdoc +2 -2
  5. data/lib/abstract_controller/base.rb +19 -10
  6. data/lib/abstract_controller/caching/fragments.rb +2 -0
  7. data/lib/abstract_controller/callbacks.rb +31 -6
  8. data/lib/abstract_controller/deprecator.rb +7 -0
  9. data/lib/abstract_controller/helpers.rb +61 -18
  10. data/lib/abstract_controller/railties/routes_helpers.rb +1 -16
  11. data/lib/abstract_controller/rendering.rb +3 -3
  12. data/lib/abstract_controller/translation.rb +1 -27
  13. data/lib/abstract_controller/url_for.rb +2 -0
  14. data/lib/abstract_controller.rb +6 -0
  15. data/lib/action_controller/api.rb +5 -3
  16. data/lib/action_controller/base.rb +3 -17
  17. data/lib/action_controller/caching.rb +2 -0
  18. data/lib/action_controller/deprecator.rb +7 -0
  19. data/lib/action_controller/form_builder.rb +2 -0
  20. data/lib/action_controller/log_subscriber.rb +16 -4
  21. data/lib/action_controller/metal/content_security_policy.rb +1 -1
  22. data/lib/action_controller/metal/data_streaming.rb +2 -0
  23. data/lib/action_controller/metal/default_headers.rb +2 -0
  24. data/lib/action_controller/metal/etag_with_flash.rb +2 -0
  25. data/lib/action_controller/metal/etag_with_template_digest.rb +2 -0
  26. data/lib/action_controller/metal/exceptions.rb +8 -0
  27. data/lib/action_controller/metal/head.rb +8 -6
  28. data/lib/action_controller/metal/helpers.rb +3 -14
  29. data/lib/action_controller/metal/http_authentication.rb +10 -4
  30. data/lib/action_controller/metal/implicit_render.rb +5 -3
  31. data/lib/action_controller/metal/instrumentation.rb +8 -1
  32. data/lib/action_controller/metal/live.rb +24 -0
  33. data/lib/action_controller/metal/mime_responds.rb +2 -2
  34. data/lib/action_controller/metal/params_wrapper.rb +3 -1
  35. data/lib/action_controller/metal/permissions_policy.rb +1 -1
  36. data/lib/action_controller/metal/redirecting.rb +6 -6
  37. data/lib/action_controller/metal/renderers.rb +2 -2
  38. data/lib/action_controller/metal/rendering.rb +0 -7
  39. data/lib/action_controller/metal/request_forgery_protection.rb +138 -50
  40. data/lib/action_controller/metal/rescue.rb +2 -0
  41. data/lib/action_controller/metal/streaming.rb +70 -30
  42. data/lib/action_controller/metal/strong_parameters.rb +89 -50
  43. data/lib/action_controller/metal/url_for.rb +7 -0
  44. data/lib/action_controller/metal.rb +79 -21
  45. data/lib/action_controller/railtie.rb +22 -9
  46. data/lib/action_controller/renderer.rb +98 -65
  47. data/lib/action_controller/test_case.rb +15 -5
  48. data/lib/action_controller.rb +8 -1
  49. data/lib/action_dispatch/constants.rb +32 -0
  50. data/lib/action_dispatch/deprecator.rb +7 -0
  51. data/lib/action_dispatch/http/cache.rb +1 -3
  52. data/lib/action_dispatch/http/content_security_policy.rb +13 -29
  53. data/lib/action_dispatch/http/filter_parameters.rb +15 -14
  54. data/lib/action_dispatch/http/headers.rb +2 -0
  55. data/lib/action_dispatch/http/mime_negotiation.rb +21 -21
  56. data/lib/action_dispatch/http/mime_type.rb +35 -12
  57. data/lib/action_dispatch/http/mime_types.rb +3 -1
  58. data/lib/action_dispatch/http/parameters.rb +1 -1
  59. data/lib/action_dispatch/http/permissions_policy.rb +44 -15
  60. data/lib/action_dispatch/http/rack_cache.rb +2 -0
  61. data/lib/action_dispatch/http/request.rb +48 -14
  62. data/lib/action_dispatch/http/response.rb +78 -59
  63. data/lib/action_dispatch/http/upload.rb +2 -0
  64. data/lib/action_dispatch/journey/formatter.rb +8 -2
  65. data/lib/action_dispatch/journey/path/pattern.rb +14 -14
  66. data/lib/action_dispatch/journey/route.rb +3 -2
  67. data/lib/action_dispatch/journey/router.rb +5 -4
  68. data/lib/action_dispatch/journey/routes.rb +2 -2
  69. data/lib/action_dispatch/log_subscriber.rb +23 -0
  70. data/lib/action_dispatch/middleware/actionable_exceptions.rb +5 -6
  71. data/lib/action_dispatch/middleware/assume_ssl.rb +24 -0
  72. data/lib/action_dispatch/middleware/callbacks.rb +2 -0
  73. data/lib/action_dispatch/middleware/cookies.rb +81 -98
  74. data/lib/action_dispatch/middleware/debug_exceptions.rb +26 -25
  75. data/lib/action_dispatch/middleware/debug_locks.rb +4 -1
  76. data/lib/action_dispatch/middleware/debug_view.rb +7 -2
  77. data/lib/action_dispatch/middleware/exception_wrapper.rb +181 -27
  78. data/lib/action_dispatch/middleware/executor.rb +1 -1
  79. data/lib/action_dispatch/middleware/flash.rb +7 -0
  80. data/lib/action_dispatch/middleware/host_authorization.rb +6 -3
  81. data/lib/action_dispatch/middleware/public_exceptions.rb +5 -3
  82. data/lib/action_dispatch/middleware/reloader.rb +7 -5
  83. data/lib/action_dispatch/middleware/remote_ip.rb +17 -16
  84. data/lib/action_dispatch/middleware/request_id.rb +2 -0
  85. data/lib/action_dispatch/middleware/server_timing.rb +4 -4
  86. data/lib/action_dispatch/middleware/session/abstract_store.rb +5 -0
  87. data/lib/action_dispatch/middleware/session/cache_store.rb +2 -0
  88. data/lib/action_dispatch/middleware/session/cookie_store.rb +11 -5
  89. data/lib/action_dispatch/middleware/session/mem_cache_store.rb +3 -1
  90. data/lib/action_dispatch/middleware/show_exceptions.rb +19 -15
  91. data/lib/action_dispatch/middleware/ssl.rb +18 -6
  92. data/lib/action_dispatch/middleware/stack.rb +7 -2
  93. data/lib/action_dispatch/middleware/static.rb +12 -8
  94. data/lib/action_dispatch/middleware/templates/rescues/_actions.html.erb +2 -2
  95. data/lib/action_dispatch/middleware/templates/rescues/_message_and_suggestions.html.erb +4 -4
  96. data/lib/action_dispatch/middleware/templates/rescues/_source.html.erb +8 -1
  97. data/lib/action_dispatch/middleware/templates/rescues/diagnostics.html.erb +7 -7
  98. data/lib/action_dispatch/middleware/templates/rescues/diagnostics.text.erb +2 -2
  99. data/lib/action_dispatch/middleware/templates/rescues/layout.erb +17 -0
  100. data/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.html.erb +16 -12
  101. data/lib/action_dispatch/middleware/templates/rescues/missing_template.html.erb +1 -1
  102. data/lib/action_dispatch/middleware/templates/rescues/routing_error.html.erb +3 -3
  103. data/lib/action_dispatch/middleware/templates/rescues/template_error.html.erb +4 -4
  104. data/lib/action_dispatch/middleware/templates/rescues/unknown_action.html.erb +1 -1
  105. data/lib/action_dispatch/middleware/templates/rescues/unknown_action.text.erb +1 -1
  106. data/lib/action_dispatch/middleware/templates/routes/_route.html.erb +3 -0
  107. data/lib/action_dispatch/middleware/templates/routes/_table.html.erb +46 -37
  108. data/lib/action_dispatch/railtie.rb +14 -4
  109. data/lib/action_dispatch/request/session.rb +16 -6
  110. data/lib/action_dispatch/request/utils.rb +8 -3
  111. data/lib/action_dispatch/routing/inspector.rb +54 -6
  112. data/lib/action_dispatch/routing/mapper.rb +26 -14
  113. data/lib/action_dispatch/routing/polymorphic_routes.rb +2 -0
  114. data/lib/action_dispatch/routing/redirection.rb +15 -6
  115. data/lib/action_dispatch/routing/route_set.rb +52 -22
  116. data/lib/action_dispatch/routing/routes_proxy.rb +1 -1
  117. data/lib/action_dispatch/routing/url_for.rb +5 -1
  118. data/lib/action_dispatch/routing.rb +4 -4
  119. data/lib/action_dispatch/system_test_case.rb +3 -3
  120. data/lib/action_dispatch/system_testing/browser.rb +5 -6
  121. data/lib/action_dispatch/system_testing/driver.rb +13 -21
  122. data/lib/action_dispatch/system_testing/test_helpers/screenshot_helper.rb +27 -16
  123. data/lib/action_dispatch/testing/assertions/response.rb +13 -6
  124. data/lib/action_dispatch/testing/assertions/routing.rb +67 -28
  125. data/lib/action_dispatch/testing/assertions.rb +3 -1
  126. data/lib/action_dispatch/testing/integration.rb +27 -17
  127. data/lib/action_dispatch/testing/request_encoder.rb +4 -1
  128. data/lib/action_dispatch/testing/test_process.rb +4 -3
  129. data/lib/action_dispatch/testing/test_request.rb +1 -1
  130. data/lib/action_dispatch/testing/test_response.rb +23 -9
  131. data/lib/action_dispatch.rb +37 -4
  132. data/lib/action_pack/gem_version.rb +4 -4
  133. data/lib/action_pack/version.rb +1 -1
  134. data/lib/action_pack.rb +1 -1
  135. metadata +55 -33
data/CHANGELOG.md CHANGED
@@ -1,638 +1,524 @@
1
- ## Rails 7.0.8.7 (December 10, 2024) ##
1
+ ## Rails 7.1.0.beta1 (September 13, 2023) ##
2
2
 
3
- * Add validation to content security policies to disallow spaces and semicolons.
4
- Developers should use multiple arguments, and different directive methods instead.
3
+ * `AbstractController::Translation.raise_on_missing_translations` removed
5
4
 
6
- [CVE-2024-54133]
5
+ This was a private API, and has been removed in favour of a more broadly applicable
6
+ `config.i18n.raise_on_missing_translations`. See the upgrading guide for more information.
7
7
 
8
- *Gannon McGibbon*
9
-
10
- ## Rails 7.0.8.6 (October 23, 2024) ##
11
-
12
- * No changes.
13
-
14
-
15
- ## Rails 7.0.8.5 (October 15, 2024) ##
16
-
17
- * Avoid regex backtracking in HTTP Token authentication
18
-
19
- [CVE-2024-47887]
20
-
21
- * Avoid regex backtracking in query parameter filtering
22
-
23
- [CVE-2024-41128]
24
-
25
-
26
- ## Rails 7.0.8.4 (June 04, 2024) ##
27
-
28
- * Include the HTTP Permissions-Policy on non-HTML Content-Types
29
- [CVE-2024-28103]
30
-
31
-
32
- ## Rails 7.0.8.3 (May 17, 2024) ##
33
-
34
- * No changes.
8
+ *Alex Ghiculescu*
35
9
 
10
+ * Add `ActionController::Parameters#extract_value` method to allow extracting serialized values from params
36
11
 
37
- ## Rails 7.0.8.2 (May 16, 2024) ##
12
+ ```ruby
13
+ params = ActionController::Parameters.new(id: "1_123", tags: "ruby,rails")
14
+ params.extract_value(:id) # => ["1", "123"]
15
+ params.extract_value(:tags, delimiter: ",") # => ["ruby", "rails"]
16
+ ```
38
17
 
39
- * No changes.
18
+ *Nikita Vasilevsky*
40
19
 
20
+ * Parse JSON `response.parsed_body` with `ActiveSupport::HashWithIndifferentAccess`
41
21
 
42
- ## Rails 7.0.8.1 (February 21, 2024) ##
22
+ Integrate with Minitest's new `assert_pattern` by parsing the JSON contents
23
+ of `response.parsed_body` with `ActiveSupport::HashWithIndifferentAccess`, so
24
+ that it's pattern-matching compatible.
43
25
 
44
- * Fix possible XSS vulnerability with the `translate` method in controllers
26
+ *Sean Doyle*
45
27
 
46
- CVE-2024-26143
28
+ * Add support for Playwright as a driver for system tests.
47
29
 
48
- ## Rails 7.0.8 (September 09, 2023) ##
30
+ *Yuki Nishijima*
49
31
 
50
32
  * Fix `HostAuthorization` potentially displaying the value of the
51
33
  X_FORWARDED_HOST header when the HTTP_HOST header is being blocked.
52
34
 
53
35
  *Hartley McGuire*, *Daniel Schlosser*
54
36
 
37
+ * Rename `fixture_file_upload` method to `file_fixture_upload`
55
38
 
56
- ## Rails 7.0.7.2 (August 22, 2023) ##
57
-
58
- * No changes.
59
-
60
-
61
- ## Rails 7.0.7.1 (August 22, 2023) ##
62
-
63
- * No changes.
64
-
65
-
66
- ## Rails 7.0.7 (August 09, 2023) ##
67
-
68
- * No changes.
69
-
70
-
71
- ## Rails 7.0.6 (June 29, 2023) ##
72
-
73
- * No changes.
74
-
75
-
76
- ## Rails 7.0.5.1 (June 26, 2023) ##
77
-
78
- * Raise an exception if illegal characters are provide to redirect_to
79
- [CVE-2023-28362]
39
+ Declare an alias to preserve the backwards compatibility of `fixture_file_upload`
80
40
 
81
- *Zack Deveau*
82
-
83
- ## Rails 7.0.5 (May 24, 2023) ##
84
-
85
- * Do not return CSP headers for 304 Not Modified responses.
86
-
87
- *Tobias Kraze*
88
-
89
- * Fix `EtagWithFlash` when there is no `Flash` middleware available.
90
-
91
- *fatkodima*
92
-
93
- * Fix content-type header with `send_stream`.
94
-
95
- *Elliot Crosby-McCullough*
96
-
97
- * Address Selenium `:capabilities` deprecation warning.
98
-
99
- *Ron Shinall*
100
-
101
- * Fix cookie domain for domain: all on two letter single level TLD.
102
-
103
- *John Hawthorn*
104
-
105
- * Don't double log the `controller`, `action`, or `namespaced_controller` when using `ActiveRecord::QueryLog`
106
-
107
- Previously if you set `config.active_record.query_log_tags` to an array that included
108
- `:controller`, `:namespaced_controller`, or `:action`, that item would get logged twice.
109
- This bug has been fixed.
110
-
111
- *Alex Ghiculescu*
112
-
113
- * Rescue `EOFError` exception from `rack` on a multipart request.
114
-
115
- *Nikita Vasilevsky*
116
-
117
- * Rescue `JSON::ParserError` in Cookies json deserializer to discards marshal dumps:
118
-
119
- Without this change, if `action_dispatch.cookies_serializer` is set to `:json` and
120
- the app tries to read a `:marshal` serialized cookie, it would error out which wouldn't
121
- clear the cookie and force app users to manually clear it in their browser.
122
-
123
- (See #45127 for original bug discussion)
124
-
125
- *Nathan Bardoux*
41
+ *Sean Doyle*
126
42
 
127
- ## Rails 7.0.4.3 (March 13, 2023) ##
43
+ * `ActionDispatch::SystemTesting::TestHelpers::ScreenshotHelper` saves the screenshot path in test metadata on failure.
128
44
 
129
- * No changes.
45
+ *Matija Čupić*
130
46
 
47
+ * `config.dom_testing_default_html_version` controls the HTML parser used by
48
+ `ActionDispatch::Assertions#html_document`.
131
49
 
132
- ## Rails 7.0.4.2 (January 24, 2023) ##
50
+ The Rails 7.1 default configuration opts into the HTML5 parser when it is supported, to better
51
+ represent what the DOM would be in a browser user agent. Previously this test helper always used
52
+ Nokogiri's HTML4 parser.
133
53
 
134
- * Fix `domain: :all` for two letter TLD
54
+ *Mike Dalessio*
135
55
 
136
- This fixes a compatibility issue introduced in our previous security
137
- release when using `domain: :all` with a two letter but single level top
138
- level domain domain (like `.ca`, rather than `.co.uk`).
139
-
140
-
141
- ## Rails 7.0.4.1 (January 17, 2023) ##
142
-
143
- * Fix sec issue with _url_host_allowed?
144
-
145
- Disallow certain strings from `_url_host_allowed?` to avoid a redirect
146
- to malicious sites.
147
-
148
- [CVE-2023-22797]
149
-
150
- * Avoid regex backtracking on If-None-Match header
151
-
152
- [CVE-2023-22795]
153
-
154
- * Use string#split instead of regex for domain parts
155
-
156
- [CVE-2023-22792]
157
-
158
- ## Rails 7.0.4 (September 09, 2022) ##
159
-
160
- * Prevent `ActionDispatch::ServerTiming` from overwriting existing values in `Server-Timing`.
161
-
162
- Previously, if another middleware down the chain set `Server-Timing` header,
163
- it would overwritten by `ActionDispatch::ServerTiming`.
164
-
165
- *Jakub Malinowski*
56
+ * The `with_routing` helper can now be called at the class level. When called at the class level, the routes will
57
+ be setup before each test, and reset after every test. For example:
166
58
 
59
+ ```ruby
60
+ class RoutingTest < ActionController::TestCase
61
+ with_routing do |routes|
62
+ routes.draw do
63
+ resources :articles
64
+ resources :authors
65
+ end
66
+ end
167
67
 
168
- ## Rails 7.0.3.1 (July 12, 2022) ##
68
+ def test_articles_route
69
+ assert_routing("/articles", controller: "articles", action: "index")
70
+ end
169
71
 
170
- * No changes.
72
+ def test_authors_route
73
+ assert_routing("/authors", controller: "authors", action: "index")
74
+ end
75
+ end
76
+ ```
171
77
 
78
+ *Andrew Novoselac*
172
79
 
173
- ## Rails 7.0.3 (May 09, 2022) ##
80
+ * The `Mime::Type` now supports handling types with parameters and correctly handles quotes.
81
+ When parsing the accept header, the parameters before the q-parameter are kept and if a matching mime-type exists it is used.
82
+ To keep the current functionality, a fallback is created to look for the media-type without the parameters.
174
83
 
175
- * Allow relative redirects when `raise_on_open_redirects` is enabled.
84
+ This change allows for custom MIME-types that are more complex like `application/vnd.api+json; profile="https://jsonapi.org/profiles/ethanresnick/cursor-pagination/" ext="https://jsonapi.org/ext/atomic"` for the [JSON API](https://jsonapi.org/).
176
85
 
177
- *Tom Hughes*
86
+ *Nicolas Erni*
178
87
 
179
- * Fix `authenticate_with_http_basic` to allow for missing password.
88
+ * The url_for helpers now support a new option called `path_params`.
89
+ This is very useful in situations where you only want to add a required param that is part of the route's URL but for other route not append an extraneous query param.
180
90
 
181
- Before Rails 7.0 it was possible to handle basic authentication with only a username.
91
+ Given the following router...
182
92
 
183
93
  ```ruby
184
- authenticate_with_http_basic do |token, _|
185
- ApiClient.authenticate(token)
94
+ Rails.application.routes.draw do
95
+ scope ":account_id" do
96
+ get "dashboard" => "pages#dashboard", as: :dashboard
97
+ get "search/:term" => "search#search", as: :search
98
+ end
99
+ delete "signout" => "sessions#destroy", as: :signout
186
100
  end
187
101
  ```
188
102
 
189
- This ability is restored.
190
-
191
- *Jean Boussier*
192
-
193
- * Fix `content_security_policy` returning invalid directives.
194
-
195
- Directives such as `self`, `unsafe-eval` and few others were not
196
- single quoted when the directive was the result of calling a lambda
197
- returning an array.
103
+ And given the following `ApplicationController`
198
104
 
199
105
  ```ruby
200
- content_security_policy do |policy|
201
- policy.frame_ancestors lambda { [:self, "https://example.com"] }
106
+ class ApplicationController < ActionController::Base
107
+ def default_url_options
108
+ { path_params: { account_id: "foo" } }
109
+ end
202
110
  end
203
111
  ```
204
112
 
205
- With this fix the policy generated from above will now be valid.
206
-
207
- *Edouard Chin*
208
-
209
- * Fix `skip_forgery_protection` to run without raising an error if forgery
210
- protection has not been enabled / `verify_authenticity_token` is not a
211
- defined callback.
212
-
213
- This fix prevents the Rails 7.0 Welcome Page (`/`) from raising an
214
- `ArgumentError` if `default_protect_from_forgery` is false.
215
-
216
- *Brad Trick*
217
-
218
- * Fix `ActionController::Live` to copy the IsolatedExecutionState in the ephemeral thread.
219
-
220
- Since its inception `ActionController::Live` has been copying thread local variables
221
- to keep things such as `CurrentAttributes` set from middlewares working in the controller action.
222
-
223
- With the introduction of `IsolatedExecutionState` in 7.0, some of that global state was lost in
224
- `ActionController::Live` controllers.
225
-
226
- *Jean Boussier*
227
-
228
- * Fix setting `trailing_slash: true` in route definition.
113
+ The standard url_for helper and friends will now behave as follows:
229
114
 
230
115
  ```ruby
231
- get '/test' => "test#index", as: :test, trailing_slash: true
116
+ dashboard_path # => /foo/dashboard
117
+ dashboard_path(account_id: "bar") # => /bar/dashboard
232
118
 
233
- test_path() # => "/test/"
119
+ signout_path # => /signout
120
+ signout_path(account_id: "bar") # => /signout?account_id=bar
121
+ signout_path(account_id: "bar", path_params: { account_id: "baz" }) # => /signout?account_id=bar
122
+ search_path("quin") # => /foo/search/quin
234
123
  ```
235
124
 
236
- *Jean Boussier*
237
-
238
- ## Rails 7.0.2.4 (April 26, 2022) ##
239
-
240
- * Allow Content Security Policy DSL to generate for API responses.
241
-
242
- *Tim Wade*
243
-
244
- ## Rails 7.0.2.3 (March 08, 2022) ##
245
-
246
- * No changes.
247
-
248
-
249
- ## Rails 7.0.2.2 (February 11, 2022) ##
250
-
251
- * No changes.
125
+ *Jason Meller, Jeremy Beker*
252
126
 
127
+ * Change `action_dispatch.show_exceptions` to one of `:all`, `:rescuable`, or
128
+ `:none`. `:all` and `:none` behave the same as the previous `true` and
129
+ `false` respectively. The new `:rescuable` option will only show exceptions
130
+ that can be rescued (e.g. `ActiveRecord::RecordNotFound`). `:rescuable` is
131
+ now the default for the test environment.
253
132
 
254
- ## Rails 7.0.2.1 (February 11, 2022) ##
133
+ *Jon Dufresne*
255
134
 
256
- * Under certain circumstances, the middleware isn't informed that the
257
- response body has been fully closed which result in request state not
258
- being fully reset before the next request
259
-
260
- [CVE-2022-23633]
261
-
262
-
263
- ## Rails 7.0.2 (February 08, 2022) ##
264
-
265
- * No changes.
266
-
267
-
268
- ## Rails 7.0.1 (January 06, 2022) ##
269
-
270
- * Fix `ActionController::Parameters` methods to keep the original logger context when creating a new copy
271
- of the original object.
272
-
273
- *Yutaka Kamei*
274
-
275
-
276
- ## Rails 7.0.0 (December 15, 2021) ##
277
-
278
- * Deprecate `Rails.application.config.action_controller.urlsafe_csrf_tokens`. This config is now always enabled.
279
-
280
- *Étienne Barrié*
281
-
282
- * Instance variables set in requests in a `ActionController::TestCase` are now cleared before the next request
283
-
284
- This means if you make multiple requests in the same test, instance variables set in the first request will
285
- not persist into the second one. (It's not recommended to make multiple requests in the same test.)
286
-
287
- *Alex Ghiculescu*
135
+ * `config.action_dispatch.cookies_serializer` now accepts `:message_pack` and
136
+ `:message_pack_allow_marshal` as serializers. These serializers require the
137
+ [`msgpack` gem](https://rubygems.org/gems/msgpack) (>= 1.7.0).
288
138
 
139
+ The Message Pack format can provide improved performance and smaller payload
140
+ sizes. It also supports roundtripping some Ruby types that are not supported
141
+ by JSON. For example:
289
142
 
290
- ## Rails 7.0.0.rc3 (December 14, 2021) ##
143
+ ```ruby
144
+ cookies.encrypted[:foo] = [{ a: 1 }, { b: 2 }.with_indifferent_access, 1.to_d, Time.at(0, 123)]
291
145
 
292
- * No changes.
146
+ # BEFORE with config.action_dispatch.cookies_serializer = :json
147
+ cookies.encrypted[:foo]
148
+ # => [{"a"=>1}, {"b"=>2}, "1.0", "1969-12-31T18:00:00.000-06:00"]
149
+ cookies.encrypted[:foo].map(&:class)
150
+ # => [Hash, Hash, String, String]
293
151
 
152
+ # AFTER with config.action_dispatch.cookies_serializer = :message_pack
153
+ cookies.encrypted[:foo]
154
+ # => [{:a=>1}, {"b"=>2}, 0.1e1, 1969-12-31 18:00:00.000123 -0600]
155
+ cookies.encrypted[:foo].map(&:class)
156
+ # => [Hash, ActiveSupport::HashWithIndifferentAccess, BigDecimal, Time]
157
+ ```
294
158
 
295
- ## Rails 7.0.0.rc2 (December 14, 2021) ##
159
+ The `:message_pack` serializer can fall back to deserializing with
160
+ `ActiveSupport::JSON` when necessary, and the `:message_pack_allow_marshal`
161
+ serializer can fall back to deserializing with `Marshal` as well as
162
+ `ActiveSupport::JSON`. Additionally, the `:marshal`, `:json`, and
163
+ `:json_allow_marshal` (AKA `:hybrid`) serializers can now fall back to
164
+ deserializing with `ActiveSupport::MessagePack` when necessary. These
165
+ behaviors ensure old cookies can still be read so that migration is easier.
296
166
 
297
- * Fix X_FORWARDED_HOST protection. [CVE-2021-44528]
167
+ *Jonathan Hefner*
298
168
 
169
+ * Remove leading dot from domains on cookies set with `domain: :all`, to meet RFC6265 requirements
299
170
 
300
- ## Rails 7.0.0.rc1 (December 06, 2021) ##
171
+ *Gareth Adams*
301
172
 
302
- * `Rails.application.executor` hooks can now be called around every request in a `ActionController::TestCase`
173
+ * Include source location in routes extended view.
303
174
 
304
- This helps to better simulate request or job local state being reset between requests and prevent state
305
- leaking from one request to another.
175
+ ```bash
176
+ $ bin/rails routes --expanded
306
177
 
307
- To enable this, set `config.active_support.executor_around_test_case = true` (this is the default in Rails 7).
178
+ ...
179
+ --[ Route 14 ]----------
180
+ Prefix | new_gist
181
+ Verb | GET
182
+ URI | /gist(.:format)
183
+ Controller#Action | gists/gists#new
184
+ Source Location | config/routes/gist.rb:3
185
+ ```
308
186
 
309
- *Alex Ghiculescu*
187
+ *Luan Vieira, John Hawthorn and Daniel Colson*
310
188
 
311
- * Consider onion services secure for cookies.
189
+ * Add `without` as an alias of `except` on `ActiveController::Parameters`.
312
190
 
313
- *Justin Tracey*
191
+ *Hidde-Jan Jongsma*
314
192
 
315
- * Remove deprecated `Rails.config.action_view.raise_on_missing_translations`.
193
+ * Expand search field on `rails/info/routes` to also search **route name**, **http verb** and **controller#action**.
316
194
 
317
- *Rafael Mendonça França*
195
+ *Jason Kotchoff*
318
196
 
319
- * Remove deprecated support to passing a path to `fixture_file_upload` relative to `fixture_path`.
197
+ * Remove deprecated `poltergeist` and `webkit` (capybara-webkit) driver registration for system testing.
320
198
 
321
199
  *Rafael Mendonça França*
322
200
 
323
- * Remove deprecated `ActionDispatch::SystemTestCase#host!`.
201
+ * Remove deprecated ability to assign a single value to `config.action_dispatch.trusted_proxies`.
324
202
 
325
203
  *Rafael Mendonça França*
326
204
 
327
- * Remove deprecated `Rails.config.action_dispatch.hosts_response_app`.
205
+ * Deprecate `config.action_dispatch.return_only_request_media_type_on_content_type`.
328
206
 
329
207
  *Rafael Mendonça França*
330
208
 
331
- * Remove deprecated `ActionDispatch::Response.return_only_media_type_on_content_type`.
209
+ * Remove deprecated behavior on `Request#content_type`.
332
210
 
333
211
  *Rafael Mendonça França*
334
212
 
335
- * Raise `ActionController::Redirecting::UnsafeRedirectError` for unsafe `redirect_to` redirects.
336
-
337
- This allows `rescue_from` to be used to add a default fallback route:
213
+ * Change `ActionController::Instrumentation` to pass `filtered_path` instead of `fullpath` in the event payload to filter sensitive query params
338
214
 
339
215
  ```ruby
340
- rescue_from ActionController::Redirecting::UnsafeRedirectError do
341
- redirect_to root_url
342
- end
216
+ get "/posts?password=test"
217
+ request.fullpath # => "/posts?password=test"
218
+ request.filtered_path # => "/posts?password=[FILTERED]"
343
219
  ```
344
220
 
345
- *Kasper Timm Hansen*, *Chris Oliver*
221
+ *Ritikesh G*
222
+
223
+ * Deprecate `AbstractController::Helpers::MissingHelperError`
346
224
 
347
- * Add `url_from` to verify a redirect location is internal.
225
+ *Hartley McGuire*
348
226
 
349
- Takes the open redirect protection from `redirect_to` so users can wrap a
350
- param, and fall back to an alternate redirect URL when the param provided
351
- one is unsafe.
227
+ * Change `ActionDispatch::Testing::TestResponse#parsed_body` to parse HTML as
228
+ a Nokogiri document
352
229
 
353
230
  ```ruby
354
- def create
355
- redirect_to url_from(params[:redirect_url]) || root_url
356
- end
231
+ get "/posts"
232
+ response.content_type # => "text/html; charset=utf-8"
233
+ response.parsed_body.class # => Nokogiri::HTML5::Document
234
+ response.parsed_body.to_html # => "<!DOCTYPE html>\n<html>\n..."
357
235
  ```
358
236
 
359
- *dmcge*, *Kasper Timm Hansen*
360
-
361
- * Allow Capybara driver name overrides in `SystemTestCase::driven_by`
237
+ *Sean Doyle*
362
238
 
363
- Allow users to prevent conflicts among drivers that use the same driver
364
- type (selenium, poltergeist, webkit, rack test).
239
+ * Deprecate `ActionDispatch::IllegalStateError`.
365
240
 
366
- Fixes #42502
241
+ *Samuel Williams*
367
242
 
368
- *Chris LaRose*
243
+ * Add HTTP::Request#route_uri_pattern that returns URI pattern of matched route.
369
244
 
370
- * Allow multiline to be passed in routes when using wildcard segments.
245
+ *Joel Hawksley*, *Kate Higa*
371
246
 
372
- Previously routes with newlines weren't detected when using wildcard segments, returning
373
- a `No route matches` error.
374
- After this change, routes with newlines are detected on wildcard segments. Example
247
+ * Add `ActionDispatch::AssumeSSL` middleware that can be turned on via `config.assume_ssl`.
248
+ It makes the application believe that all requests are arriving over SSL. This is useful
249
+ when proxying through a load balancer that terminates SSL, the forwarded request will appear
250
+ as though its HTTP instead of HTTPS to the application. This makes redirects and cookie
251
+ security target HTTP instead of HTTPS. This middleware makes the server assume that the
252
+ proxy already terminated SSL, and that the request really is HTTPS.
375
253
 
376
- ```ruby
377
- draw do
378
- get "/wildcard/*wildcard_segment", to: SimpleApp.new("foo#index"), as: :wildcard
379
- end
380
-
381
- # After the change, the path matches.
382
- assert_equal "/wildcard/a%0Anewline", url_helpers.wildcard_path(wildcard_segment: "a\nnewline")
383
- ```
254
+ *DHH*
384
255
 
385
- Fixes #39103
256
+ * Only use HostAuthorization middleware if `config.hosts` is not empty
386
257
 
387
- *Ignacio Chiazzo*
258
+ *Hartley McGuire*
388
259
 
389
- * Treat html suffix in controller translation.
260
+ * Allow raising an error when a callback's only/unless symbols aren't existing methods.
390
261
 
391
- *Rui Onodera*, *Gavin Miller*
262
+ When `before_action :callback, only: :action_name` is declared on a controller that doesn't respond to `action_name`, raise an exception at request time. This is a safety measure to ensure that typos or forgetfulness don't prevent a crucial callback from being run when it should.
392
263
 
393
- * Allow permitting numeric params.
264
+ For new applications, raising an error for undefined actions is turned on by default. If you do not want to opt-in to this behavior set `config.action_pack.raise_on_missing_callback_actions` to `false` in your application configuration. See #43487 for more details.
394
265
 
395
- Previously it was impossible to permit different fields on numeric parameters.
396
- After this change you can specify different fields for each numbered parameter.
397
- For example params like,
398
- ```ruby
399
- book: {
400
- authors_attributes: {
401
- '0': { name: "William Shakespeare", age_of_death: "52" },
402
- '1': { name: "Unattributed Assistant" },
403
- '2': "Not a hash",
404
- 'new_record': { name: "Some name" }
405
- }
406
- }
407
- ```
266
+ *Jess Bees*
408
267
 
409
- Before you could permit name on each author with,
410
- `permit book: { authors_attributes: [ :name ] }`
268
+ * Allow cookie options[:domain] to accept a proc to set the cookie domain on a more flexible per-request basis
411
269
 
412
- After this change you can permit different keys on each numbered element,
413
- `permit book: { authors_attributes: { '1': [ :name ], '0': [ :name, :age_of_death ] } }`
270
+ *RobL*
414
271
 
415
- Fixes #41625
272
+ * When a host is not specified for an `ActionController::Renderer`'s env,
273
+ the host and related options will now be derived from the routes'
274
+ `default_url_options` and `ActionDispatch::Http::URL.secure_protocol`.
416
275
 
417
- *Adam Hess*
276
+ This means that for an application with a configuration like:
418
277
 
419
- * Update `HostAuthorization` middleware to render debug info only
420
- when `config.consider_all_requests_local` is set to true.
278
+ ```ruby
279
+ Rails.application.default_url_options = { host: "rubyonrails.org" }
280
+ Rails.application.config.force_ssl = true
281
+ ```
421
282
 
422
- Also, blocked host info is always logged with level `error`.
283
+ rendering a URL like:
423
284
 
424
- Fixes #42813
285
+ ```ruby
286
+ ApplicationController.renderer.render inline: "<%= blog_url %>"
287
+ ```
425
288
 
426
- *Nikita Vyrko*
289
+ will now return `"https://rubyonrails.org/blog"` instead of
290
+ `"http://example.org/blog"`.
427
291
 
428
- * Add Server-Timing middleware
292
+ *Jonathan Hefner*
429
293
 
430
- Server-Timing specification defines how the server can communicate to browsers performance metrics
431
- about the request it is responding to.
294
+ * Add details of cookie name and size to `CookieOverflow` exception.
432
295
 
433
- The ServerTiming middleware is enabled by default on `development` environment by default using the
434
- `config.server_timing` setting and set the relevant duration metrics in the `Server-Timing` header
296
+ *Andy Waite*
435
297
 
436
- The full specification for Server-Timing header can be found in: https://www.w3.org/TR/server-timing/#dfn-server-timing-header-field
298
+ * Don't double log the `controller`, `action`, or `namespaced_controller` when using `ActiveRecord::QueryLog`
437
299
 
438
- *Sebastian Sogamoso*, *Guillermo Iguaran*
300
+ Previously if you set `config.active_record.query_log_tags` to an array that included
301
+ `:controller`, `:namespaced_controller`, or `:action`, that item would get logged twice.
302
+ This bug has been fixed.
439
303
 
304
+ *Alex Ghiculescu*
440
305
 
441
- ## Rails 7.0.0.alpha2 (September 15, 2021) ##
306
+ * Add the following permissions policy directives: `hid`, `idle-detection`, `screen-wake-lock`,
307
+ `serial`, `sync-xhr`, `web-share`.
442
308
 
443
- * No changes.
309
+ *Guillaume Cabanel*
444
310
 
311
+ * The `speaker`, `vibrate`, and `vr` permissions policy directives are now
312
+ deprecated.
445
313
 
446
- ## Rails 7.0.0.alpha1 (September 15, 2021) ##
314
+ There is no browser support for these directives, and no plan for browser
315
+ support in the future. You can just remove these directives from your
316
+ application.
447
317
 
448
- * Use a static error message when raising `ActionDispatch::Http::Parameters::ParseError`
449
- to avoid inadvertently logging the HTTP request body at the `fatal` level when it contains
450
- malformed JSON.
318
+ *Jonathan Hefner*
451
319
 
452
- Fixes #41145
320
+ * Added the `:status` option to `assert_redirected_to` to specify the precise
321
+ HTTP status of the redirect. Defaults to `:redirect` for backwards
322
+ compatibility.
453
323
 
454
- *Aaron Lahey*
324
+ *Jon Dufresne*
455
325
 
456
- * Add `Middleware#delete!` to delete middleware or raise if not found.
326
+ * Rescue `JSON::ParserError` in Cookies JSON deserializer to discards marshal dumps:
457
327
 
458
- `Middleware#delete!` works just like `Middleware#delete` but will
459
- raise an error if the middleware isn't found.
328
+ Without this change, if `action_dispatch.cookies_serializer` is set to `:json` and
329
+ the app tries to read a `:marshal` serialized cookie, it would error out which wouldn't
330
+ clear the cookie and force app users to manually clear it in their browser.
460
331
 
461
- *Alex Ghiculescu*, *Petrik de Heus*, *Junichi Sato*
332
+ (See #45127 for original bug discussion)
462
333
 
463
- * Raise error on unpermitted open redirects.
334
+ *Nathan Bardoux*
464
335
 
465
- Add `allow_other_host` options to `redirect_to`.
466
- Opt in to this behaviour with `ActionController::Base.raise_on_open_redirects = true`.
336
+ * Add `HTTP_REFERER` when following redirects on integration tests
467
337
 
468
- *Gannon McGibbon*
338
+ This makes `follow_redirect!` a closer simulation of what happens in a real browser
469
339
 
470
- * Deprecate `poltergeist` and `webkit` (capybara-webkit) driver registration for system testing (they will be removed in Rails 7.1). Add `cuprite` instead.
340
+ *Felipe Sateler*
471
341
 
472
- [Poltergeist](https://github.com/teampoltergeist/poltergeist) and [capybara-webkit](https://github.com/thoughtbot/capybara-webkit) are already not maintained. These usage in Rails are removed for avoiding confusing users.
342
+ * Added `exclude?` method to `ActionController::Parameters`.
473
343
 
474
- [Cuprite](https://github.com/rubycdp/cuprite) is a good alternative to Poltergeist. Some guide descriptions are replaced from Poltergeist to Cuprite.
344
+ *Ian Neubert*
475
345
 
476
- *Yusuke Iwaki*
346
+ * Rescue `EOFError` exception from `rack` on a multipart request.
477
347
 
478
- * Exclude additional flash types from `ActionController::Base.action_methods`.
348
+ *Nikita Vasilevsky*
479
349
 
480
- Ensures that additional flash types defined on ActionController::Base subclasses
481
- are not listed as actions on that controller.
350
+ * Log redirects from routes the same way as redirects from controllers.
482
351
 
483
- class MyController < ApplicationController
484
- add_flash_types :hype
485
- end
352
+ *Dennis Paagman*
486
353
 
487
- MyController.action_methods.include?('hype') # => false
354
+ * Prevent `ActionDispatch::ServerTiming` from overwriting existing values in `Server-Timing`.
355
+ Previously, if another middleware down the chain set `Server-Timing` header,
356
+ it would overwritten by `ActionDispatch::ServerTiming`.
488
357
 
489
- *Gavin Morrice*
358
+ *Jakub Malinowski*
490
359
 
491
- * OpenSSL constants are now used for Digest computations.
360
+ * Allow opting out of the `SameSite` cookie attribute when setting a cookie.
492
361
 
493
- *Dirkjan Bussink*
362
+ You can opt out of `SameSite` by passing `same_site: nil`.
494
363
 
495
- * Remove IE6-7-8 file download related hack/fix from ActionController::DataStreaming module.
364
+ `cookies[:foo] = { value: "bar", same_site: nil }`
496
365
 
497
- Due to the age of those versions of IE this fix is no longer relevant, more importantly it creates an edge-case for unexpected Cache-Control headers.
366
+ Previously, this incorrectly set the `SameSite` attribute to the value of the `cookies_same_site_protection` setting.
498
367
 
499
- *Tadas Sasnauskas*
368
+ *Alex Ghiculescu*
500
369
 
501
- * Configuration setting to skip logging an uncaught exception backtrace when the exception is
502
- present in `rescued_responses`.
370
+ * Allow using `helper_method`s in `content_security_policy` and `permissions_policy`
503
371
 
504
- It may be too noisy to get all backtraces logged for applications that manage uncaught
505
- exceptions via `rescued_responses` and `exceptions_app`.
506
- `config.action_dispatch.log_rescued_responses` (defaults to `true`) can be set to `false` in
507
- this case, so that only exceptions not found in `rescued_responses` will be logged.
372
+ Previously you could access basic helpers (defined in helper modules), but not
373
+ helper methods defined using `helper_method`. Now you can use either.
508
374
 
509
- *Alexander Azarov*, *Mike Dalessio*
375
+ ```ruby
376
+ content_security_policy do |p|
377
+ p.default_src "https://example.com"
378
+ p.script_src "https://example.com" if helpers.script_csp?
379
+ end
380
+ ```
510
381
 
511
- * Ignore file fixtures on `db:fixtures:load`.
382
+ *Alex Ghiculescu*
512
383
 
513
- *Kevin Sjöberg*
384
+ * Reimplement `ActionController::Parameters#has_value?` and `#value?` to avoid parameters and hashes comparison.
514
385
 
515
- * Fix ActionController::Live controller test deadlocks by removing the body buffer size limit for tests.
386
+ Deprecated equality between parameters and hashes is going to be removed in Rails 7.2.
387
+ The new implementation takes care of conversions.
516
388
 
517
- *Dylan Thacker-Smith*
389
+ *Seva Stefkin*
518
390
 
519
- * New `ActionController::ConditionalGet#no_store` method to set HTTP cache control `no-store` directive.
391
+ * Allow only String and Symbol keys in `ActionController::Parameters`.
392
+ Raise `ActionController::InvalidParameterKey` when initializing Parameters
393
+ with keys that aren't strings or symbols.
520
394
 
521
- *Tadas Sasnauskas*
395
+ *Seva Stefkin*
522
396
 
523
- * Drop support for the `SERVER_ADDR` header.
397
+ * Add the ability to use custom logic for storing and retrieving CSRF tokens.
524
398
 
525
- Following up https://github.com/rack/rack/pull/1573 and https://github.com/rails/rails/pull/42349.
399
+ By default, the token will be stored in the session. Custom classes can be
400
+ defined to specify arbitrary behavior, but the ability to store them in
401
+ encrypted cookies is built in.
526
402
 
527
- *Ricardo Díaz*
403
+ *Andrew Kowpak*
528
404
 
529
- * Set session options when initializing a basic session.
405
+ * Make ActionController::Parameters#values cast nested hashes into parameters.
530
406
 
531
407
  *Gannon McGibbon*
532
408
 
533
- * Add `cache_control: {}` option to `fresh_when` and `stale?`.
409
+ * Introduce `html:` and `screenshot:` kwargs for system test screenshot helper
534
410
 
535
- Works as a shortcut to set `response.cache_control` with the above methods.
411
+ Use these as an alternative to the already-available environment variables.
536
412
 
537
- *Jacopo Beschi*
413
+ For example, this will display a screenshot in iTerm, save the HTML, and output
414
+ its path.
415
+
416
+ ```ruby
417
+ take_screenshot(html: true, screenshot: "inline")
418
+ ```
538
419
 
539
- * Writing into a disabled session will now raise an error.
420
+ *Alex Ghiculescu*
540
421
 
541
- Previously when no session store was set, writing into the session would silently fail.
422
+ * Allow `ActionController::Parameters#to_h` to receive a block.
542
423
 
543
- *Jean Boussier*
424
+ *Bob Farrell*
544
425
 
545
- * Add support for 'require-trusted-types-for' and 'trusted-types' headers.
426
+ * Allow relative redirects when `raise_on_open_redirects` is enabled
546
427
 
547
- Fixes #42034.
428
+ *Tom Hughes*
548
429
 
549
- *lfalcao*
430
+ * Allow Content Security Policy DSL to generate for API responses.
550
431
 
551
- * Remove inline styles and address basic accessibility issues on rescue templates.
432
+ *Tim Wade*
552
433
 
553
- *Jacob Herrington*
434
+ * Fix `authenticate_with_http_basic` to allow for missing password.
554
435
 
555
- * Add support for 'private, no-store' Cache-Control headers.
436
+ Before Rails 7.0 it was possible to handle basic authentication with only a username.
556
437
 
557
- Previously, 'no-store' was exclusive; no other directives could be specified.
438
+ ```ruby
439
+ authenticate_with_http_basic do |token, _|
440
+ ApiClient.authenticate(token)
441
+ end
442
+ ```
558
443
 
559
- *Alex Smith*
444
+ This ability is restored.
560
445
 
561
- * Expand payload of `unpermitted_parameters.action_controller` instrumentation to allow subscribers to
562
- know which controller action received unpermitted parameters.
446
+ *Jean Boussier*
563
447
 
564
- *bbuchalter*
448
+ * Fix `content_security_policy` returning invalid directives.
565
449
 
566
- * Add `ActionController::Live#send_stream` that makes it more convenient to send generated streams:
450
+ Directives such as `self`, `unsafe-eval` and few others were not
451
+ single quoted when the directive was the result of calling a lambda
452
+ returning an array.
567
453
 
568
454
  ```ruby
569
- send_stream(filename: "subscribers.csv") do |stream|
570
- stream.writeln "email_address,updated_at"
571
-
572
- @subscribers.find_each do |subscriber|
573
- stream.writeln [ subscriber.email_address, subscriber.updated_at ].join(",")
574
- end
455
+ content_security_policy do |policy|
456
+ policy.frame_ancestors lambda { [:self, "https://example.com"] }
575
457
  end
576
458
  ```
577
459
 
578
- *DHH*
460
+ With this fix the policy generated from above will now be valid.
579
461
 
580
- * Add `ActionController::Live::Buffer#writeln` to write a line to the stream with a newline included.
462
+ *Edouard Chin*
581
463
 
582
- *DHH*
464
+ * Fix `skip_forgery_protection` to run without raising an error if forgery
465
+ protection has not been enabled / `verify_authenticity_token` is not a
466
+ defined callback.
583
467
 
584
- * `ActionDispatch::Request#content_type` now returned Content-Type header as it is.
468
+ This fix prevents the Rails 7.0 Welcome Page (`/`) from raising an
469
+ `ArgumentError` if `default_protect_from_forgery` is false.
585
470
 
586
- Previously, `ActionDispatch::Request#content_type` returned value does NOT contain charset part.
587
- This behavior changed to returned Content-Type header containing charset part as it is.
471
+ *Brad Trick*
588
472
 
589
- If you want just MIME type, please use `ActionDispatch::Request#media_type` instead.
473
+ * Make `redirect_to` return an empty response body.
590
474
 
591
- Before:
475
+ Application controllers that wish to add a response body after calling
476
+ `redirect_to` can continue to do so.
592
477
 
593
- ```ruby
594
- request = ActionDispatch::Request.new("CONTENT_TYPE" => "text/csv; header=present; charset=utf-16", "REQUEST_METHOD" => "GET")
595
- request.content_type #=> "text/csv"
596
- ```
478
+ *Jon Dufresne*
597
479
 
598
- After:
480
+ * Use non-capturing group for subdomain matching in `ActionDispatch::HostAuthorization`
599
481
 
600
- ```ruby
601
- request = ActionDispatch::Request.new("Content-Type" => "text/csv; header=present; charset=utf-16", "REQUEST_METHOD" => "GET")
602
- request.content_type #=> "text/csv; header=present; charset=utf-16"
603
- request.media_type #=> "text/csv"
604
- ```
482
+ Since we do nothing with the captured subdomain group, we can use a non-capturing group instead.
605
483
 
606
- *Rafael Mendonça França*
484
+ *Sam Bostock*
607
485
 
608
- * Change `ActionDispatch::Request#media_type` to return `nil` when the request don't have a `Content-Type` header.
486
+ * Fix `ActionController::Live` to copy the IsolatedExecutionState in the ephemeral thread.
609
487
 
610
- *Rafael Mendonça França*
488
+ Since its inception `ActionController::Live` has been copying thread local variables
489
+ to keep things such as `CurrentAttributes` set from middlewares working in the controller action.
611
490
 
612
- * Fix error in `ActionController::LogSubscriber` that would happen when throwing inside a controller action.
491
+ With the introduction of `IsolatedExecutionState` in 7.0, some of that global state was lost in
492
+ `ActionController::Live` controllers.
613
493
 
614
- *Janko Marohnić*
494
+ *Jean Boussier*
615
495
 
616
- * Allow anything with `#to_str` (like `Addressable::URI`) as a `redirect_to` location.
496
+ * Fix setting `trailing_slash: true` in route definition.
617
497
 
618
- *ojab*
498
+ ```ruby
499
+ get '/test' => "test#index", as: :test, trailing_slash: true
619
500
 
620
- * Change the request method to a `GET` when passing failed requests down to `config.exceptions_app`.
501
+ test_path() # => "/test/"
502
+ ```
621
503
 
622
- *Alex Robbin*
504
+ *Jean Boussier*
623
505
 
624
- * Deprecate the ability to assign a single value to `config.action_dispatch.trusted_proxies`
625
- as `RemoteIp` middleware behaves inconsistently depending on whether this is configured
626
- with a single value or an enumerable.
506
+ * Make `Session#merge!` stringify keys.
627
507
 
628
- Fixes #40772.
508
+ Previously `Session#update` would, but `merge!` wouldn't.
629
509
 
630
- *Christian Sutter*
510
+ *Drew Bragg*
631
511
 
632
- * Add `redirect_back_or_to(fallback_location, **)` as a more aesthetically pleasing version of `redirect_back fallback_location:, **`.
633
- The old method name is retained without explicit deprecation.
512
+ * Add `:unsafe_hashes` mapping for `content_security_policy`
634
513
 
635
- *DHH*
514
+ ```ruby
515
+ # Before
516
+ policy.script_src :strict_dynamic, "'unsafe-hashes'", "'sha256-rRMdkshZyJlCmDX27XnL7g3zXaxv7ei6Sg+yt4R3svU='"
517
+
518
+ # After
519
+ policy.script_src :strict_dynamic, :unsafe_hashes, "'sha256-rRMdkshZyJlCmDX27XnL7g3zXaxv7ei6Sg+yt4R3svU='"
520
+ ```
636
521
 
522
+ *Igor Morozov*
637
523
 
638
- Please check [6-1-stable](https://github.com/rails/rails/blob/6-1-stable/actionpack/CHANGELOG.md) for previous changes.
524
+ Please check [7-0-stable](https://github.com/rails/rails/blob/7-0-stable/actionpack/CHANGELOG.md) for previous changes.