Ecosyste.ms: Advisories
An open API service providing security vulnerability metadata for many open source software ecosystems.
Security Advisories: GSA_kwCzR0hTQS12NWg2LWMyaHYtaHYzcs4AA6RU
StringIO buffer overread vulnerability
An issue was discovered in StringIO 3.0.1, as distributed in Ruby 3.0.x through 3.0.6 and 3.1.x through 3.1.4.
The ungetbyte
and ungetc
methods on a StringIO can read past the end of a string, and a subsequent call to StringIO.gets
may return the memory value.
This vulnerability is not affected StringIO 3.0.3 and later, and Ruby 3.2.x and later.
We recommend to update the StringIO gem to version 3.0.3 or later. In order to ensure compatibility with bundled version in older Ruby series, you may update as follows instead:
- For Ruby 3.0 users: Update to
stringio
3.0.1.1 - For Ruby 3.1 users: Update to
stringio
3.1.0.2
You can use gem update stringio
to update it. If you are using bundler, please add gem "stringio", ">= 3.0.1.2"
to your Gemfile
.
JSON: https://advisories.ecosyste.ms/api/v1/advisories/GSA_kwCzR0hTQS12NWg2LWMyaHYtaHYzcs4AA6RU
Source: GitHub Advisory Database
Origin: Unspecified
Severity: Critical
Classification: General
Published: 10 months ago
Updated: 6 months ago
CVSS Score: 9.8
CVSS vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
Identifiers: GHSA-v5h6-c2hv-hv3r, CVE-2024-27280
References:
- https://github.com/ruby/stringio/commit/0e596524097706263d10900ca180898e4a8f5233
- https://github.com/ruby/stringio/commit/c58c5f54f1eab99665ea6a161d29ff6a7490afc8
- https://github.com/rubysec/ruby-advisory-db/blob/master/gems/stringio/CVE-2024-27280.yml
- https://www.ruby-lang.org/en/news/2024/03/21/buffer-overread-cve-2024-27280
- https://nvd.nist.gov/vuln/detail/CVE-2024-27280
- https://hackerone.com/reports/1399856
- https://github.com/advisories/GHSA-v5h6-c2hv-hv3r
Blast Radius: 38.8
Affected Packages
rubygems:stringio
Dependent packages: 22Dependent repositories: 9,166
Downloads: 47,065,750 total
Affected Version Ranges: < 3.0.1.1
Fixed in: 3.0.1.1
All affected versions:
All unaffected versions: 0.0.1, 0.0.2, 0.1.0, 0.1.3, 0.1.4, 3.0.0, 3.0.1, 3.0.2, 3.0.3, 3.0.4, 3.0.5, 3.0.6, 3.0.7, 3.0.8, 3.0.9, 3.1.0, 3.1.1, 3.1.2