Lucene search

K
githubGitHub Advisory DatabaseGHSA-GPRJ-6M2F-J9HX
HistorySep 03, 2024 - 7:33 p.m.

DOM clobbering could escalate to Cross-site Scripting (XSS)

2024-09-0319:33:36
CWE-79
GitHub Advisory Database
github.com
3
dom clobbering
cross-site scripting
xss
document.currentscript.src
pagefind
html injection
privilege escalation
security advisory

CVSS3

6.4

Attack Vector

NETWORK

Attack Complexity

HIGH

Privileges Required

LOW

User Interaction

NONE

Scope

UNCHANGED

Confidentiality Impact

LOW

Integrity Impact

LOW

Availability Impact

HIGH

CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H

AI Score

5.9

Confidence

High

EPSS

0.001

Percentile

21.8%

Pagefind initializes its dynamic JavaScript and WebAssembly files relative to the location of the first script you load. This information is gathered by looking up the value of document.currentScript.src.

It is possible to “clobber” this lookup with otherwise benign HTML on the page, for example:

<img src></img>

This will cause document.currentScript.src to resolve as an external domain, which will then be used by Pagefind to load dependencies.

This exploit would only work in the case that an attacker could inject HTML to your live, hosted, website. In these cases, this would act as a way to escalate the privilege available to an attacker. This assumes they have the ability to add some elements to the page (for example, img tags with a name attribute), but not others, as adding a script to the page would itself be the XSS vector.

Pagefind has tightened this resolution by ensuring the source is loaded from a valid script element. There are no reports of this being exploited in the wild via Pagefind.

Original Report

If an attacker can inject benign html, such as:
<img src></img>

they can clobber document.currentScript.src leading to XSS in your library.

Here is the same attack on webpack that was accepted: https://github.com/webpack/webpack/security/advisories/GHSA-4vvj-4cpr-p986

Affected configurations

Vulners
Node
pagefindRange<1.1.1
OR
pagefindmodular-uiRange<1.1.1
OR
pagefinddefault-uiRange<1.1.1
OR
pagefindRange<1.1.1
VendorProductVersionCPE
*pagefind*cpe:2.3:a:*:pagefind:*:*:*:*:*:*:*:*
pagefindmodular-ui*cpe:2.3:a:pagefind:modular-ui:*:*:*:*:*:*:*:*
pagefinddefault-ui*cpe:2.3:a:pagefind:default-ui:*:*:*:*:*:*:*:*

CVSS3

6.4

Attack Vector

NETWORK

Attack Complexity

HIGH

Privileges Required

LOW

User Interaction

NONE

Scope

UNCHANGED

Confidentiality Impact

LOW

Integrity Impact

LOW

Availability Impact

HIGH

CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H

AI Score

5.9

Confidence

High

EPSS

0.001

Percentile

21.8%

Related for GHSA-GPRJ-6M2F-J9HX