actionpack 8.0.4 → 8.1.0.beta1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +241 -173
- data/lib/abstract_controller/asset_paths.rb +4 -2
- data/lib/abstract_controller/base.rb +10 -2
- data/lib/abstract_controller/caching.rb +6 -3
- data/lib/abstract_controller/helpers.rb +1 -1
- data/lib/abstract_controller/logger.rb +2 -1
- data/lib/action_controller/base.rb +1 -1
- data/lib/action_controller/caching.rb +1 -2
- data/lib/action_controller/form_builder.rb +1 -1
- data/lib/action_controller/log_subscriber.rb +7 -0
- data/lib/action_controller/metal/allow_browser.rb +1 -1
- data/lib/action_controller/metal/conditional_get.rb +25 -0
- data/lib/action_controller/metal/data_streaming.rb +1 -3
- data/lib/action_controller/metal/exceptions.rb +5 -0
- data/lib/action_controller/metal/flash.rb +1 -4
- data/lib/action_controller/metal/head.rb +3 -1
- data/lib/action_controller/metal/permissions_policy.rb +9 -0
- data/lib/action_controller/metal/rate_limiting.rb +22 -7
- data/lib/action_controller/metal/redirecting.rb +61 -5
- data/lib/action_controller/metal/renderers.rb +27 -6
- data/lib/action_controller/metal/rendering.rb +7 -1
- data/lib/action_controller/metal/request_forgery_protection.rb +18 -10
- data/lib/action_controller/metal/rescue.rb +9 -0
- data/lib/action_controller/railtie.rb +2 -6
- data/lib/action_dispatch/http/cache.rb +111 -1
- data/lib/action_dispatch/http/filter_parameters.rb +5 -3
- data/lib/action_dispatch/http/mime_types.rb +1 -0
- data/lib/action_dispatch/http/param_builder.rb +28 -27
- data/lib/action_dispatch/http/parameters.rb +3 -3
- data/lib/action_dispatch/http/permissions_policy.rb +4 -0
- data/lib/action_dispatch/http/query_parser.rb +12 -10
- data/lib/action_dispatch/http/request.rb +10 -5
- data/lib/action_dispatch/http/response.rb +16 -3
- data/lib/action_dispatch/http/url.rb +99 -3
- data/lib/action_dispatch/journey/gtg/simulator.rb +33 -12
- data/lib/action_dispatch/journey/gtg/transition_table.rb +33 -43
- data/lib/action_dispatch/journey/nodes/node.rb +2 -1
- data/lib/action_dispatch/journey/route.rb +45 -31
- data/lib/action_dispatch/journey/router/utils.rb +8 -14
- data/lib/action_dispatch/journey/router.rb +59 -81
- data/lib/action_dispatch/journey/routes.rb +7 -0
- data/lib/action_dispatch/journey/visitors.rb +55 -23
- data/lib/action_dispatch/journey/visualizer/fsm.js +4 -6
- data/lib/action_dispatch/middleware/cookies.rb +4 -2
- data/lib/action_dispatch/middleware/debug_exceptions.rb +7 -1
- data/lib/action_dispatch/middleware/debug_view.rb +11 -0
- data/lib/action_dispatch/middleware/exception_wrapper.rb +11 -5
- data/lib/action_dispatch/middleware/executor.rb +12 -2
- data/lib/action_dispatch/middleware/public_exceptions.rb +1 -5
- data/lib/action_dispatch/middleware/session/cache_store.rb +17 -0
- data/lib/action_dispatch/middleware/templates/rescues/_copy_button.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/_source.html.erb +3 -2
- data/lib/action_dispatch/middleware/templates/rescues/_trace.html.erb +9 -5
- data/lib/action_dispatch/middleware/templates/rescues/blocked_host.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/diagnostics.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/invalid_statement.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/layout.erb +50 -0
- data/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/missing_template.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/routing_error.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/template_error.html.erb +1 -0
- data/lib/action_dispatch/middleware/templates/rescues/unknown_action.html.erb +1 -0
- data/lib/action_dispatch/railtie.rb +10 -2
- data/lib/action_dispatch/routing/inspector.rb +4 -1
- data/lib/action_dispatch/routing/mapper.rb +323 -173
- data/lib/action_dispatch/routing/route_set.rb +2 -4
- data/lib/action_dispatch/routing/routes_proxy.rb +0 -1
- data/lib/action_dispatch/system_testing/test_helpers/screenshot_helper.rb +2 -2
- data/lib/action_dispatch/testing/assertions/response.rb +14 -0
- data/lib/action_dispatch/testing/assertions/routing.rb +11 -3
- data/lib/action_dispatch/testing/integration.rb +4 -3
- data/lib/action_dispatch/testing/request_encoder.rb +9 -9
- data/lib/action_pack/gem_version.rb +3 -3
- metadata +11 -10
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: ed45caa459109b7c6009c7b63f8be21dfe1965dc7bc745e8e7588579a9384391
|
|
4
|
+
data.tar.gz: aabc44311112b16f6e9b8c3f34f391d1fc1abe91cb1b0df7e920dd0068cbc8b0
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 05dc45165c2451cf7a0bd23c7b5baf55ba3e970cde0877211b208f227b98e538237c373135f5d8c3ba905c18af5834d69086ab8e223a11f7d77fed3f0e067746
|
|
7
|
+
data.tar.gz: 43cba6f2e00ce49bc0b4ef8172eb26b6571325dcfa5c8b5deebcec90cfad8f6d8d7d0804459dc29e5fd36073aa8f1b09348999e6258197360be3306d9c41134e
|
data/CHANGELOG.md
CHANGED
|
@@ -1,292 +1,360 @@
|
|
|
1
|
-
## Rails 8.0.
|
|
1
|
+
## Rails 8.1.0.beta1 (September 04, 2025) ##
|
|
2
2
|
|
|
3
|
-
*
|
|
4
|
-
|
|
5
|
-
*Sean Doyle*
|
|
3
|
+
* Remove deprecated support to a route to multiple paths.
|
|
6
4
|
|
|
5
|
+
*Rafael Mendonça França*
|
|
7
6
|
|
|
8
|
-
|
|
7
|
+
* Remove deprecated support for using semicolons as a query string separator.
|
|
9
8
|
|
|
10
|
-
|
|
9
|
+
Before:
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
```ruby
|
|
12
|
+
ActionDispatch::QueryParser.each_pair("foo=bar;baz=quux").to_a
|
|
13
|
+
# => [["foo", "bar"], ["baz", "quux"]]
|
|
14
|
+
```
|
|
14
15
|
|
|
15
|
-
|
|
16
|
+
After:
|
|
16
17
|
|
|
17
|
-
|
|
18
|
+
```ruby
|
|
19
|
+
ActionDispatch::QueryParser.each_pair("foo=bar;baz=quux").to_a
|
|
20
|
+
# => [["foo", "bar;baz=quux"]]
|
|
21
|
+
```
|
|
18
22
|
|
|
19
|
-
|
|
20
|
-
a Rake task, it was possible under certain conditions that all routes would be cleared.
|
|
21
|
-
If ran inside a middleware, this would result in getting a 404 on most page you visit.
|
|
22
|
-
This issue was only happening in development.
|
|
23
|
+
*Rafael Mendonça França*
|
|
23
24
|
|
|
24
|
-
|
|
25
|
+
* Remove deprecated support to skipping over leading brackets in parameter names in the parameter parser.
|
|
25
26
|
|
|
26
|
-
|
|
27
|
+
Before:
|
|
27
28
|
|
|
29
|
+
```ruby
|
|
30
|
+
ActionDispatch::ParamBuilder.from_query_string("[foo]=bar") # => { "foo" => "bar" }
|
|
31
|
+
ActionDispatch::ParamBuilder.from_query_string("[foo][bar]=baz") # => { "foo" => { "bar" => "baz" } }
|
|
28
32
|
```
|
|
29
|
-
|
|
30
|
-
|
|
33
|
+
|
|
34
|
+
After:
|
|
35
|
+
|
|
36
|
+
```ruby
|
|
37
|
+
ActionDispatch::ParamBuilder.from_query_string("[foo]=bar") # => { "[foo]" => "bar" }
|
|
38
|
+
ActionDispatch::ParamBuilder.from_query_string("[foo][bar]=baz") # => { "[foo]" => { "bar" => "baz" } }
|
|
31
39
|
```
|
|
32
40
|
|
|
33
|
-
|
|
41
|
+
*Rafael Mendonça França*
|
|
34
42
|
|
|
35
|
-
|
|
43
|
+
* Deprecate `Rails.application.config.action_dispatch.ignore_leading_brackets`.
|
|
36
44
|
|
|
37
|
-
*
|
|
45
|
+
*Rafael Mendonça França*
|
|
38
46
|
|
|
39
|
-
|
|
47
|
+
* Raise `ActionController::TooManyRequests` error from `ActionController::RateLimiting`
|
|
40
48
|
|
|
41
|
-
|
|
42
|
-
`
|
|
49
|
+
Requests that exceed the rate limit raise an `ActionController::TooManyRequests` error.
|
|
50
|
+
By default, Action Dispatch rescues the error and responds with a `429 Too Many Requests` status.
|
|
43
51
|
|
|
44
|
-
|
|
52
|
+
*Sean Doyle*
|
|
45
53
|
|
|
46
|
-
|
|
54
|
+
* Add .md/.markdown as Markdown extensions and add a default `markdown:` renderer:
|
|
47
55
|
|
|
56
|
+
```ruby
|
|
57
|
+
class Page
|
|
58
|
+
def to_markdown
|
|
59
|
+
body
|
|
60
|
+
end
|
|
61
|
+
end
|
|
48
62
|
|
|
49
|
-
|
|
63
|
+
class PagesController < ActionController::Base
|
|
64
|
+
def show
|
|
65
|
+
@page = Page.find(params[:id])
|
|
50
66
|
|
|
51
|
-
|
|
67
|
+
respond_to do |format|
|
|
68
|
+
format.html
|
|
69
|
+
format.md { render markdown: @page }
|
|
70
|
+
end
|
|
71
|
+
end
|
|
72
|
+
end
|
|
73
|
+
```
|
|
52
74
|
|
|
53
|
-
|
|
75
|
+
*DHH*
|
|
54
76
|
|
|
55
|
-
*
|
|
77
|
+
* Add headers to engine routes inspection command
|
|
56
78
|
|
|
57
|
-
|
|
79
|
+
*Petrik de Heus*
|
|
58
80
|
|
|
59
|
-
|
|
81
|
+
* Add "Copy as text" button to error pages
|
|
60
82
|
|
|
61
|
-
*
|
|
83
|
+
*Mikkel Malmberg*
|
|
62
84
|
|
|
63
|
-
|
|
85
|
+
* Add `scope:` option to `rate_limit` method.
|
|
64
86
|
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
:only and :except must include only [:index, :create, :new, :show, :update, :destroy, :edit], but also included [:foo, :bar]
|
|
68
|
-
```
|
|
87
|
+
Previously, it was not possible to share a rate limit count between several controllers, since the count was by
|
|
88
|
+
default separate for each controller.
|
|
69
89
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
90
|
+
Now, the `scope:` option solves this problem.
|
|
91
|
+
|
|
92
|
+
```ruby
|
|
93
|
+
class APIController < ActionController::API
|
|
94
|
+
rate_limit to: 2, within: 2.seconds, scope: "api"
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
class API::PostsController < APIController
|
|
98
|
+
# ...
|
|
99
|
+
end
|
|
100
|
+
|
|
101
|
+
class API::UsersController < APIController
|
|
102
|
+
# ...
|
|
103
|
+
end
|
|
73
104
|
```
|
|
74
105
|
|
|
75
|
-
*
|
|
106
|
+
*ArthurPV*, *Kamil Hanus*
|
|
76
107
|
|
|
77
|
-
*
|
|
108
|
+
* Add support for `rack.response_finished` callbacks in ActionDispatch::Executor.
|
|
78
109
|
|
|
79
|
-
|
|
110
|
+
The executor middleware now supports deferring completion callbacks to later
|
|
111
|
+
in the request lifecycle by utilizing Rack's `rack.response_finished` mechanism,
|
|
112
|
+
when available. This enables applications to define `rack.response_finished` callbacks
|
|
113
|
+
that may rely on state that would be cleaned up by the executor's completion callbacks.
|
|
80
114
|
|
|
81
|
-
*
|
|
115
|
+
*Adrianna Chang*, *Hartley McGuire*
|
|
82
116
|
|
|
83
|
-
*
|
|
117
|
+
* Produce a log when `rescue_from` is invoked.
|
|
84
118
|
|
|
85
|
-
*Jean Boussier*
|
|
119
|
+
*Steven Webb*, *Jean Boussier*
|
|
86
120
|
|
|
121
|
+
* Allow hosts redirects from `hosts` Rails configuration
|
|
87
122
|
|
|
88
|
-
|
|
123
|
+
```ruby
|
|
124
|
+
config.action_controller.allowed_redirect_hosts << "example.com"
|
|
125
|
+
```
|
|
89
126
|
|
|
90
|
-
*
|
|
127
|
+
*Kevin Robatel*
|
|
91
128
|
|
|
92
|
-
|
|
129
|
+
* `rate_limit.action_controller` notification has additional payload
|
|
93
130
|
|
|
131
|
+
additional values: count, to, within, by, name, cache_key
|
|
94
132
|
|
|
95
|
-
|
|
133
|
+
*Jonathan Rochkind*
|
|
96
134
|
|
|
97
|
-
* Add
|
|
98
|
-
Developers should use multiple arguments, and different directive methods instead.
|
|
135
|
+
* Add JSON support to the built-in health controller.
|
|
99
136
|
|
|
100
|
-
|
|
137
|
+
The health controller now responds to JSON requests with a structured response
|
|
138
|
+
containing status and timestamp information. This makes it easier for monitoring
|
|
139
|
+
tools and load balancers to consume health check data programmatically.
|
|
101
140
|
|
|
102
|
-
|
|
141
|
+
```ruby
|
|
142
|
+
# /up.json
|
|
143
|
+
{
|
|
144
|
+
"status": "up",
|
|
145
|
+
"timestamp": "2025-09-19T12:00:00Z"
|
|
146
|
+
}
|
|
147
|
+
```
|
|
103
148
|
|
|
149
|
+
*Francesco Loreti*, *Juan Vásquez*
|
|
104
150
|
|
|
105
|
-
|
|
151
|
+
* Allow to open source file with a crash from the browser.
|
|
106
152
|
|
|
107
|
-
*
|
|
153
|
+
*Igor Kasyanchuk*
|
|
108
154
|
|
|
155
|
+
* Always check query string keys for valid encoding just like values are checked.
|
|
109
156
|
|
|
110
|
-
|
|
157
|
+
*Casper Smits*
|
|
111
158
|
|
|
112
|
-
*
|
|
159
|
+
* Always return empty body for HEAD requests in `PublicExceptions` and
|
|
160
|
+
`DebugExceptions`.
|
|
113
161
|
|
|
114
|
-
|
|
162
|
+
This is required by `Rack::Lint` (per RFC9110).
|
|
163
|
+
|
|
164
|
+
*Hartley McGuire*
|
|
115
165
|
|
|
116
|
-
*
|
|
166
|
+
* Add comprehensive support for HTTP Cache-Control request directives according to RFC 9111.
|
|
117
167
|
|
|
118
|
-
|
|
168
|
+
Provides a `request.cache_control_directives` object that gives access to request cache directives:
|
|
119
169
|
|
|
170
|
+
```ruby
|
|
171
|
+
# Boolean directives
|
|
172
|
+
request.cache_control_directives.only_if_cached? # => true/false
|
|
173
|
+
request.cache_control_directives.no_cache? # => true/false
|
|
174
|
+
request.cache_control_directives.no_store? # => true/false
|
|
175
|
+
request.cache_control_directives.no_transform? # => true/false
|
|
176
|
+
|
|
177
|
+
# Value directives
|
|
178
|
+
request.cache_control_directives.max_age # => integer or nil
|
|
179
|
+
request.cache_control_directives.max_stale # => integer or nil (or true for valueless max-stale)
|
|
180
|
+
request.cache_control_directives.min_fresh # => integer or nil
|
|
181
|
+
request.cache_control_directives.stale_if_error # => integer or nil
|
|
182
|
+
|
|
183
|
+
# Special helpers for max-stale
|
|
184
|
+
request.cache_control_directives.max_stale? # => true if max-stale present (with or without value)
|
|
185
|
+
request.cache_control_directives.max_stale_unlimited? # => true only for valueless max-stale
|
|
186
|
+
```
|
|
120
187
|
|
|
121
|
-
|
|
188
|
+
Example usage:
|
|
122
189
|
|
|
123
|
-
|
|
190
|
+
```ruby
|
|
191
|
+
def show
|
|
192
|
+
if request.cache_control_directives.only_if_cached?
|
|
193
|
+
@article = Article.find_cached(params[:id])
|
|
194
|
+
return head(:gateway_timeout) if @article.nil?
|
|
195
|
+
else
|
|
196
|
+
@article = Article.find(params[:id])
|
|
197
|
+
end
|
|
198
|
+
|
|
199
|
+
render :show
|
|
200
|
+
end
|
|
201
|
+
```
|
|
124
202
|
|
|
125
|
-
*
|
|
203
|
+
*egg528*
|
|
126
204
|
|
|
127
|
-
*
|
|
205
|
+
* Add assert_in_body/assert_not_in_body as the simplest way to check if a piece of text is in the response body.
|
|
128
206
|
|
|
129
|
-
|
|
207
|
+
*DHH*
|
|
130
208
|
|
|
131
|
-
|
|
132
|
-
> When applicable, its external encoding must be “ASCII-8BIT” and it must be opened in binary mode.
|
|
209
|
+
* Include cookie name when calculating maximum allowed size.
|
|
133
210
|
|
|
134
|
-
|
|
135
|
-
behavior.
|
|
211
|
+
*Hartley McGuire*
|
|
136
212
|
|
|
137
|
-
|
|
213
|
+
* Implement `must-understand` directive according to RFC 9111.
|
|
138
214
|
|
|
139
|
-
|
|
215
|
+
The `must-understand` directive indicates that a cache must understand the semantics of the response status code, or discard the response. This directive is enforced to be used only with `no-store` to ensure proper cache behavior.
|
|
140
216
|
|
|
141
217
|
```ruby
|
|
142
|
-
class
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
218
|
+
class ArticlesController < ApplicationController
|
|
219
|
+
def show
|
|
220
|
+
@article = Article.find(params[:id])
|
|
221
|
+
|
|
222
|
+
if @article.special_format?
|
|
223
|
+
must_understand
|
|
224
|
+
render status: 203 # Non-Authoritative Information
|
|
225
|
+
else
|
|
226
|
+
fresh_when @article
|
|
148
227
|
end
|
|
228
|
+
end
|
|
149
229
|
end
|
|
150
230
|
```
|
|
151
231
|
|
|
152
|
-
*
|
|
153
|
-
|
|
154
|
-
* Raise an `ArgumentError` when invalid `:only` or `:except` options are passed into `#resource` and `#resources`.
|
|
155
|
-
|
|
156
|
-
*Joshua Young*
|
|
157
|
-
|
|
158
|
-
## Rails 8.0.0.beta1 (September 26, 2024) ##
|
|
159
|
-
|
|
160
|
-
* Fix non-GET requests not updating cookies in `ActionController::TestCase`.
|
|
232
|
+
*heka1024*
|
|
161
233
|
|
|
162
|
-
|
|
234
|
+
* The JSON renderer doesn't escape HTML entities or Unicode line separators anymore.
|
|
163
235
|
|
|
164
|
-
|
|
236
|
+
Using `render json:` will no longer escape `<`, `>`, `&`, `U+2028` and `U+2029` characters that can cause errors
|
|
237
|
+
when the resulting JSON is embedded in JavaScript, or vulnerabilities when the resulting JSON is embedded in HTML.
|
|
165
238
|
|
|
166
|
-
|
|
239
|
+
Since the renderer is used to return a JSON document as `application/json`, it's typically not necessary to escape
|
|
240
|
+
those characters, and it improves performance.
|
|
167
241
|
|
|
168
|
-
|
|
169
|
-
|
|
242
|
+
Escaping will still occur when the `:callback` option is set, since the JSON is used as JavaScript code in this
|
|
243
|
+
situation (JSONP).
|
|
170
244
|
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
errors caused by params tampering.
|
|
245
|
+
You can use the `:escape` option or set `config.action_controller.escape_json_responses` to `true` to restore the
|
|
246
|
+
escaping behavior.
|
|
174
247
|
|
|
175
248
|
```ruby
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
# After
|
|
182
|
-
params.expect(person: [ :name, :age, pets: [[:name]] ])
|
|
183
|
-
# raises ActionController::ParameterMissing, correctly returning a 400 error
|
|
249
|
+
class PostsController < ApplicationController
|
|
250
|
+
def index
|
|
251
|
+
render json: Post.last(30), escape: true
|
|
252
|
+
end
|
|
253
|
+
end
|
|
184
254
|
```
|
|
185
255
|
|
|
186
|
-
|
|
187
|
-
declare when a param is expected to be an array of parameter hashes,
|
|
188
|
-
this new double array syntax is used to explicitly declare an array.
|
|
189
|
-
`expect` requires you to declare expected arrays in this way, and will
|
|
190
|
-
ignore arrays that are passed when, for example, `pet: [:name]` is used.
|
|
191
|
-
|
|
192
|
-
In order to preserve compatibility, `permit` does not adopt the new
|
|
193
|
-
double array syntax and is therefore more permissive about unexpected
|
|
194
|
-
types. Using `expect` everywhere is recommended.
|
|
256
|
+
*Étienne Barrié*, *Jean Boussier*
|
|
195
257
|
|
|
196
|
-
|
|
197
|
-
with the direct replacement `params.expect(person: [:name, :age])`
|
|
198
|
-
to prevent external users from manipulating params to trigger 500
|
|
199
|
-
errors. A 400 error will be returned instead, using public/400.html
|
|
258
|
+
* Load lazy route sets before inserting test routes
|
|
200
259
|
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
is a scalar and not an array or hash, also requiring the param.
|
|
260
|
+
Without loading lazy route sets early, we miss `after_routes_loaded` callbacks, or risk
|
|
261
|
+
invoking them with the test routes instead of the real ones if another load is triggered by an engine.
|
|
204
262
|
|
|
205
|
-
|
|
206
|
-
# Before
|
|
207
|
-
User.find(params.require(:id)) # allows an array, altering behavior
|
|
263
|
+
*Gannon McGibbon*
|
|
208
264
|
|
|
209
|
-
|
|
210
|
-
User.find(params.expect(:id)) # expect only returns non-blank permitted scalars (excludes Hash, Array, nil, "", etc)
|
|
211
|
-
```
|
|
265
|
+
* Raise `AbstractController::DoubleRenderError` if `head` is called after rendering.
|
|
212
266
|
|
|
213
|
-
|
|
267
|
+
After this change, invoking `head` will lead to an error if response body is already set:
|
|
214
268
|
|
|
215
|
-
|
|
269
|
+
```ruby
|
|
270
|
+
class PostController < ApplicationController
|
|
271
|
+
def index
|
|
272
|
+
render locals: {}
|
|
273
|
+
head :ok
|
|
274
|
+
end
|
|
275
|
+
end
|
|
276
|
+
```
|
|
216
277
|
|
|
217
|
-
*
|
|
278
|
+
*Iaroslav Kurbatov*
|
|
218
279
|
|
|
219
|
-
*
|
|
280
|
+
* The Cookie Serializer can now serialize an Active Support SafeBuffer when using message pack.
|
|
220
281
|
|
|
221
|
-
|
|
282
|
+
Such code would previously produce an error if an application was using messagepack as its cookie serializer.
|
|
222
283
|
|
|
223
|
-
|
|
284
|
+
```ruby
|
|
285
|
+
class PostController < ApplicationController
|
|
286
|
+
def index
|
|
287
|
+
flash.notice = t(:hello_html) # This would try to serialize a SafeBuffer, which was not possible.
|
|
288
|
+
end
|
|
289
|
+
end
|
|
290
|
+
```
|
|
224
291
|
|
|
225
|
-
*
|
|
292
|
+
*Edouard Chin*
|
|
226
293
|
|
|
227
|
-
*
|
|
294
|
+
* Fix `Rails.application.reload_routes!` from clearing almost all routes.
|
|
228
295
|
|
|
229
|
-
|
|
296
|
+
When calling `Rails.application.reload_routes!` inside a middleware of
|
|
297
|
+
a Rake task, it was possible under certain conditions that all routes would be cleared.
|
|
298
|
+
If ran inside a middleware, this would result in getting a 404 on most page you visit.
|
|
299
|
+
This issue was only happening in development.
|
|
230
300
|
|
|
231
|
-
*
|
|
301
|
+
*Edouard Chin*
|
|
232
302
|
|
|
233
|
-
|
|
303
|
+
* Add resource name to the `ArgumentError` that's raised when invalid `:only` or `:except` options are given to `#resource` or `#resources`
|
|
234
304
|
|
|
235
|
-
|
|
236
|
-
You may use `with_options` or a loop to make drawing multiple paths easier.
|
|
305
|
+
This makes it easier to locate the source of the problem, especially for routes drawn by gems.
|
|
237
306
|
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
307
|
+
Before:
|
|
308
|
+
```
|
|
309
|
+
:only and :except must include only [:index, :create, :new, :show, :update, :destroy, :edit], but also included [:foo, :bar]
|
|
310
|
+
```
|
|
241
311
|
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
312
|
+
After:
|
|
313
|
+
```
|
|
314
|
+
Route `resources :products` - :only and :except must include only [:index, :create, :new, :show, :update, :destroy, :edit], but also included [:foo, :bar]
|
|
245
315
|
```
|
|
246
316
|
|
|
247
|
-
*
|
|
317
|
+
*Jeremy Green*
|
|
248
318
|
|
|
249
|
-
*
|
|
319
|
+
* A route pointing to a non-existing controller now returns a 500 instead of a 404.
|
|
250
320
|
|
|
251
|
-
|
|
321
|
+
A controller not existing isn't a routing error that should result
|
|
322
|
+
in a 404, but a programming error that should result in a 500 and
|
|
323
|
+
be reported.
|
|
252
324
|
|
|
253
|
-
|
|
325
|
+
Until recently, this was hard to untangle because of the support
|
|
326
|
+
for dynamic `:controller` segment in routes, but since this is
|
|
327
|
+
deprecated and will be removed in Rails 8.1, we can now easily
|
|
328
|
+
not consider missing controllers as routing errors.
|
|
254
329
|
|
|
255
|
-
|
|
256
|
-
as specified by RFC 7232, Section 6.
|
|
330
|
+
*Jean Boussier*
|
|
257
331
|
|
|
258
|
-
|
|
259
|
-
Rails 8.0 defaults.
|
|
332
|
+
* Add `check_collisions` option to `ActionDispatch::Session::CacheStore`.
|
|
260
333
|
|
|
261
|
-
|
|
334
|
+
Newly generated session ids use 128 bits of randomness, which is more than
|
|
335
|
+
enough to ensure collisions can't happen, but if you need to harden sessions
|
|
336
|
+
even more, you can enable this option to check in the session store that the id
|
|
337
|
+
is indeed free you can enable that option. This however incurs an extra write
|
|
338
|
+
on session creation.
|
|
262
339
|
|
|
263
|
-
*
|
|
340
|
+
*Shia*
|
|
264
341
|
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
```
|
|
342
|
+
* In ExceptionWrapper, match backtrace lines with built templates more often,
|
|
343
|
+
allowing improved highlighting of errors within do-end blocks in templates.
|
|
344
|
+
Fix for Ruby 3.4 to match new method labels in backtrace.
|
|
269
345
|
|
|
270
|
-
*
|
|
346
|
+
*Martin Emde*
|
|
271
347
|
|
|
272
|
-
*
|
|
348
|
+
* Allow setting content type with a symbol of the Mime type.
|
|
273
349
|
|
|
274
350
|
```ruby
|
|
275
351
|
# Before
|
|
276
|
-
|
|
352
|
+
response.content_type = "text/html"
|
|
277
353
|
|
|
278
354
|
# After
|
|
279
|
-
|
|
355
|
+
response.content_type = :html
|
|
280
356
|
```
|
|
281
357
|
|
|
282
|
-
*
|
|
283
|
-
|
|
284
|
-
* Add `display_capture` and `keyboard_map` in `permissions_policy`
|
|
285
|
-
|
|
286
|
-
*Cyril Blaecke*
|
|
287
|
-
|
|
288
|
-
* Add `connect` route helper.
|
|
289
|
-
|
|
290
|
-
*Samuel Williams*
|
|
358
|
+
*Petrik de Heus*
|
|
291
359
|
|
|
292
|
-
Please check [
|
|
360
|
+
Please check [8-0-stable](https://github.com/rails/rails/blob/8-0-stable/actionpack/CHANGELOG.md) for previous changes.
|
|
@@ -7,8 +7,10 @@ module AbstractController
|
|
|
7
7
|
extend ActiveSupport::Concern
|
|
8
8
|
|
|
9
9
|
included do
|
|
10
|
-
|
|
11
|
-
:stylesheets_dir, :default_asset_host_protocol, :relative_url_root
|
|
10
|
+
singleton_class.delegate :asset_host, :asset_host=, :assets_dir, :assets_dir=, :javascripts_dir, :javascripts_dir=,
|
|
11
|
+
:stylesheets_dir, :stylesheets_dir=, :default_asset_host_protocol, :default_asset_host_protocol=, :relative_url_root, :relative_url_root=, to: :config
|
|
12
|
+
delegate :asset_host, :asset_host=, :assets_dir, :assets_dir=, :javascripts_dir, :javascripts_dir=,
|
|
13
|
+
:stylesheets_dir, :stylesheets_dir=, :default_asset_host_protocol, :default_asset_host_protocol=, :relative_url_root, :relative_url_root=, to: :config
|
|
12
14
|
end
|
|
13
15
|
end
|
|
14
16
|
end
|
|
@@ -3,7 +3,6 @@
|
|
|
3
3
|
# :markup: markdown
|
|
4
4
|
|
|
5
5
|
require "abstract_controller/error"
|
|
6
|
-
require "active_support/configurable"
|
|
7
6
|
require "active_support/descendants_tracker"
|
|
8
7
|
require "active_support/core_ext/module/anonymous"
|
|
9
8
|
require "active_support/core_ext/module/attr_internal"
|
|
@@ -47,7 +46,7 @@ module AbstractController
|
|
|
47
46
|
# Returns the formats that can be processed by the controller.
|
|
48
47
|
attr_internal :formats
|
|
49
48
|
|
|
50
|
-
|
|
49
|
+
class_attribute :config, instance_predicate: false, default: ActiveSupport::OrderedOptions.new
|
|
51
50
|
extend ActiveSupport::DescendantsTracker
|
|
52
51
|
|
|
53
52
|
class << self
|
|
@@ -65,6 +64,7 @@ module AbstractController
|
|
|
65
64
|
unless klass.instance_variable_defined?(:@abstract)
|
|
66
65
|
klass.instance_variable_set(:@abstract, false)
|
|
67
66
|
end
|
|
67
|
+
klass.config = ActiveSupport::InheritableOptions.new(config)
|
|
68
68
|
super
|
|
69
69
|
end
|
|
70
70
|
|
|
@@ -121,6 +121,10 @@ module AbstractController
|
|
|
121
121
|
@controller_path ||= name.delete_suffix("Controller").underscore unless anonymous?
|
|
122
122
|
end
|
|
123
123
|
|
|
124
|
+
def configure # :nodoc:
|
|
125
|
+
yield config
|
|
126
|
+
end
|
|
127
|
+
|
|
124
128
|
# Refresh the cached action_methods when a new action_method is added.
|
|
125
129
|
def method_added(name)
|
|
126
130
|
super
|
|
@@ -190,6 +194,10 @@ module AbstractController
|
|
|
190
194
|
true
|
|
191
195
|
end
|
|
192
196
|
|
|
197
|
+
def config # :nodoc:
|
|
198
|
+
@_config ||= self.class.config.inheritable_copy
|
|
199
|
+
end
|
|
200
|
+
|
|
193
201
|
def inspect # :nodoc:
|
|
194
202
|
"#<#{self.class.name}:#{'%#016x' % (object_id << 1)}>"
|
|
195
203
|
end
|
|
@@ -32,13 +32,16 @@ module AbstractController
|
|
|
32
32
|
included do
|
|
33
33
|
extend ConfigMethods
|
|
34
34
|
|
|
35
|
-
|
|
35
|
+
singleton_class.delegate :default_static_extension, :default_static_extension=, to: :config
|
|
36
|
+
delegate :default_static_extension, :default_static_extension=, to: :config
|
|
36
37
|
self.default_static_extension ||= ".html"
|
|
37
38
|
|
|
38
|
-
|
|
39
|
+
singleton_class.delegate :perform_caching, :perform_caching=, to: :config
|
|
40
|
+
delegate :perform_caching, :perform_caching=, to: :config
|
|
39
41
|
self.perform_caching = true if perform_caching.nil?
|
|
40
42
|
|
|
41
|
-
|
|
43
|
+
singleton_class.delegate :enable_fragment_cache_logging, :enable_fragment_cache_logging=, to: :config
|
|
44
|
+
delegate :enable_fragment_cache_logging, :enable_fragment_cache_logging=, to: :config
|
|
42
45
|
self.enable_fragment_cache_logging = false
|
|
43
46
|
|
|
44
47
|
class_attribute :_view_cache_dependencies, default: []
|
|
@@ -90,7 +90,7 @@ module AbstractController
|
|
|
90
90
|
#--
|
|
91
91
|
# Implemented by Resolution#modules_for_helpers.
|
|
92
92
|
|
|
93
|
-
# :method: all_helpers_from_path
|
|
93
|
+
# :method: # all_helpers_from_path
|
|
94
94
|
# :call-seq: all_helpers_from_path(path)
|
|
95
95
|
#
|
|
96
96
|
# Returns a list of helper names in a given path.
|