Описание
IPX Allows Path Traversal via Prefix Matching Bypass
Summary
The approach used to check whether a path is within allowed directories is vulnerable to path prefix bypass when the allowed directories do not end with a path separator. This occurs because the check relies on a raw string prefix comparison.
PoC
- setup
main.js
node main.js
Impact
Path Traversal
Possible Fix
Check if the dir ends with / (path separator) and if not, add before calling startsWith
Ссылки
- https://github.com/unjs/ipx/security/advisories/GHSA-mm3p-j368-7jcr
- https://nvd.nist.gov/vuln/detail/CVE-2025-54387
- https://github.com/unjs/ipx/commit/81693ddbfc062cc922e4e2406e8427ab4e3ad214
- https://github.com/unjs/ipx/releases/tag/v1.3.2
- https://github.com/unjs/ipx/releases/tag/v2.1.1
- https://github.com/unjs/ipx/releases/tag/v3.1.1
Пакеты
ipx
< 1.3.2
1.3.2
ipx
>= 2.0.0-0, < 2.1.1
2.1.1
ipx
>= 3.0.0, < 3.1.1
3.1.1
Связанные уязвимости
IPX is an image optimizer powered by sharp and svgo. In versions 1.3.1 and below, 2.0.0-0 through 2.1.0, and 3.0.0 through 3.1.0, the approach used to check whether a path is within allowed directories is vulnerable to path prefix bypass when the allowed directories do not end with a path separator. This occurs because the check relies on a raw string prefix comparison. This is fixed in versions 1.3.2, 2.1.1 and 3.1.1.