rails-rfc6570 3.5.1 → 3.6.0

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.
Files changed (64) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +8 -0
  3. data/README.md +2 -2
  4. data/lib/rails/rfc6570/version.rb +2 -2
  5. data/rails-rfc6570.gemspec +1 -1
  6. data/vendor/bundle/ruby/3.4.0/gems/actionpack-8.1.1/CHANGELOG.md +477 -0
  7. data/vendor/bundle/ruby/3.4.0/gems/actionview-8.1.1/CHANGELOG.md +139 -0
  8. data/vendor/bundle/ruby/3.4.0/gems/activesupport-8.1.1/CHANGELOG.md +465 -0
  9. data/vendor/bundle/ruby/3.4.0/gems/{addressable-2.8.7 → addressable-2.8.8}/CHANGELOG.md +55 -46
  10. data/vendor/bundle/ruby/3.4.0/gems/{addressable-2.8.7 → addressable-2.8.8}/README.md +6 -6
  11. data/vendor/bundle/ruby/3.4.0/gems/{addressable-2.8.7 → addressable-2.8.8}/addressable.gemspec +6 -6
  12. data/vendor/bundle/ruby/3.4.0/gems/json-2.16.0/README.md +299 -0
  13. data/vendor/bundle/ruby/3.4.0/gems/json-2.16.0/json.gemspec +62 -0
  14. data/vendor/bundle/ruby/3.4.0/gems/{minitest-5.25.5 → minitest-5.26.2}/README.rdoc +10 -8
  15. data/vendor/bundle/ruby/3.4.0/gems/{public_suffix-6.0.2 → public_suffix-7.0.0}/CHANGELOG.md +8 -0
  16. data/vendor/bundle/ruby/3.4.0/gems/{public_suffix-6.0.2 → public_suffix-7.0.0}/README.md +38 -29
  17. data/vendor/bundle/ruby/3.4.0/gems/{rack-3.2.1 → rack-3.2.4}/CHANGELOG.md +81 -14
  18. data/vendor/bundle/ruby/3.4.0/gems/{rack-3.2.1 → rack-3.2.4}/README.md +8 -0
  19. data/vendor/bundle/ruby/3.4.0/gems/{rake-13.3.0 → rake-13.3.1}/rake.gemspec +1 -1
  20. data/vendor/bundle/ruby/3.4.0/specifications/{actionpack-8.0.3.gemspec → actionpack-8.1.1.gemspec} +6 -6
  21. data/vendor/bundle/ruby/3.4.0/specifications/{actionview-8.0.3.gemspec → actionview-8.1.1.gemspec} +6 -6
  22. data/vendor/bundle/ruby/3.4.0/specifications/{activesupport-8.0.3.gemspec → activesupport-8.1.1.gemspec} +4 -4
  23. data/vendor/bundle/ruby/3.4.0/specifications/{addressable-2.8.7.gemspec → addressable-2.8.8.gemspec} +6 -6
  24. data/vendor/bundle/ruby/3.4.0/specifications/{bigdecimal-3.2.3.gemspec → bigdecimal-3.3.1.gemspec} +2 -2
  25. data/vendor/bundle/ruby/3.4.0/specifications/{connection_pool-2.5.4.gemspec → connection_pool-2.5.5.gemspec} +2 -2
  26. data/vendor/bundle/ruby/3.4.0/specifications/json-2.16.0.gemspec +0 -0
  27. data/vendor/bundle/ruby/3.4.0/specifications/{minitest-5.25.5.gemspec → minitest-5.26.2.gemspec} +6 -6
  28. data/vendor/bundle/ruby/3.4.0/specifications/{public_suffix-6.0.2.gemspec → public_suffix-7.0.0.gemspec} +5 -5
  29. data/vendor/bundle/ruby/3.4.0/specifications/{rack-3.2.1.gemspec → rack-3.2.4.gemspec} +2 -2
  30. data/vendor/bundle/ruby/3.4.0/specifications/{rake-13.3.0.gemspec → rake-13.3.1.gemspec} +4 -4
  31. data/vendor/bundle/ruby/3.4.0/specifications/{rspec-3.13.1.gemspec → rspec-3.13.2.gemspec} +4 -4
  32. data/vendor/bundle/ruby/3.4.0/specifications/{rspec-core-3.13.5.gemspec → rspec-core-3.13.6.gemspec} +4 -4
  33. data/vendor/bundle/ruby/3.4.0/specifications/{rspec-mocks-3.13.5.gemspec → rspec-mocks-3.13.7.gemspec} +5 -5
  34. data/vendor/bundle/ruby/3.4.0/specifications/{uri-1.0.3.gemspec → uri-1.1.1.gemspec} +4 -4
  35. metadata +55 -55
  36. data/vendor/bundle/ruby/3.4.0/gems/actionpack-8.0.3/CHANGELOG.md +0 -285
  37. data/vendor/bundle/ruby/3.4.0/gems/actionview-8.0.3/CHANGELOG.md +0 -129
  38. data/vendor/bundle/ruby/3.4.0/gems/activesupport-8.0.3/CHANGELOG.md +0 -309
  39. data/vendor/bundle/ruby/3.4.0/gems/benchmark-0.4.1/README.md +0 -138
  40. data/vendor/bundle/ruby/3.4.0/gems/benchmark-0.4.1/benchmark.gemspec +0 -32
  41. data/vendor/bundle/ruby/3.4.0/specifications/benchmark-0.4.1.gemspec +0 -23
  42. /data/vendor/bundle/ruby/3.4.0/gems/{actionpack-8.0.3 → actionpack-8.1.1}/MIT-LICENSE +0 -0
  43. /data/vendor/bundle/ruby/3.4.0/gems/{actionpack-8.0.3 → actionpack-8.1.1}/README.rdoc +0 -0
  44. /data/vendor/bundle/ruby/3.4.0/gems/{actionview-8.0.3 → actionview-8.1.1}/MIT-LICENSE +0 -0
  45. /data/vendor/bundle/ruby/3.4.0/gems/{actionview-8.0.3 → actionview-8.1.1}/README.rdoc +0 -0
  46. /data/vendor/bundle/ruby/3.4.0/gems/{activesupport-8.0.3 → activesupport-8.1.1}/MIT-LICENSE +0 -0
  47. /data/vendor/bundle/ruby/3.4.0/gems/{activesupport-8.0.3 → activesupport-8.1.1}/README.rdoc +0 -0
  48. /data/vendor/bundle/ruby/3.4.0/gems/{addressable-2.8.7 → addressable-2.8.8}/LICENSE.txt +0 -0
  49. /data/vendor/bundle/ruby/3.4.0/gems/{bigdecimal-3.2.3 → bigdecimal-3.3.1}/LICENSE +0 -0
  50. /data/vendor/bundle/ruby/3.4.0/gems/{bigdecimal-3.2.3 → bigdecimal-3.3.1}/bigdecimal.gemspec +0 -0
  51. /data/vendor/bundle/ruby/3.4.0/gems/{connection_pool-2.5.4 → connection_pool-2.5.5}/LICENSE +0 -0
  52. /data/vendor/bundle/ruby/3.4.0/gems/{connection_pool-2.5.4 → connection_pool-2.5.5}/README.md +0 -0
  53. /data/vendor/bundle/ruby/3.4.0/gems/{connection_pool-2.5.4 → connection_pool-2.5.5}/connection_pool.gemspec +0 -0
  54. /data/vendor/bundle/ruby/3.4.0/gems/{public_suffix-6.0.2 → public_suffix-7.0.0}/LICENSE.txt +0 -0
  55. /data/vendor/bundle/ruby/3.4.0/gems/{rack-3.2.1 → rack-3.2.4}/MIT-LICENSE +0 -0
  56. /data/vendor/bundle/ruby/3.4.0/gems/{rake-13.3.0 → rake-13.3.1}/MIT-LICENSE +0 -0
  57. /data/vendor/bundle/ruby/3.4.0/gems/{rake-13.3.0 → rake-13.3.1}/README.rdoc +0 -0
  58. /data/vendor/bundle/ruby/3.4.0/gems/{rspec-3.13.1 → rspec-3.13.2}/LICENSE.md +0 -0
  59. /data/vendor/bundle/ruby/3.4.0/gems/{rspec-3.13.1 → rspec-3.13.2}/README.md +0 -0
  60. /data/vendor/bundle/ruby/3.4.0/gems/{rspec-core-3.13.5 → rspec-core-3.13.6}/LICENSE.md +0 -0
  61. /data/vendor/bundle/ruby/3.4.0/gems/{rspec-core-3.13.5 → rspec-core-3.13.6}/README.md +0 -0
  62. /data/vendor/bundle/ruby/3.4.0/gems/{rspec-mocks-3.13.5 → rspec-mocks-3.13.7}/LICENSE.md +0 -0
  63. /data/vendor/bundle/ruby/3.4.0/gems/{rspec-mocks-3.13.5 → rspec-mocks-3.13.7}/README.md +0 -0
  64. /data/vendor/bundle/ruby/3.4.0/gems/{uri-1.0.3 → uri-1.1.1}/README.md +0 -0
