GHSA-4vc4-m8qh-g8jm · Severity: critical · Ecosystem: rubygems — Ruby SAML allows a SAML authentication bypass due to DOCTYPE handling (parser differential)
ruby-saml provides security assertion markup language (SAML) single sign-on (SSO) for Ruby. An authentication bypass vulnerability was found in ruby-saml prior to versions 1.12.4 and 1.18.0 due to a parser differential. ReXML and Nokogiri parse XML differently; the parsers can generate entirely different document structures from the same XML input. That allows an attacker to be able to execute a Signature Wrapping attack. This issue may lead to authentication bypass. Versions 1.12.4 and 1.18.0 fix the issue.
Conclusion & alert: CVE-2025-25291 is rated High Exploit Risk (90.7/100): CVSS Critical severity, with high exploitation likelihood (EPSS 20.84%, 96th percentile). Core evidence: 2 public exploit reference(s) are indexed (Exploit-DB). EPSS rose +7.00% over the last day, indicating growing attacker interest. Mandatory action: Public exploits are available—assess exposure, apply mitigations, and prioritize patching.
Risk is dynamic; we continuously reassess and refresh what is shown on this page as upstream context changes.
| EDB-ID | Source | Kind | Published | Link |
|---|---|---|---|---|
| — | nvd_ref | exploit_tag | Exploit-DB ↗ | |
| — | nvd_ref | exploit_tag | Exploit-DB ↗ |
EPSS lead: Daily EPSS estimates relative likelihood of exploitation; percentile ranks this CVE among scored vulnerabilities (higher = more severe relative rank).
| # | Date | Old EPSS score | New EPSS score | Delta (New - Old) |
|---|---|---|---|---|
| 1 | 2026-04-20 | 13.85% | 20.84% | +7.00% |
| 2 | 2026-01-06 | 17.71% | 13.85% | -3.87% |
| 3 | 2025-12-27 | — | 17.71% | — |
Full EPSS history (38 records total)
CVSS metrics for this CVE.
| Base score | Version | Severity | Vector | Exploitability | Impact | Score source |
|---|---|---|---|---|---|---|
| 9.3 | 4.0 | CRITICAL |
|
— | — | [email protected] |
| 9.8 | 3.1 | CRITICAL |
|
3.9 | 5.9 | [email protected] |
GHSA-4vc4-m8qh-g8jm · Severity: critical · Ecosystem: rubygems — Ruby SAML allows a SAML authentication bypass due to DOCTYPE handling (parser differential)
| vendor | priority | summary | link |
|---|---|---|---|
debian
|
not yet assigned | CVE-2025-25291 not yet assigned priority: Debian including 1 source packages (ruby-saml), 2 status rows across 2 suites (bookworm, bullseye): open 1, resolved 1. | https://security-tracker.debian.org/tracker/CVE-2025-25291 |
ubuntu
|
medium | CVE-2025-25291 medium priority: Ubuntu including 1 source packages (ruby-saml), 9 status rows across 9 suites (bionic, focal, jammy, noble, oracular, plucky, questing, upstream, xenial): released 6, ignored 2, DNE 1. | https://ubuntu.com/security/CVE-2025-25291 |
| Vendor | Product | Version | Raw CPE |
|---|---|---|---|
| omniauth | omniauth_saml | < 1.10.6 | cpe:2.3:a:omniauth:omniauth_saml:*:*:*:*:*:ruby:*:* |
| omniauth | omniauth_saml | >= 2.0.0, < 2.1.3 | cpe:2.3:a:omniauth:omniauth_saml:*:*:*:*:*:ruby:*:* |
| omniauth | omniauth_saml | >= 2.2.0, < 2.2.3 | cpe:2.3:a:omniauth:omniauth_saml:*:*:*:*:*:ruby:*:* |
| onelogin | ruby-saml | < 1.12.4 | cpe:2.3:a:onelogin:ruby-saml:*:*:*:*:*:*:*:* |
| onelogin | ruby-saml | >= 1.13.0, < 1.18.0 | cpe:2.3:a:onelogin:ruby-saml:*:*:*:*:*:*:*:* |
| netapp | storagegrid | — | cpe:2.3:a:netapp:storagegrid:-:*:*:*:*:*:*:* |