CVE-2024-45389

MEDIUM IN THE WILD

Pagefind < 1.1.1 - Cross-Site Scripting via document.currentScript.src Clobbering

Title source: llm
STIX 2.1

Exploitation Summary

CVE-2024-45389 has been observed exploited in the wild (reported by InTheWild.io).

Description

Pagefind, a fully static search library, initializes its dynamic JavaScript and WebAssembly files relative to the location of the first script the user loads. This information is gathered by looking up the value of `document.currentScript.src`. Prior to Pagefind version 1.1.1, it is possible to "clobber" this lookup with otherwise benign HTML on the page. 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 a 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 cross-site scripting vector. Pagefind has tightened this resolution in version 1.1.1 by ensuring the source is loaded from a valid script element. There are no reports of this being exploited in the wild via Pagefind.

Scores

CVSS v3 6.4
EPSS 0.0121
EPSS Percentile 79.3%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H

CISA SSVC

Vulnrichment
Exploitation poc
Automatable no
Technical Impact partial

Details

InTheWild.io 2024-09-03
CWE
CWE-79
Status published
Products (6)
crates.io/pagefind 0 - 1.1.1crates.io
npm/pagefind 0 - 1.1.1npm
pagefind/default-ui 0 - 1.1.1npm
pagefind/modular-ui 0 - 1.1.1npm
pagefind/pagefind 1.1.1 alpha0 (5 CPE variants)
pagefind/pagefind < 1.1.1
Published Sep 03, 2024
Tracked Since Feb 18, 2026