{"schema_version":"1.7.2","id":"OESA-2026-1967","modified":"2026-04-17T13:02:43Z","published":"2026-04-17T13:02:43Z","upstream":["CVE-2026-35611"],"summary":"rubygem-addressable security update","details":"Addressable is a replacement for the URI implementation that is part of Ruby&amp;apos;s standard library. It more closely conforms to the relevant RFCs and adds support for URI and URL templates.\r\n\r\nSecurity Fix(es):\n\nWithin the URI template implementation in Addressable, two classes of URI template generate regular expressions vulnerable to catastrophic backtracking:\r\n\r\n1. Templates using the `*` (explode) modifier with any expansion operator (e.g., `{foo*}`, `{+var*}`, `{#var*}`, `{/var*}`, `{.var*}`, `{;var*}`, `{?var*}`, `{&amp;var*}`) generate patterns with nested unbounded quantifiers that are O(2^n) when matched against a maliciously crafted URI.\r\n2. Templates using multiple variables with the `+` or `#` operators (e.g., `{+v1,v2,v3}`) generate patterns with O(n^k) complexity due to the comma separator being within the matched character class, causing ambiguous backtracking across k variables.\r\n\r\nWhen matched against a maliciously crafted URI, this can result in catastrophic backtracking and uncontrolled resource consumption, leading to denial of service. The first pattern was partially addressed in 2.8.10 for certain operator combinations. Both patterns are fully remediated in 2.9.0.\r\n\r\nUsers of the URI parsing capabilities in Addressable but not the URI template matching capabilities are unaffected.(CVE-2026-35611)","affected":[{"package":{"ecosystem":"openEuler:24.03-LTS-SP1","name":"rubygem-addressable","purl":"pkg:rpm/openEuler/rubygem-addressable&distro=openEuler-24.03-LTS-SP1"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"2.8.6-2.oe2403sp1"}]}],"ecosystem_specific":{"noarch":["rubygem-addressable-2.8.6-2.oe2403sp1.noarch.rpm","rubygem-addressable-doc-2.8.6-2.oe2403sp1.noarch.rpm"],"src":["rubygem-addressable-2.8.6-2.oe2403sp1.src.rpm"]}},{"package":{"ecosystem":"openEuler:24.03-LTS-SP2","name":"rubygem-addressable","purl":"pkg:rpm/openEuler/rubygem-addressable&distro=openEuler-24.03-LTS-SP2"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"2.8.6-2.oe2403sp2"}]}],"ecosystem_specific":{"noarch":["rubygem-addressable-2.8.6-2.oe2403sp2.noarch.rpm","rubygem-addressable-doc-2.8.6-2.oe2403sp2.noarch.rpm"],"src":["rubygem-addressable-2.8.6-2.oe2403sp2.src.rpm"]}},{"package":{"ecosystem":"openEuler:24.03-LTS-SP3","name":"rubygem-addressable","purl":"pkg:rpm/openEuler/rubygem-addressable&distro=openEuler-24.03-LTS-SP3"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"2.8.6-2.oe2403sp3"}]}],"ecosystem_specific":{"noarch":["rubygem-addressable-2.8.6-2.oe2403sp3.noarch.rpm","rubygem-addressable-doc-2.8.6-2.oe2403sp3.noarch.rpm"],"src":["rubygem-addressable-2.8.6-2.oe2403sp3.src.rpm"]}},{"package":{"ecosystem":"openEuler:20.03-LTS-SP4","name":"rubygem-addressable","purl":"pkg:rpm/openEuler/rubygem-addressable&distro=openEuler-20.03-LTS-SP4"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"2.5.2-3.oe2003sp4"}]}],"ecosystem_specific":{"noarch":["rubygem-addressable-2.5.2-3.oe2003sp4.noarch.rpm","rubygem-addressable-doc-2.5.2-3.oe2003sp4.noarch.rpm"],"src":["rubygem-addressable-2.5.2-3.oe2003sp4.src.rpm"]}},{"package":{"ecosystem":"openEuler:22.03-LTS-SP4","name":"rubygem-addressable","purl":"pkg:rpm/openEuler/rubygem-addressable&distro=openEuler-22.03-LTS-SP4"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"2.8.0-2.oe2203sp4"}]}],"ecosystem_specific":{"noarch":["rubygem-addressable-2.8.0-2.oe2203sp4.noarch.rpm","rubygem-addressable-doc-2.8.0-2.oe2203sp4.noarch.rpm"],"src":["rubygem-addressable-2.8.0-2.oe2203sp4.src.rpm"]}},{"package":{"ecosystem":"openEuler:24.03-LTS","name":"rubygem-addressable","purl":"pkg:rpm/openEuler/rubygem-addressable&distro=openEuler-24.03-LTS"},"ranges":[{"type":"ECOSYSTEM","events":[{"introduced":"0"},{"fixed":"2.8.6-2.oe2403"}]}],"ecosystem_specific":{"noarch":["rubygem-addressable-2.8.6-2.oe2403sp1.noarch.rpm","rubygem-addressable-doc-2.8.6-2.oe2403sp1.noarch.rpm","rubygem-addressable-2.8.6-2.oe2403sp2.noarch.rpm","rubygem-addressable-doc-2.8.6-2.oe2403sp2.noarch.rpm","rubygem-addressable-2.8.6-2.oe2403sp3.noarch.rpm","rubygem-addressable-doc-2.8.6-2.oe2403sp3.noarch.rpm","rubygem-addressable-2.8.6-2.oe2403.noarch.rpm","rubygem-addressable-doc-2.8.6-2.oe2403.noarch.rpm"],"src":["rubygem-addressable-2.8.6-2.oe2403sp1.src.rpm","rubygem-addressable-2.8.6-2.oe2403sp2.src.rpm","rubygem-addressable-2.8.6-2.oe2403sp3.src.rpm","rubygem-addressable-2.8.6-2.oe2403.src.rpm"]}}],"references":[{"type":"ADVISORY","url":"https://www.openeuler.org/zh/security/security-bulletins/detail/?id=openEuler-SA-2026-1967"},{"type":"ADVISORY","url":"https://nvd.nist.gov/vuln/detail/CVE-2026-35611"}],"database_specific":{"severity":"High"}}
