Advisory Database
  • Advisories
  • Dependency Scanning
  1. npm
  2. ›
  3. @pagefind/modular-ui
  4. ›
  5. CVE-2024-45389

CVE-2024-45389: DOM clobbering could escalate to Cross-site Scripting (XSS)

September 3, 2024 (updated September 12, 2024)

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 name="currentScript" src="blob:https://xxx.xxx.xxx/ui.js"></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.

References

  • github.com/CloudCannon/pagefind
  • github.com/CloudCannon/pagefind/commit/14ec96864eabaf1d7d809d5da0186a8856261eeb
  • github.com/CloudCannon/pagefind/security/advisories/GHSA-gprj-6m2f-j9hx
  • github.com/advisories/GHSA-gprj-6m2f-j9hx
  • github.com/webpack/webpack/security/advisories/GHSA-4vvj-4cpr-p986
  • nvd.nist.gov/vuln/detail/CVE-2024-45389

Code Behaviors & Features

Detect and mitigate CVE-2024-45389 with GitLab Dependency Scanning

Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →

Affected versions

All versions before 1.1.1

Fixed versions

  • 1.1.1

Solution

Upgrade to version 1.1.1 or above.

Impact 5.4 MEDIUM

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

Learn more about CVSS

Weakness

  • CWE-79: Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')

Source file

npm/@pagefind/modular-ui/CVE-2024-45389.yml

Spotted a mistake? Edit the file on GitLab.

  • Site Repo
  • About GitLab
  • Terms
  • Privacy Statement
  • Contact

Page generated Wed, 14 May 2025 12:15:29 +0000.