CVE-2026-42246
HIGH7.4EPSS 0.02%net-imap vulnerable to STARTTLS stripping via invalid response timing
Description
### Summary A man-in-the-middle attacker can cause `Net::IMAP#starttls` to return "successfully", without starting TLS. ### Details When using `Net::IMAP#starttls` to upgrade a plaintext connection to use TLS, a man-in-the-middle attacker can inject a tagged `OK` response with an easily predictable tag. By sending the response before the client finishes sending the command, the command completes "successfully" before the response handler is registered. This allows `#starttls` to return without error, but the response handler is never invoked, the TLS connection is never established, and the socket remains unencrypted. This allows man-in-the-middle attackers to perform a STARTTLS stripping attack, unless the client code explicitly checks `Net::IMAP#tls_verified?`. ### Impact TLS bypass, leading to cleartext transmission of sensitive information. ### Mitigation * Upgrade to a patched version of net-imap that raises an exception whenever `#starttls` does not establish TLS. * Connect to an implicit TLS port, rather than use `STARTTLS` with a cleartext port. This is strongly recommended anyway: * [RFC 8314](https://www.rfc-editor.org/info/rfc8314): Cleartext Considered Obsolete: Use of Transport Layer Security (TLS) for Email Submission and Access * [NO STARTTLS](https://nostarttls.secvuln.info/): Why TLS is better without STARTTLS, A Security Analysis of STARTTLS in the Email Context * Explicitly verify `Net::IMAP#tls_verified?` is `true`, before using the connection after `#starttls`.
Affected packages (4)
- Debian/ruby2.7from 0
- Debian/ruby3.1from 0
- Debian/ruby3.3from 0
- RubyGems/net-imap>= 0.6.0, < 0.6.4
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 4.0 | — | CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:P/VC:H/VI:H/VA:N/SC:N/SI:N/SA:N |
| osv | CVSS 3.1 | HIGH7.4 | CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N |
References (15)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2026-42246
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2026-42246
- PATCHhttps://github.com/ruby/net-imap
- WEBhttps://github.com/ruby/net-imap/commit/0ede4c40b1523dfeaf95777b2678e54cc0fd9618
- WEBhttps://github.com/ruby/net-imap/commit/24a4e770b43230286a05aa2a9746cdbb3eb8485e
- WEBhttps://github.com/ruby/net-imap/commit/97e2488fb5401a1783bddd959dde007d9fbce42c
- WEBhttps://github.com/ruby/net-imap/commit/f79d35bf5833f186e81044c57c843eda30c873da
- WEBhttps://github.com/ruby/net-imap/releases/tag/v0.3.10
- WEBhttps://github.com/ruby/net-imap/releases/tag/v0.4.24
- WEBhttps://github.com/ruby/net-imap/releases/tag/v0.5.14
- WEBhttps://github.com/ruby/net-imap/releases/tag/v0.6.4
- WEBhttps://github.com/ruby/net-imap/security/advisories/GHSA-vcgp-9326-pqcp
- WEBhttps://github.com/rubysec/ruby-advisory-db/blob/master/gems/net-imap/CVE-2026-42246.yml
- WEBhttps://nostarttls.secvuln.info
- WEBhttps://www.rfc-editor.org/info/rfc8314