<?xml version="1.0" encoding="UTF-8"?>
<cvrfdoc xmlns="http://www.icasi.org/CVRF/schema/cvrf/1.1" xmlns:cvrf="http://www.icasi.org/CVRF/schema/cvrf/1.1">
	<DocumentTitle xml:lang="en">An update for rubygem-addressable is now available for openEuler-24.03-LTS-SP1,openEuler-24.03-LTS-SP2,openEuler-24.03-LTS-SP3,openEuler-20.03-LTS-SP4,openEuler-22.03-LTS-SP4,openEuler-24.03-LTS</DocumentTitle>
	<DocumentType>Security Advisory</DocumentType>
	<DocumentPublisher Type="Vendor">
		<ContactDetails>openeuler-security@openeuler.org</ContactDetails>
		<IssuingAuthority>openEuler security committee</IssuingAuthority>
	</DocumentPublisher>
	<DocumentTracking>
		<Identification>
			<ID>openEuler-SA-2026-1967</ID>
		</Identification>
		<Status>Final</Status>
		<Version>1.0</Version>
		<RevisionHistory>
			<Revision>
				<Number>1.0</Number>
				<Date>2026-04-17</Date>
				<Description>Initial</Description>
			</Revision>
		</RevisionHistory>
		<InitialReleaseDate>2026-04-17</InitialReleaseDate>
		<CurrentReleaseDate>2026-04-17</CurrentReleaseDate>
		<Generator>
			<Engine>openEuler SA Tool V1.0</Engine>
			<Date>2026-04-17</Date>
		</Generator>
	</DocumentTracking>
	<DocumentNotes>
		<Note Title="Synopsis" Type="General" Ordinal="1" xml:lang="en">rubygem-addressable security update</Note>
		<Note Title="Summary" Type="General" Ordinal="2" xml:lang="en">An update for rubygem-addressable is now available for openEuler-24.03-LTS-SP1,openEuler-24.03-LTS-SP2,openEuler-24.03-LTS-SP3,openEuler-20.03-LTS-SP4,openEuler-22.03-LTS-SP4,openEuler-24.03-LTS</Note>
		<Note Title="Description" Type="General" Ordinal="3" xml:lang="en">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.

Security Fix(es):

Within the URI template implementation in Addressable, two classes of URI template generate regular expressions vulnerable to catastrophic backtracking:

1. 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.
2. 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.

When 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.

Users of the URI parsing capabilities in Addressable but not the URI template matching capabilities are unaffected.(CVE-2026-35611)</Note>
		<Note Title="Topic" Type="General" Ordinal="4" xml:lang="en">An update for rubygem-addressable is now available for openEuler-24.03-LTS-SP1,openEuler-24.03-LTS-SP2,openEuler-24.03-LTS-SP3,openEuler-20.03-LTS-SP4,openEuler-22.03-LTS-SP4,openEuler-24.03-LTS.

