LiquidJS — это шаблонизатор, совместимый с Shopify/GitHub Pages, на чистом JavaScript. До версии 10.25.3 для {% include %}, {% render %} и {% Layout %} LiquidJS проверяет, находится ли путь-кандидат внутри настроенных частей или корней макетов, прежде чем читать его. Эта проверка основана на пути, а не на реальном пути.
По этой причине файл типа parts/link.liquid проходит проверку на наличие каталога, если его путь находится под разрешенным корнем. Если link.liquid на самом деле является символической ссылкой на файл за пределами разрешенного корня, файловая система следует по символической ссылке при открытии файла, и LiquidJS отображает внешнюю цель. Таким образом, ограничение применяется к запрошенной строке пути, а не к файлу, который фактически читается.
Это важно в средах, где злоумышленник может размещать шаблоны или иным образом влиять на файлы в доверенном корне шаблона, включая загруженные темы, извлеченные архивы, смонтированный контент или деревья шаблонов, контролируемые репозиторием. Эта уязвимость исправлена в версии 10.25.3.
Показать оригинальное описание (EN)
LiquidJS is a Shopify / GitHub Pages compatible template engine in pure JavaScript. Prior to 10.25.3, for {% include %}, {% render %}, and {% layout %}, LiquidJS checks whether the candidate path is inside the configured partials or layouts roots before reading it. That check is path-based, not realpath-based. Because of that, a file like partials/link.liquid passes the directory containment check as long as its pathname is under the allowed root. If link.liquid is actually a symlink to a file outside the allowed root, the filesystem follows the symlink when the file is opened and LiquidJS renders the external target. So the restriction is applied to the path string that was requested, not to the file that is actually read. This matters in environments where an attacker can place templates or otherwise influence files under a trusted template root, including uploaded themes, extracted archives, mounted content, or repository-controlled template trees. This vulnerability is fixed in 10.25.3.
Характеристики атаки
Последствия
Строка CVSS v4.0
Тип уязвимости (CWE)
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
Liquidjs Liquidjs
cpe:2.3:a:liquidjs:liquidjs:*:*:*:*:*:node.js:*:*
|
— |
10.25.3
|