@@ -0,0 +1,62 @@
1
+ # frozen_string_literal: true
2
+
3
+ version = File.foreach(File.join(__dir__, "lib/json/version.rb")) do |line|
4
+ /^\s*VERSION\s*=\s*'(.*)'/ =~ line and break $1
5
+ end rescue nil
6
+
7
+ spec = Gem::Specification.new do |s|
8
+ java_ext = Gem::Platform === s.platform && s.platform =~ 'java' || RUBY_ENGINE == 'jruby'
9
+
10
+ s.name = "json"
11
+ s.version = version
12
+
13
+ s.summary = "JSON Implementation for Ruby"
14
+ s.homepage = "https://github.com/ruby/json"
15
+ s.metadata = {
16
+ 'bug_tracker_uri' => 'https://github.com/ruby/json/issues',
17
+ 'changelog_uri' => 'https://github.com/ruby/json/blob/master/CHANGES.md',
18
+ 'documentation_uri' => 'https://docs.ruby-lang.org/en/master/JSON.html',
19
+ 'homepage_uri' => s.homepage,
20
+ 'source_code_uri' => 'https://github.com/ruby/json',
21
+ }
22
+
23
+ s.required_ruby_version = Gem::Requirement.new(">= 2.7")
24
+
25
+ if java_ext
26
+ s.description = "A JSON implementation as a JRuby extension."
27
+ s.author = "Daniel Luz"
28
+ s.email = "dev+ruby@mernen.com"
29
+ else
30
+ s.description = "This is a JSON implementation as a Ruby extension in C."
31
+ s.authors = ["Florian Frank"]
32
+ s.email = "flori@ping.de"
33
+ end
34
+
35
+ s.licenses = ["Ruby"]
36
+
37
+ s.extra_rdoc_files = ["README.md"]
38
+ s.rdoc_options = ["--title", "JSON implementation for Ruby", "--main", "README.md"]
39
+
40
+ s.files = [
41
+ "CHANGES.md",
42
+ "COPYING",
43
+ "BSDL",
44
+ "LEGAL",
45
+ "README.md",
46
+ "json.gemspec",
47
+ ] + Dir.glob("lib/**/*.rb", base: File.expand_path("..", __FILE__))
48
+
49
+ if java_ext
50
+ s.platform = 'java'
51
+ s.files += Dir["lib/json/ext/**/*.jar"]
52
+ else
53
+ s.extensions = Dir["ext/json/**/extconf.rb"]
54
+ s.files += Dir["ext/json/**/*.{c,h,rb}"]
55
+ end
56
+ end
57
+
58
+ if RUBY_ENGINE == 'jruby' && $0 == __FILE__
59
+ Gem::Builder.new(spec).build
60
+ else
61
+ spec
62
+ end
@@ -95,7 +95,9 @@ Given that you'd like to test the following class:
95
95
 
96
96
  === Unit tests
97
97
 
98
- Define your tests as methods beginning with +test_+.
98
+ Define your tests as methods beginning with +test_+. Use
99
+ {assertions}[/minitest/Minitest/Assertions.html] to test for results
100
+ or state.
99
101
 
100
102
  require "minitest/autorun"
101
103
 
@@ -119,6 +121,9 @@ Define your tests as methods beginning with +test_+.
119
121
 
120
122
  === Specs