openEuler Security has rated this update as having a security impact of high. A Common Vunlnerability Scoring System(CVSS)base score,which gives a detailed severity rating, is available for each vulnerability from the CVElink(s) in the References section.</Note>
		<Note Title="Severity" Type="General" Ordinal="5" xml:lang="en">High</Note>
		<Note Title="Affected Component" Type="General" Ordinal="6" xml:lang="en">rubygem-addressable</Note>
	</DocumentNotes>
	<DocumentReferences>
		<Reference Type="Self">
			<URL>https://www.openeuler.org/zh/security/security-bulletins/detail/?id=openEuler-SA-2026-1967</URL>
		</Reference>
		<Reference Type="openEuler CVE">
			<URL>https://www.openeuler.org/en/security/cve/detail/?cveId=CVE-2026-35611</URL>
		</Reference>
		<Reference Type="Other">
			<URL>https://nvd.nist.gov/vuln/detail/CVE-2026-35611</URL>
		</Reference>
	</DocumentReferences>
	<ProductTree xmlns="http://www.icasi.org/CVRF/schema/prod/1.1">
		<Branch Type="Product Name" Name="openEuler">
			<FullProductName ProductID="openEuler-24.03-LTS-SP1" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP1">openEuler-24.03-LTS-SP1</FullProductName>
			<FullProductName ProductID="openEuler-24.03-LTS-SP2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP2">openEuler-24.03-LTS-SP2</FullProductName>
			<FullProductName ProductID="openEuler-24.03-LTS-SP3" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP3">openEuler-24.03-LTS-SP3</FullProductName>
			<FullProductName ProductID="openEuler-20.03-LTS-SP4" CPE="cpe:/a:openEuler:openEuler:20.03-LTS-SP4">openEuler-20.03-LTS-SP4</FullProductName>
			<FullProductName ProductID="openEuler-22.03-LTS-SP4" CPE="cpe:/a:openEuler:openEuler:22.03-LTS-SP4">openEuler-22.03-LTS-SP4</FullProductName>
			<FullProductName ProductID="openEuler-24.03-LTS" CPE="cpe:/a:openEuler:openEuler:24.03-LTS">openEuler-24.03-LTS</FullProductName>
		</Branch>
		<Branch Type="Package Arch" Name="noarch">
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP1">rubygem-addressable-2.8.6-2.oe2403sp1.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-doc-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP1">rubygem-addressable-doc-2.8.6-2.oe2403sp1.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP2">rubygem-addressable-2.8.6-2.oe2403sp2.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-doc-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP2">rubygem-addressable-doc-2.8.6-2.oe2403sp2.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP3">rubygem-addressable-2.8.6-2.oe2403sp3.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-doc-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP3">rubygem-addressable-doc-2.8.6-2.oe2403sp3.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.5.2-3" CPE="cpe:/a:openEuler:openEuler:20.03-LTS-SP4">rubygem-addressable-2.5.2-3.oe2003sp4.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-doc-2.5.2-3" CPE="cpe:/a:openEuler:openEuler:20.03-LTS-SP4">rubygem-addressable-doc-2.5.2-3.oe2003sp4.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.0-2" CPE="cpe:/a:openEuler:openEuler:22.03-LTS-SP4">rubygem-addressable-2.8.0-2.oe2203sp4.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-doc-2.8.0-2" CPE="cpe:/a:openEuler:openEuler:22.03-LTS-SP4">rubygem-addressable-doc-2.8.0-2.oe2203sp4.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS">rubygem-addressable-2.8.6-2.oe2403.noarch.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-doc-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS">rubygem-addressable-doc-2.8.6-2.oe2403.noarch.rpm</FullProductName>
		</Branch>
		<Branch Type="Package Arch" Name="src">
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP1">rubygem-addressable-2.8.6-2.oe2403sp1.src.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP2">rubygem-addressable-2.8.6-2.oe2403sp2.src.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS-SP3">rubygem-addressable-2.8.6-2.oe2403sp3.src.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.5.2-3" CPE="cpe:/a:openEuler:openEuler:20.03-LTS-SP4">rubygem-addressable-2.5.2-3.oe2003sp4.src.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.0-2" CPE="cpe:/a:openEuler:openEuler:22.03-LTS-SP4">rubygem-addressable-2.8.0-2.oe2203sp4.src.rpm</FullProductName>
			<FullProductName ProductID="rubygem-addressable-2.8.6-2" CPE="cpe:/a:openEuler:openEuler:24.03-LTS">rubygem-addressable-2.8.6-2.oe2403.src.rpm</FullProductName>
		</Branch>
	</ProductTree>
	<Vulnerability Ordinal="1" xmlns="http://www.icasi.org/CVRF/schema/vuln/1.1">
		<Notes>
			<Note Title="Vulnerability Description" Type="General" Ordinal="1" xml:lang="en">Within the URI template implementation in Addressable, two classes of URI template generate regular expressions vulnerable to catastrophic backtracking:

1. 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.
2. 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.

When 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.

Users of the URI parsing capabilities in Addressable but not the URI template matching capabilities are unaffected.</Note>
		</Notes>
		<ReleaseDate>2026-04-17</ReleaseDate>
		<CVE>CVE-2026-35611</CVE>
		<ProductStatuses>
			<Status Type="Fixed">
				<ProductID>openEuler-24.03-LTS-SP1</ProductID>
				<ProductID>openEuler-24.03-LTS-SP2</ProductID>
				<ProductID>openEuler-24.03-LTS-SP3</ProductID>
				<ProductID>openEuler-20.03-LTS-SP4</ProductID>
				<ProductID>openEuler-22.03-LTS-SP4</ProductID>
				<ProductID>openEuler-24.03-LTS</ProductID>
			</Status>
		</ProductStatuses>
		<Threats>
			<Threat Type="Impact">
				<Description>High</Description>
			</Threat>
		</Threats>
		<CVSSScoreSets>
			<ScoreSet>
				<BaseScore>7.5</BaseScore>
				<Vector>AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H</Vector>
			</ScoreSet>
		</CVSSScoreSets>
		<Remediations>
			<Remediation Type="Vendor Fix">
				<Description>rubygem-addressable security update</Description>
				<DATE>2026-04-17</DATE>
				<URL>https://www.openeuler.org/zh/security/security-bulletins/detail/?id=openEuler-SA-2026-1967</URL>
			</Remediation>
		</Remediations>
	</Vulnerability>
</cvrfdoc>