rack 3.0.12 → 3.0.14

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: f4cd617243053c032b45f1eb8f73158d61aa295bf866072d85324ae696de1e2d
4
- data.tar.gz: 84e26d26314c4e7877e21e770e6622cfe57379add2bce818f93fd50b362cd9a9
3
+ metadata.gz: aba215a5282440e26123d6d89cbd7f69c423bb5a2deb8948cdda64db357e70bd
4
+ data.tar.gz: 63f6ba8e4cfe56ab88e3ef08c9d57104b2ef5bed04a90024e01ad702bfd3521e
5
5
  SHA512:
6
- metadata.gz: f41b2be1181d9c56dee9b2264fadfd8667a27242ec254403658476d8dd9b4d142d2bd528dc74464f4d5748a8a420341a5361057d27fe5a2633c926f3c62ba46b
7
- data.tar.gz: daa0660d8c5bddcf6e9d1091d1ae0ee3c614cedd64ba2f8a0ad47ed742806517cd2552108116cebe53bb8bec60d97b46e00c3ec6520fa9f85d54b56d07f20939
6
+ metadata.gz: 8f4c65b5ebf1b508a389ecc8a9863c23eb486441eb0067b3d97c8fc715c8c9cb5df570cdb887e7aee84256baa92a027a42bd71757d3eb208d5818c201848ca29
7
+ data.tar.gz: 62af3b727ae2110984d2b58699483a40be233bd766f2f35d7dec07c56369ad942b72866a768068390e46b39e42c4e51e0461573f02cd9166cf8e43ceabb59284
data/CHANGELOG.md CHANGED
@@ -2,11 +2,27 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. For info on how to format all future additions to this file please reference [Keep A Changelog](https://keepachangelog.com/en/1.0.0/).
4
4
 
5
+ ## [3.0.14] - 2025-03-11
6
+
7
+ ### Security
8
+
9
+ - [CVE-2025-27610](https://github.com/rack/rack/security/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
10
+
11
+ ## [3.0.13] - 2025-03-04
12
+
13
+ ### Security
14
+
15
+ - [CVE-2025-27111](https://github.com/rack/rack/security/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
16
+
17
+ ### Fixed
18
+
19
+ - Remove autoloads for constants no longer shipped with Rack. ([#2269](https://github.com/rack/rack/pull/2269), [@ccutrer](https://github.com/ccutrer))
20
+
5
21
  ## [3.0.12] - 2025-02-12
6
22
 
7
23
  ### Security
8
24
 
9
- - [CVE-2025-25184](https://github.com/rack/rack/security/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in Rack::CommonLogger.
25
+ - [CVE-2025-25184](https://github.com/rack/rack/security/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
10
26
 
11
27
  ## [3.0.11] - 2024-05-10
12
28
 
@@ -184,6 +200,70 @@ All notable changes to this project will be documented in this file. For info on
184
200
  - Fix multipart filename generation for filenames that contain spaces. Encode spaces as "%20" instead of "+" which will be decoded properly by the multipart parser. ([#1736](https://github.com/rack/rack/pull/1645), [@muirdm](https://github.com/muirdm))
185
201
  - `Rack::Request#scheme` returns `ws` or `wss` when one of the `X-Forwarded-Scheme` / `X-Forwarded-Proto` headers is set to `ws` or `wss`, respectively. ([#1730](https://github.com/rack/rack/issues/1730), [@erwanst](https://github.com/erwanst))
186
202
 
203
+ ## [2.2.13] - 2025-03-11
204
+
205
+ ### Security
206
+
207
+ - [CVE-2025-27610](https://github.com/rack/rack/security/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
208
+
209
+ ## [2.2.12] - 2025-03-04
210
+
211
+ ### Security
212
+
213
+ - [CVE-2025-27111](https://github.com/rack/rack/security/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
214
+
215
+ ## [2.2.11] - 2025-02-12
216
+
217
+ ### Security
218
+
219
+ - [CVE-2025-25184](https://github.com/rack/rack/security/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
220
+
221
+ ## [2.2.10] - 2024-10-14
222
+
223
+ - Fix compatibility issues with Ruby v3.4.0. ([#2248](https://github.com/rack/rack/pull/2248), [@byroot](https://github.com/byroot))
224
+
225
+ ## [2.2.9] - 2023-03-21
226
+
227
+ - Return empty when parsing a multi-part POST with only one end delimiter. ([#2104](https://github.com/rack/rack/pull/2104), [@alpaca-tc])
228
+
229
+ ## [2.2.8] - 2023-07-31
230
+
231
+ - Regenerate SPEC ([#2102](https://github.com/rack/rack/pull/2102), [@skipkayhil](https://github.com/skipkayhil))
232
+ - Limit file extension length of multipart tempfiles ([#2015](https://github.com/rack/rack/pull/2015), [@dentarg](https://github.com/dentarg))
233
+ - Fix "undefined method DelegateClass for Rack::Session::Cookie:Class" ([#2092](https://github.com/rack/rack/pull/2092), [@onigra](https://github.com/onigra) [@dchandekstark](https://github.com/dchandekstark))
234
+
235
+ ## [2.2.7] - 2023-03-13
236
+
237
+ - Correct the year number in the changelog ([#2015](https://github.com/rack/rack/pull/2015), [@kimulab](https://github.com/kimulab))
238
+ - Support underscore in host names for Rack 2.2 (Fixes [#2070](https://github.com/rack/rack/issues/2070)) ([#2015](https://github.com/rack/rack/pull/2071), [@jeremyevans](https://github.com/jeremyevans))
239
+
240
+ ## [2.2.6.4] - 2023-03-13
241
+
242
+ - [CVE-2023-27539] Avoid ReDoS in header parsing
243
+
244
+ ## [2.2.6.3] - 2023-03-02
245
+
246
+ - [CVE-2023-27530] Introduce multipart_total_part_limit to limit total parts
247
+
248
+ ## [2.2.6.2] - 2023-01-17
249
+
250
+ - [CVE-2022-44570] Fix ReDoS in Rack::Utils.get_byte_ranges
251
+
252
+ ## [2.2.6.1] - 2023-01-17
253
+
254
+ - [CVE-2022-44571] Fix ReDoS vulnerability in multipart parser
255
+ - [CVE-2022-44572] Forbid control characters in attributes (also ReDoS)
256
+
257
+ ## [2.2.6] - 2023-01-17
258
+
259
+ - Extend `Rack::MethodOverride` to handle `QueryParser::ParamsTooDeepError` error. ([#2011](https://github.com/rack/rack/pull/2011), [@byroot](https://github.com/byroot))
260
+
261
+ ## [2.2.5] - 2022-12-27
262
+
263
+ ### Fixed
264
+
265
+ - `Rack::URLMap` uses non-deprecated form of `Regexp.new`. ([#1998](https://github.com/rack/rack/pull/1998), [@weizheheng](https://github.com/weizheheng))
266
+
187
267
  ## [2.2.4] - 2022-06-30
188
268
 
189
269
  - Better support for lower case headers in `Rack::ETag` middleware. ([#1919](https://github.com/rack/rack/pull/1919), [@ioquatix](https://github.com/ioquatix))
data/lib/rack/sendfile.rb CHANGED
@@ -138,7 +138,7 @@ module Rack
138
138
  end
139
139
  when '', nil
140
140
  else
141
- env[RACK_ERRORS].puts "Unknown x-sendfile variation: '#{type}'.\n"
141
+ env[RACK_ERRORS].puts "Unknown x-sendfile variation: #{type.inspect}"
142
142
  end
143
143
  end
144
144
  response
data/lib/rack/static.rb CHANGED
@@ -124,8 +124,9 @@ module Rack
124
124
 
125
125
  def call(env)
126
126
  path = env[PATH_INFO]
127
+ actual_path = Utils.clean_path_info(Utils.unescape_path(path))
127
128
 
128
- if can_serve(path)
129
+ if can_serve(actual_path)
129
130
  if overwrite_file_path(path)
130
131
  env[PATH_INFO] = (add_index_root?(path) ? path + @index : @urls[path])
131
132
  elsif @gzip && env['HTTP_ACCEPT_ENCODING'] && /\bgzip\b/.match?(env['HTTP_ACCEPT_ENCODING'])
data/lib/rack/version.rb CHANGED
@@ -25,7 +25,7 @@ module Rack
25
25
  VERSION
26
26
  end
27
27
 
28
- RELEASE = "3.0.12"
28
+ RELEASE = "3.0.14"
29
29
 
30
30
  # Return the Rack release as a dotted string.
31
31
  def self.release
data/lib/rack.rb CHANGED
@@ -15,8 +15,8 @@ require_relative 'rack/version'
15
15
  require_relative 'rack/constants'
16
16
 
17
17
  module Rack
18
- autoload :Builder, "rack/builder"
19
18
  autoload :BodyProxy, "rack/body_proxy"
19
+ autoload :Builder, "rack/builder"
20
20
  autoload :Cascade, "rack/cascade"
21
21
  autoload :Chunked, "rack/chunked"
22
22
  autoload :CommonLogger, "rack/common_logger"
@@ -24,14 +24,13 @@ module Rack
24
24
  autoload :Config, "rack/config"
25
25
  autoload :ContentLength, "rack/content_length"
26
26
  autoload :ContentType, "rack/content_type"
27
+ autoload :Deflater, "rack/deflater"
28
+ autoload :Directory, "rack/directory"
27
29
  autoload :ETag, "rack/etag"
28
30
  autoload :Events, "rack/events"
29
31
  autoload :File, "rack/file"
30
32
  autoload :Files, "rack/files"
31
- autoload :Deflater, "rack/deflater"
32
- autoload :Directory, "rack/directory"
33
33
  autoload :ForwardRequest, "rack/recursive"
34
- autoload :Handler, "rack/handler"
35
34
  autoload :Head, "rack/head"
36
35
  autoload :Headers, "rack/headers"
37
36
  autoload :Lint, "rack/lint"
@@ -40,32 +39,29 @@ module Rack
40
39
  autoload :MediaType, "rack/media_type"
41
40
  autoload :MethodOverride, "rack/method_override"
42
41
  autoload :Mime, "rack/mime"
42
+ autoload :MockRequest, "rack/mock_request"
43
+ autoload :MockResponse, "rack/mock_response"
44
+ autoload :Multipart, "rack/multipart"
43
45
  autoload :NullLogger, "rack/null_logger"
44
46
  autoload :QueryParser, "rack/query_parser"
45
47
  autoload :Recursive, "rack/recursive"
46
48
  autoload :Reloader, "rack/reloader"
49
+ autoload :Request, "rack/request"
50
+ autoload :Response, "rack/response"
47
51
  autoload :RewindableInput, "rack/rewindable_input"
48
52
  autoload :Runtime, "rack/runtime"
49
53
  autoload :Sendfile, "rack/sendfile"
50
- autoload :Server, "rack/server"
51
54
  autoload :ShowExceptions, "rack/show_exceptions"
52
55
  autoload :ShowStatus, "rack/show_status"
53
56
  autoload :Static, "rack/static"
54
57
  autoload :TempfileReaper, "rack/tempfile_reaper"
55
58
  autoload :URLMap, "rack/urlmap"
56
59
  autoload :Utils, "rack/utils"
57
- autoload :Multipart, "rack/multipart"
58
-
59
- autoload :MockRequest, "rack/mock_request"
60
- autoload :MockResponse, "rack/mock_response"
61
-
62
- autoload :Request, "rack/request"
63
- autoload :Response, "rack/response"
64
60
 
65
61
  module Auth
66
62
  autoload :Basic, "rack/auth/basic"
67
- autoload :AbstractRequest, "rack/auth/abstract/request"
68
- autoload :AbstractHandler, "rack/auth/abstract/handler"
69
63
  autoload :Digest, "rack/auth/digest"
64
+ autoload :AbstractHandler, "rack/auth/abstract/handler"
65
+ autoload :AbstractRequest, "rack/auth/abstract/request"
70
66
  end
71
67
  end
metadata CHANGED
@@ -1,13 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rack
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.0.12
4
+ version: 3.0.14
5
5
  platform: ruby
6
6
  authors:
7
7
  - Leah Neukirchen
8
8
  bindir: bin
9
9
  cert_chain: []
10
- date: 2025-02-12 00:00:00.000000000 Z
10
+ date: 2025-03-10 00:00:00.000000000 Z
11
11
  dependencies:
12
12
  - !ruby/object:Gem::Dependency
13
13
  name: minitest