121
123
 
124
+ Use {expectations}[/minitest/Minitest/Expectations.html] to check
125
+ results or state. They must be wrapped in a value call (eg +_+).
126
+
122
127
  require "minitest/autorun"
123
128
 
124
129
  describe Meme do
@@ -146,7 +151,7 @@ For matchers support check out:
146
151
 
147
152
  === Benchmarks
148
153
 
149
- Add benchmarks to your tests.
154
+ Add {benchmarks}[/minitest/Minitest/Benchmark.html] to your tests.
150
155
 
151
156
  # optionally run benchmarks, good for CI-only work!
152
157
  require "minitest/benchmark" if ENV["BENCH"]
@@ -422,13 +427,10 @@ Current versions of rails: (https://endoflife.date/rails)
422
427
 
423
428
  | rails | min ruby | minitest | status | EOL Date |
424
429
  |-------+----------+----------+----------+------------|
430
+ | 8.1 | >= 3.2 | >= 5.1 | Current | 2027-10-07 |
425
431
  | 8.0 | >= 3.2 | >= 5.1 | Current | 2026-11-07 |
426
- | 7.2 | >= 3.1 | >= 5.1 | Current | 2026-08-09 |
427
- | 7.1 | >= 2.7 | >= 5.1 | Security | 2025-10-01 |
428
- | 7.0 | >= 2.7 | >= 5.1 | Security | 2025-04-01 |
429
- | 6.1 | >= 2.5 | >= 5.1 | EOL | 2024-10-01 |
430
- | 6.0 | >= 2.5 | >= 5.1 | EOL | 2023-06-01 |
431
- | 5.2 | >= 2.2.2 | ~> 5.1 | EOL | 2022-06-01 |
432
+ | 7.2 | >= 3.1 | >= 5.1 | Security | 2026-08-09 |
433
+ | 7.1 | >= 2.7 | >= 5.1 | EOL | 2025-10-01 |
432
434
 
433
435
  If you want to look at the requirements for a specific version, run:
434
436
 
@@ -3,6 +3,14 @@
3
3
  This project uses [Semantic Versioning 2.0.0](https://semver.org/).
4
4
 
5
5
 
6
+ ## 7.0.0
7
+
8
+ ### Changed
9
+
10
+ - Updated definitions.
11
+ - Minimum Ruby version is 3.2
12
+
13
+
6
14
  ## 6.0.2
7
15
 
8
16
  ### Changed
@@ -1,6 +1,6 @@
1
- # Public Suffix <small>for Ruby</small>
1
+ # PublicSuffix for Ruby
2
2
 
3
- <tt>PublicSuffix</tt> is a Ruby domain name parser based on the [Public Suffix List](https://publicsuffix.org/).
3
+ `PublicSuffix` is a Ruby domain name parser based on the [Public Suffix List](https://publicsuffix.org/).
4
4
 
5
5
  [![Build Status](https://github.com/weppos/publicsuffix-ruby/actions/workflows/tests.yml/badge.svg)](https://github.com/weppos/publicsuffix-ruby/actions/workflows/tests.yml)
6
6
  [![Tidelift dependencies](https://tidelift.com/badges/package/rubygems/public_suffix)](https://tidelift.com/subscription/pkg/rubygems-public-suffix?utm_source=rubygems-public-suffix&utm_medium=referral&utm_campaign=enterprise)
@@ -16,7 +16,7 @@
16
16
 
17
17
  ## Requirements
18
18
 
19
- <tt>PublicSuffix</tt> requires **Ruby >= 3.0**. For an older versions of Ruby use a previous release.
19
+ `PublicSuffix` requires **Ruby >= 3.2**. For older versions of Ruby, use a previous release.
20
20
 
21
21
 
22
22
  ## Installation
@@ -106,9 +106,9 @@ PublicSuffix.valid?("example.tldnotlisted", default_rule: nil)
106
106
  ```
107
107
 
108
108
 
109
- ## Fully Qualified Domain Names
109
+ ## Fully qualified domain names
110
110
 
111
- This library automatically recognizes Fully Qualified Domain Names. A FQDN is a domain name that end with a trailing dot.
111
+ This library automatically recognizes Fully Qualified Domain Names. A FQDN is a domain name that ends with a trailing dot.
112
112
 
113
113
  ```ruby
114
114
  # Parse a standard domain name
@@ -122,7 +122,7 @@ PublicSuffix.domain("www.google.com.")
122
122
 
123
123
  ## Private domains
124
124
 
125
- This library has support for switching off support for private (non-ICANN).
125
+ This library supports toggling private (non-ICANN) domain handling.
126
126
 
127
127
  ```ruby
128
128
  # Extract a domain including private domains (by default)
@@ -148,15 +148,15 @@ PublicSuffix.domain("something.blogspot.com")
148
148
  # => "blogspot.com"
149
149
  ```
150
150
 
151
- ## Add domain to list
151
+ ## Adding custom domains
152
152
 
153
- If you want to manually add a domain to the list just run:
153
+ To manually add a domain to the list:
154
154
 
155
155
  ```ruby
156
156
  PublicSuffix::List.default << PublicSuffix::Rule.factory('onmicrosoft.com')
157
157
  ```
158
158
 
159
- ## What is the Public Suffix List?
159
+ ## What is the public suffix list?
160
160
 
161
161
  The [Public Suffix List](https://publicsuffix.org) is a cross-vendor initiative to provide an accurate list of domain name suffixes.
162
162
 
@@ -165,7 +165,7 @@ The Public Suffix List is an initiative of the Mozilla Project, but is maintaine
165
165
  A "public suffix" is one under which Internet users can directly register names. Some examples of public suffixes are ".com", ".co.uk" and "pvt.k12.wy.us". The Public Suffix List is a list of all known public suffixes.
166
166
 
167
167
 
168
- ## Why the Public Suffix List is better than any available Regular Expression parser?
168
+ ## Why use the public suffix list instead of regular expressions?
169
169
 
170
170
  Previously, browsers used an algorithm which basically only denied setting wide-ranging cookies for top-level domains with no dots (e.g. com or org). However, this did not work for top-level domains where only third-level registrations are allowed (e.g. co.uk). In these cases, websites could set a cookie for co.uk which will be passed onto every website registered under co.uk.
171
171
 
@@ -180,43 +180,52 @@ Source: https://wiki.mozilla.org/Public_Suffix_List
180
180
  Not convinced yet? Check out [this real world example](https://stackoverflow.com/q/288810/123527).
181
181
 
182
182
 
183
- ## Does <tt>PublicSuffix</tt> make requests to Public Suffix List website?
183
+ ## Does PublicSuffix make network requests?
184
184
 
185
- No. <tt>PublicSuffix</tt> comes with a bundled list. It does not make any HTTP requests to parse or validate a domain.
185
+ No. `PublicSuffix` comes with a bundled list. It does not make any HTTP requests to parse or validate a domain.
186
186
 
187
187
 
188
- ## Support
188
+ ## Terminology
189
189
 
190
- Library documentation is auto-generated from the [README](https://github.com/weppos/publicsuffix-ruby/blob/master/README.md) and the source code, and it's available at https://rubydoc.info/gems/public_suffix.
190
+ - **TLD** (Top-Level Domain): The last segment of a domain name. For example, in `mozilla.org`, the `.org` portion is the TLD.
191
191
 
192
- - The PublicSuffix bug tracker is here: https://github.com/weppos/publicsuffix-ruby/issues
193
- - The PublicSuffix code repository is here: https://github.com/weppos/publicsuffix-ruby. Contributions are welcome! Please include tests and/or feature coverage for every patch, and create a topic branch for every separate change you make.
192
+ - **SLD** (Second-Level Domain): A domain directly below a top-level domain. For example, in `https://www.mozilla.org/en-US/`, `mozilla` is the second-level domain of the `.org` TLD.
194
193
 
195
- [Consider subscribing to Tidelift which provides Enterprise support for this project](https://tidelift.com/subscription/pkg/rubygems-public-suffix?utm_source=rubygems-public-suffix&utm_medium=referral&utm_campaign=readme) as part of the Tidelift Subscription. Tidelift subscriptions also help the maintainers by funding the project, which in turn allows us to ship releases, bugfixes, and security updates more often.
194
+ - **TRD** (Third-Level Domain): Also known as a subdomain, this is the part of the domain before the SLD or root domain. For example, in `https://www.mozilla.org/en-US/`, `www` is the TRD.
196
195
 
196
+ - **FQDN** (Fully Qualified Domain Name): A complete domain name that includes the hostname, domain, and top-level domain, ending with a trailing dot. The format is `[hostname].[domain].[tld].` (e.g., `www.mozilla.org.`).
197
197
 
198
- ## Security and Vulnerability Reporting
199
198
 
200
- Full information and description of our security policy please visit [`SECURITY.md`](SECURITY.md)
199
+ ## Documentation and support
201
200
 
201
+ ### Documentation
202
202
 
203
- ## Changelog
203
+ Library documentation is auto-generated from the [README](https://github.com/weppos/publicsuffix-ruby/blob/master/README.md) and source code, and is available at https://rubydoc.info/gems/public_suffix.
204
204
 
205
- See the [CHANGELOG.md](CHANGELOG.md) file for details.
205
+ ### Bug reports and contributions
206
206
 
207
+ - **Bug Tracker**: https://github.com/weppos/publicsuffix-ruby/issues
208
+ - **Code Repository**: https://github.com/weppos/publicsuffix-ruby
207
209
 
208
- ## License
210
+ Contributions are welcome! Please include tests and/or feature coverage for every patch, and create a topic branch for every separate change you make.
209
211
 
210
- Copyright (c) 2009-2025 Simone Carletti. This is Free Software distributed under the MIT license.
212
+ ### Enterprise support
211
213
 
212
- The [Public Suffix List source](https://publicsuffix.org/list/) is subject to the terms of the Mozilla Public License, v. 2.0.
214
+ [Consider subscribing to Tidelift](https://tidelift.com/subscription/pkg/rubygems-public-suffix?utm_source=rubygems-public-suffix&utm_medium=referral&utm_campaign=readme), which provides enterprise support for this project as part of the Tidelift Subscription. Tidelift subscriptions help fund the project, allowing us to ship releases, bugfixes, and security updates more frequently.
213
215
 
214
- ## Definitions
215
216
 
216
- tld = Top level domain, this is in reference to the last segment of a domain, sometimes the part that is directly after the "dot" symbol. For example, `mozilla.org`, the `.org` portion is the tld.
217
+ ## Security and vulnerability reporting
217
218
 
218
- sld = Second level domain, a domain that is directly below a top-level domain. For example, in `https://www.mozilla.org/en-US/`, `mozilla` is the second-level domain of the .org tld.
219
+ For full information and details about our security policy, please visit [`SECURITY.md`](SECURITY.md).
220
+
221
+
222
+ ## Changelog
219
223
 
220
- trd = Transit routing domain, or known as a subdomain. This is the part of the domain that is before the sld or root domain. For example, in `https://www.mozilla.org/en-US/`, `www` is the trd.
224
+ See [CHANGELOG.md](CHANGELOG.md) for details.
221
225
 
222
- FQDN = Fully Qualified Domain Names, are domain names that are written with the hostname and the domain name, and include the top-level domain, the format looks like `[hostname].[domain].[tld].` for ex. `[www].[mozilla].[org]`.
226
+
227
+ ## License
228
+
229
+ Copyright (c) 2009-2025 Simone Carletti. This is Free Software distributed under the MIT license.
230
+
231
+ The [Public Suffix List source](https://publicsuffix.org/list/) is subject to the terms of the Mozilla Public License, v. 2.0.
@@ -2,7 +2,26 @@
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
- ## Unreleased
5
+ ## [3.2.4] - 2025-11-03
6
+
7
+ ### Fixed
8
+
9
+ - Multipart parser: limit MIME header size check to the unread buffer region to avoid false `multipart mime part header too large` errors when previously read data accumulates in the scan buffer. ([#2392](https://github.com/rack/rack/pull/2392), [@alpaca-tc](https://github.com/alpaca-tc), [@willnet](https://github.com/willnet), [@krororo](https://github.com/krororo))
10
+
11
+ ## [3.2.3] - 2025-10-10
12
+
13
+ ### Security
14
+
15
+ - [CVE-2025-61780](https://github.com/advisories/GHSA-r657-rxjc-j557) Improper handling of headers in `Rack::Sendfile` may allow proxy bypass.
16
+ - [CVE-2025-61919](https://github.com/advisories/GHSA-6xw4-3v39-52mm) Unbounded read in `Rack::Request` form parsing can lead to memory exhaustion.
17
+
18
+ ## [3.2.2] - 2025-10-07
19
+
20
+ ### Security
21
+
22
+ - [CVE-2025-61772](https://github.com/advisories/GHSA-wpv5-97wm-hp9c) Multipart parser buffers unbounded per-part headers, enabling DoS (memory exhaustion)
23
+ - [CVE-2025-61771](https://github.com/advisories/GHSA-w9pc-fmgc-vxvw) Multipart parser buffers large non‑file fields entirely in memory, enabling DoS (memory exhaustion)
24
+ - [CVE-2025-61770](https://github.com/advisories/GHSA-p543-xpfm-54cp) Unbounded multipart preamble buffering enables DoS (memory exhaustion)
6
25
 
7
26
  ## [3.2.1] -- 2025-09-02
8
27
 
@@ -61,6 +80,27 @@ This release continues Rack's evolution toward a cleaner, more efficient foundat
61
80
  - `SERVER_NAME` and `HTTP_HOST` are now more strictly validated according to the relevant specifications. ([#2298](https://github.com/rack/rack/pull/2298), [@ioquatix])
62
81
  - `Rack::Lint` now disallows `PATH_INFO="" SCRIPT_NAME=""`. ([#2298](https://github.com/rack/rack/issues/2307), [@jeremyevans])
63
82
 
83
+ ## [3.1.19] - 2025-11-03
84
+
85
+ ### Fixed
86
+
87
+ - Multipart parser: limit MIME header size check to the unread buffer region to avoid false `multipart mime part header too large` errors when previously read data accumulates in the scan buffer. ([#2392](https://github.com/rack/rack/pull/2392), [@alpaca-tc](https://github.com/alpaca-tc), [@willnet](https://github.com/willnet), [@krororo](https://github.com/krororo))
88
+
89
+ ## [3.1.18] - 2025-10-10
90
+
91
+ ### Security
92
+
93
+ - [CVE-2025-61780](https://github.com/advisories/GHSA-r657-rxjc-j557) Improper handling of headers in `Rack::Sendfile` may allow proxy bypass.
94
+ - [CVE-2025-61919](https://github.com/advisories/GHSA-6xw4-3v39-52mm) Unbounded read in `Rack::Request` form parsing can lead to memory exhaustion.
95
+
96
+ ## [3.1.17] - 2025-10-07
97
+
98
+ ### Security
99
+
100
+ - [CVE-2025-61772](https://github.com/advisories/GHSA-wpv5-97wm-hp9c) Multipart parser buffers unbounded per-part headers, enabling DoS (memory exhaustion)
101
+ - [CVE-2025-61771](https://github.com/advisories/GHSA-w9pc-fmgc-vxvw) Multipart parser buffers large non‑file fields entirely in memory, enabling DoS (memory exhaustion)
102
+ - [CVE-2025-61770](https://github.com/advisories/GHSA-p543-xpfm-54cp) Unbounded multipart preamble buffering enables DoS (memory exhaustion)
103
+
64
104
  ## [3.1.16] - 2025-06-04
65
105
 
66
106
  ### Security
@@ -77,7 +117,7 @@ This release continues Rack's evolution toward a cleaner, more efficient foundat
77
117
 
78
118
  ### Security
79
119
 
80
- - [CVE-2025-46727](https://github.com/rack/rack/security/advisories/GHSA-gjh7-p2fx-99vx) Unbounded parameter parsing in `Rack::QueryParser` can lead to memory exhaustion.
120
+ - [CVE-2025-46727](https://github.com/advisories/GHSA-gjh7-p2fx-99vx) Unbounded parameter parsing in `Rack::QueryParser` can lead to memory exhaustion.
81
121
 
82
122
  ## [3.1.13] - 2025-04-13
83
123
 
@@ -87,19 +127,19 @@ This release continues Rack's evolution toward a cleaner, more efficient foundat
87
127
 
88
128
  ### Security
89
129
 
90
- - [CVE-2025-27610](https://github.com/rack/rack/security/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
130
+ - [CVE-2025-27610](https://github.com/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
91
131
 
92
132
  ## [3.1.11] - 2025-03-04
93
133
 
94
134
  ### Security
95
135
 
96
- - [CVE-2025-27111](https://github.com/rack/rack/security/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
136
+ - [CVE-2025-27111](https://github.com/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
97
137
 
98
138
  ## [3.1.10] - 2025-02-12
99
139
 
100
140
  ### Security
101
141
 
102
- - [CVE-2025-25184](https://github.com/rack/rack/security/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
142
+ - [CVE-2025-25184](https://github.com/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
103
143
 
104
144
  ## [3.1.9] - 2025-01-31
105
145
 
@@ -132,7 +172,7 @@ This release continues Rack's evolution toward a cleaner, more efficient foundat
132
172
 
133
173
  ### Security
134
174
 
135
- - Fix potential ReDoS attack in `Rack::Request#parse_http_accept_header`. ([GHSA-cj83-2ww7-mvq7](https://github.com/rack/rack/security/advisories/GHSA-cj83-2ww7-mvq7), [@dwisiswant0](https://github.com/dwisiswant0))
175
+ - Fix potential ReDoS attack in `Rack::Request#parse_http_accept_header`. ([GHSA-cj83-2ww7-mvq7](https://github.com/advisories/GHSA-cj83-2ww7-mvq7), [@dwisiswant0](https://github.com/dwisiswant0))
136
176
 
137
177
  ## [3.1.4] - 2024-06-22
138
178
 
@@ -224,7 +264,7 @@ This release is primarily a maintenance release that removes features deprecated
224
264
 
225
265
  ### Security
226
266
 
227
- - [CVE-2025-46727](https://github.com/rack/rack/security/advisories/GHSA-gjh7-p2fx-99vx) Unbounded parameter parsing in `Rack::QueryParser` can lead to memory exhaustion.
267
+ - [CVE-2025-46727](https://github.com/advisories/GHSA-gjh7-p2fx-99vx) Unbounded parameter parsing in `Rack::QueryParser` can lead to memory exhaustion.
228
268
 
229
269
  ## [3.0.15] - 2025-04-13
230
270
 
@@ -234,13 +274,13 @@ This release is primarily a maintenance release that removes features deprecated
234
274
 
235
275
  ### Security
236
276
 
237
- - [CVE-2025-27610](https://github.com/rack/rack/security/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
277
+ - [CVE-2025-27610](https://github.com/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
238
278
 
239
279
  ## [3.0.13] - 2025-03-04
240
280
 
241
281
  ### Security
242
282
 
243
- - [CVE-2025-27111](https://github.com/rack/rack/security/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
283
+ - [CVE-2025-27111](https://github.com/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
244
284
 
245
285
  ### Fixed
246
286
 
@@ -250,7 +290,7 @@ This release is primarily a maintenance release that removes features deprecated
250
290
 
251
291
  ### Security
252
292
 
253
- - [CVE-2025-25184](https://github.com/rack/rack/security/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
293
+ - [CVE-2025-25184](https://github.com/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
254
294
 
255
295
  ## [3.0.11] - 2024-05-10
256
296
 
@@ -430,6 +470,33 @@ This release introduces major improvements to Rack, including enhanced support f
430
470
  - 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))
431
471
  - `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))
432
472
 
473
+ ## [2.2.21] - 2025-11-03
474
+
475
+ ### Fixed
476
+
477
+ - Multipart parser: limit MIME header size check to the unread buffer region to avoid false `multipart mime part header too large` errors when previously read data accumulates in the scan buffer. ([#2392](https://github.com/rack/rack/pull/2392), [@alpaca-tc](https://github.com/alpaca-tc), [@willnet](https://github.com/willnet), [@krororo](https://github.com/krororo))
478
+
479
+ ## [2.2.20] - 2025-10-10
480
+
481
+ ### Security
482
+
483
+ - [CVE-2025-61780](https://github.com/advisories/GHSA-r657-rxjc-j557) Improper handling of headers in `Rack::Sendfile` may allow proxy bypass.
484
+ - [CVE-2025-61919](https://github.com/advisories/GHSA-6xw4-3v39-52mm) Unbounded read in `Rack::Request` form parsing can lead to memory exhaustion.
485
+
486
+ ## [2.2.19] - 2025-10-07
487
+
488
+ ### Security
489
+
490
+ - [CVE-2025-61772](https://github.com/advisories/GHSA-wpv5-97wm-hp9c) Multipart parser buffers unbounded per-part headers, enabling DoS (memory exhaustion)
491
+ - [CVE-2025-61771](https://github.com/advisories/GHSA-w9pc-fmgc-vxvw) Multipart parser buffers large non‑file fields entirely in memory, enabling DoS (memory exhaustion)
492
+ - [CVE-2025-61770](https://github.com/advisories/GHSA-p543-xpfm-54cp) Unbounded multipart preamble buffering enables DoS (memory exhaustion)
493
+
494
+ ## [2.2.18] - 2025-09-25
495
+
496
+ ### Security
497
+
498
+ - [CVE-2025-59830](https://github.com/advisories/GHSA-625h-95r8-8xpm) Unbounded parameter parsing in `Rack::QueryParser` can lead to memory exhaustion via semicolon-separated parameters.
499
+
433
500
  ## [2.2.17] - 2025-06-03
434
501
 
435
502
  - Backport `Rack::MediaType#params` now handles parameters without values. ([#2263](https://github.com/rack/rack/pull/2263), [@AllyMarthaJ](https://github.com/AllyMarthaJ))
@@ -448,25 +515,25 @@ This release introduces major improvements to Rack, including enhanced support f
448
515
 
449
516
  ### Security
450
517
 
451
- - [CVE-2025-46727](https://github.com/rack/rack/security/advisories/GHSA-gjh7-p2fx-99vx) Unbounded parameter parsing in `Rack::QueryParser` can lead to memory exhaustion.
518
+ - [CVE-2025-46727](https://github.com/advisories/GHSA-gjh7-p2fx-99vx) Unbounded parameter parsing in `Rack::QueryParser` can lead to memory exhaustion.
452
519
 
453
520
  ## [2.2.13] - 2025-03-11
454
521
 
455
522
  ### Security
456
523
 
457
- - [CVE-2025-27610](https://github.com/rack/rack/security/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
524
+ - [CVE-2025-27610](https://github.com/advisories/GHSA-7wqh-767x-r66v) Local file inclusion in `Rack::Static`.
458
525
 
459
526
  ## [2.2.12] - 2025-03-04
460
527
 
461
528
  ### Security
462
529
 
463
- - [CVE-2025-27111](https://github.com/rack/rack/security/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
530
+ - [CVE-2025-27111](https://github.com/advisories/GHSA-8cgq-6mh2-7j6v) Possible Log Injection in `Rack::Sendfile`.
464
531
 
465
532
  ## [2.2.11] - 2025-02-12
466
533
 
467
534
  ### Security
468
535
 
469
- - [CVE-2025-25184](https://github.com/rack/rack/security/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
536
+ - [CVE-2025-25184](https://github.com/advisories/GHSA-7g2v-jj9q-g3rg) Possible Log Injection in `Rack::CommonLogger`.
470
537
 
471
538
  ## [2.2.10] - 2024-10-14
472
539
 
@@ -230,6 +230,14 @@ query string, before attempting parsing, so if the same parameter key is
230
230
  used multiple times in the query, each counts as a separate parameter for
231
231
  this check.
232
232
 
233
+ ### `RACK_MULTIPART_BUFFERED_UPLOAD_BYTESIZE_LIMIT`
234
+
235
+ This environment variable sets the maximum amount of memory Rack will use
236
+ to buffer multipart parameters when parsing a request body. This considers
237
+ the size of the multipart mime headers and the body part for multipart
238
+ parameters that are buffered in memory and do not use tempfiles. This
239
+ defaults to 16MB if not provided.
240
+
233
241
  ### `param_depth_limit`
234
242
 
235
243
  ```ruby
@@ -27,7 +27,7 @@ Gem::Specification.new do |s|
27
27
  "bug_tracker_uri" => "https://github.com/ruby/rake/issues",
28
28
  "changelog_uri" => "https://github.com/ruby/rake/releases",
29
29
  "documentation_uri" => "https://ruby.github.io/rake",
30
- "source_code_uri" => "#{s.homepage}/releases/v#{s.version}"
30
+ "source_code_uri" => s.homepage
31
31
  }
32
32
 
33
33
  s.files = [
@@ -1,12 +1,12 @@
1
1
  # -*- encoding: utf-8 -*-
2
- # stub: actionpack 8.0.3 ruby lib
2
+ # stub: actionpack 8.1.1 ruby lib
3
3
 
4
4
  Gem::Specification.new do |s|
5
5
  s.name = "actionpack".freeze
6
- s.version = "8.0.3".freeze
6
+ s.version = "8.1.1".freeze
7
7
 
8
8
  s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
9
- s.metadata = { "bug_tracker_uri" => "https://github.com/rails/rails/issues", "changelog_uri" => "https://github.com/rails/rails/blob/v8.0.3/actionpack/CHANGELOG.md", "documentation_uri" => "https://api.rubyonrails.org/v8.0.3/", "mailing_list_uri" => "https://discuss.rubyonrails.org/c/rubyonrails-talk", "rubygems_mfa_required" => "true", "source_code_uri" => "https://github.com/rails/rails/tree/v8.0.3/actionpack" } if s.respond_to? :metadata=
9
+ s.metadata = { "bug_tracker_uri" => "https://github.com/rails/rails/issues", "changelog_uri" => "https://github.com/rails/rails/blob/v8.1.1/actionpack/CHANGELOG.md", "documentation_uri" => "https://api.rubyonrails.org/v8.1.1/", "mailing_list_uri" => "https://discuss.rubyonrails.org/c/rubyonrails-talk", "rubygems_mfa_required" => "true", "source_code_uri" => "https://github.com/rails/rails/tree/v8.1.1/actionpack" } if s.respond_to? :metadata=
10
10
  s.require_paths = ["lib".freeze]
11
11
  s.authors = ["David Heinemeier Hansson".freeze]
12
12
  s.date = "1980-01-02"
@@ -23,7 +23,7 @@ Gem::Specification.new do |s|
23
23
 
24
24
  s.specification_version = 4
25
25
 
26
- s.add_runtime_dependency(%q<activesupport>.freeze, ["= 8.0.3".freeze])
26
+ s.add_runtime_dependency(%q<activesupport>.freeze, ["= 8.1.1".freeze])
27
27
  s.add_runtime_dependency(%q<nokogiri>.freeze, [">= 1.8.5".freeze])
28
28
  s.add_runtime_dependency(%q<rack>.freeze, [">= 2.2.4".freeze])
29
29
  s.add_runtime_dependency(%q<rack-session>.freeze, [">= 1.0.1".freeze])
@@ -31,6 +31,6 @@ Gem::Specification.new do |s|
31
31
  s.add_runtime_dependency(%q<rails-html-sanitizer>.freeze, ["~> 1.6".freeze])
32
32
  s.add_runtime_dependency(%q<rails-dom-testing>.freeze, ["~> 2.2".freeze])
33
33
  s.add_runtime_dependency(%q<useragent>.freeze, ["~> 0.16".freeze])
34
- s.add_runtime_dependency(%q<actionview>.freeze, ["= 8.0.3".freeze])
35
- s.add_development_dependency(%q<activemodel>.freeze, ["= 8.0.3".freeze])
34
+ s.add_runtime_dependency(%q<actionview>.freeze, ["= 8.1.1".freeze])
35
+ s.add_development_dependency(%q<activemodel>.freeze, ["= 8.1.1".freeze])
36
36
  end
@@ -1,12 +1,12 @@
1
1
  # -*- encoding: utf-8 -*-
2
- # stub: actionview 8.0.3 ruby lib
2
+ # stub: actionview 8.1.1 ruby lib
3
3
 
4
4
  Gem::Specification.new do |s|
5
5
  s.name = "actionview".freeze
6
- s.version = "8.0.3".freeze
6
+ s.version = "8.1.1".freeze
7
7
 
8
8
  s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
9
- s.metadata = { "bug_tracker_uri" => "https://github.com/rails/rails/issues", "changelog_uri" => "https://github.com/rails/rails/blob/v8.0.3/actionview/CHANGELOG.md", "documentation_uri" => "https://api.rubyonrails.org/v8.0.3/", "mailing_list_uri" => "https://discuss.rubyonrails.org/c/rubyonrails-talk", "rubygems_mfa_required" => "true", "source_code_uri" => "https://github.com/rails/rails/tree/v8.0.3/actionview" } if s.respond_to? :metadata=
9
+ s.metadata = { "bug_tracker_uri" => "https://github.com/rails/rails/issues", "changelog_uri" => "https://github.com/rails/rails/blob/v8.1.1/actionview/CHANGELOG.md", "documentation_uri" => "https://api.rubyonrails.org/v8.1.1/", "mailing_list_uri" => "https://discuss.rubyonrails.org/c/rubyonrails-talk", "rubygems_mfa_required" => "true", "source_code_uri" => "https://github.com/rails/rails/tree/v8.1.1/actionview" } if s.respond_to? :metadata=
10
10
  s.require_paths = ["lib".freeze]
11
11
  s.authors = ["David Heinemeier Hansson".freeze]
12
12
  s.date = "1980-01-02"
@@ -23,11 +23,11 @@ Gem::Specification.new do |s|
23
23
 
24
24
  s.specification_version = 4
25
25
 
26
- s.add_runtime_dependency(%q<activesupport>.freeze, ["= 8.0.3".freeze])
26
+ s.add_runtime_dependency(%q<activesupport>.freeze, ["= 8.1.1".freeze])
27
27
  s.add_runtime_dependency(%q<builder>.freeze, ["~> 3.1".freeze])
28
28
  s.add_runtime_dependency(%q<erubi>.freeze, ["~> 1.11".freeze])
29
29
  s.add_runtime_dependency(%q<rails-html-sanitizer>.freeze, ["~> 1.6".freeze])
30
30
  s.add_runtime_dependency(%q<rails-dom-testing>.freeze, ["~> 2.2".freeze])
31
- s.add_development_dependency(%q<actionpack>.freeze, ["= 8.0.3".freeze])
32
- s.add_development_dependency(%q<activemodel>.freeze, ["= 8.0.3".freeze])
31
+ s.add_development_dependency(%q<actionpack>.freeze, ["= 8.1.1".freeze])
32
+ s.add_development_dependency(%q<activemodel>.freeze, ["= 8.1.1".freeze])
33
33
  end
@@ -1,12 +1,12 @@
1
1
  # -*- encoding: utf-8 -*-
2
- # stub: activesupport 8.0.3 ruby lib
2
+ # stub: activesupport 8.1.1 ruby lib
3
3
 
4
4
  Gem::Specification.new do |s|
5
5
  s.name = "activesupport".freeze
6
- s.version = "8.0.3".freeze
6
+ s.version = "8.1.1".freeze
7
7
 
8
8
  s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
9
- s.metadata = { "bug_tracker_uri" => "https://github.com/rails/rails/issues", "changelog_uri" => "https://github.com/rails/rails/blob/v8.0.3/activesupport/CHANGELOG.md", "documentation_uri" => "https://api.rubyonrails.org/v8.0.3/", "mailing_list_uri" => "https://discuss.rubyonrails.org/c/rubyonrails-talk", "rubygems_mfa_required" => "true", "source_code_uri" => "https://github.com/rails/rails/tree/v8.0.3/activesupport" } if s.respond_to? :metadata=
9
+ s.metadata = { "bug_tracker_uri" => "https://github.com/rails/rails/issues", "changelog_uri" => "https://github.com/rails/rails/blob/v8.1.1/activesupport/CHANGELOG.md", "documentation_uri" => "https://api.rubyonrails.org/v8.1.1/", "mailing_list_uri" => "https://discuss.rubyonrails.org/c/rubyonrails-talk", "rubygems_mfa_required" => "true", "source_code_uri" => "https://github.com/rails/rails/tree/v8.1.1/activesupport" } if s.respond_to? :metadata=
10
10
  s.require_paths = ["lib".freeze]
11
11
  s.authors = ["David Heinemeier Hansson".freeze]
12
12
  s.date = "1980-01-02"
@@ -31,8 +31,8 @@ Gem::Specification.new do |s|
31
31
  s.add_runtime_dependency(%q<base64>.freeze, [">= 0".freeze])
32
32
  s.add_runtime_dependency(%q<drb>.freeze, [">= 0".freeze])
33
33
  s.add_runtime_dependency(%q<bigdecimal>.freeze, [">= 0".freeze])
34
+ s.add_runtime_dependency(%q<json>.freeze, [">= 0".freeze])
34
35
  s.add_runtime_dependency(%q<logger>.freeze, [">= 1.4.2".freeze])
35
36
  s.add_runtime_dependency(%q<securerandom>.freeze, [">= 0.3".freeze])
36
37
  s.add_runtime_dependency(%q<uri>.freeze, [">= 0.13.1".freeze])
37
- s.add_runtime_dependency(%q<benchmark>.freeze, [">= 0.3".freeze])
38
38
  end
@@ -1,15 +1,15 @@
1
1
  # -*- encoding: utf-8 -*-
2
- # stub: addressable 2.8.7 ruby lib
2
+ # stub: addressable 2.8.8 ruby lib
3
3
 
4
4
  Gem::Specification.new do |s|
5
5
  s.name = "addressable".freeze
6
- s.version = "2.8.7".freeze
6
+ s.version = "2.8.8".freeze
7
7
 
8
8
  s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
9
- s.metadata = { "changelog_uri" => "https://github.com/sporkmonger/addressable/blob/main/CHANGELOG.md#v2.8.7" } if s.respond_to? :metadata=
9
+ s.metadata = { "changelog_uri" => "https://github.com/sporkmonger/addressable/blob/main/CHANGELOG.md#v2.8.8" } if s.respond_to? :metadata=
10
10
  s.require_paths = ["lib".freeze]
11
11
  s.authors = ["Bob Aman".freeze]
12
- s.date = "2024-06-21"
12
+ s.date = "1980-01-02"
13
13
  s.description = "Addressable is an alternative implementation to the URI implementation that is\npart of Ruby's standard library. It is flexible, offers heuristic parsing, and\nadditionally provides extensive support for IRIs and URI templates.\n".freeze
14
14
  s.email = "bob@sporkmonger.com".freeze
15
15
  s.extra_rdoc_files = ["README.md".freeze]
@@ -18,13 +18,13 @@ Gem::Specification.new do |s|
18
18
  s.licenses = ["Apache-2.0".freeze]
19
19
  s.rdoc_options = ["--main".freeze, "README.md".freeze]
20
20
  s.required_ruby_version = Gem::Requirement.new(">= 2.2".freeze)
21
- s.rubygems_version = "3.5.11".freeze
21
+ s.rubygems_version = "3.6.9".freeze
22
22
  s.summary = "URI Implementation".freeze
23
23
 
24
24
  s.installed_by_version = "3.6.9".freeze
25
25
 
26
26
  s.specification_version = 4
27
27
 
28
- s.add_runtime_dependency(%q<public_suffix>.freeze, [">= 2.0.2".freeze, "< 7.0".freeze])
28
+ s.add_runtime_dependency(%q<public_suffix>.freeze, [">= 2.0.2".freeze, "< 8.0".freeze])
29
29
  s.add_development_dependency(%q<bundler>.freeze, [">= 1.0".freeze, "< 3.0".freeze])
30
30
  end
@@ -1,10 +1,10 @@
1
1
  # -*- encoding: utf-8 -*-
2
- # stub: bigdecimal 3.2.3 ruby lib
2
+ # stub: bigdecimal 3.3.1 ruby lib
3
3
  # stub: ext/bigdecimal/extconf.rb
4
4
 
5
5
  Gem::Specification.new do |s|
6
6
  s.name = "bigdecimal".freeze
7
- s.version = "3.2.3".freeze
7
+ s.version = "3.3.1".freeze
8
8
 
9
9
  s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
10
10
  s.metadata = { "changelog_uri" => "https://github.com/ruby/bigdecimal/blob/master/CHANGES.md" } if s.respond_to? :metadata=