SandboxJS — это библиотека песочницы JavaScript. До версии 0.8.36 SandboxJS блокировал прямое присвоение глобальным объектам (например, Math.random = ...), но эту защиту можно обойти через открытый вызываемый путь конструктора: this.constructor.call(target, AttackerObject). Поскольку this.constructor разрешается во внутреннюю функцию SandboxGlobal, а Function.prototype.call разрешен, код злоумышленника может записывать произвольные свойства в глобальные объекты хоста и сохранять эти мутации в экземплярах песочницы в одном и том же процессе.
Эта уязвимость исправлена в версии 0.8.36.
Показать оригинальное описание (EN)
SandboxJS is a JavaScript sandboxing library. Prior to 0.8.36, SandboxJS blocks direct assignment to global objects (for example Math.random = ...), but this protection can be bypassed through an exposed callable constructor path: this.constructor.call(target, attackerObject). Because this.constructor resolves to the internal SandboxGlobal function and Function.prototype.call is allowed, attacker code can write arbitrary properties into host global objects and persist those mutations across sandbox instances in the same process. This vulnerability is fixed in 0.8.36.
Характеристики атаки
Последствия
Строка CVSS v3.1
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
Nyariv Sandboxjs
cpe:2.3:a:nyariv:sandboxjs:*:*:*:*:*:node.js:*:*
|
— |
0.8.36
|