OneUptime — это решение для мониторинга и управления онлайн-сервисами. До версии 10.0.20 синтетические мониторы OneUptime позволяли пользователям проекта с низким уровнем привилегий отправлять собственный код Playwright, который выполнялся в службе oneuptime-probe. В текущей реализации этот ненадежный код запускается внутри виртуальной машины Node и получает живые объекты хоста Playwright, такие как браузер и страница.
Это создает отдельный примитив RCE на стороне сервера: злоумышленнику не нужен классический выход из песочницы this.constructor.constructor(...). Вместо этого злоумышленник может напрямую использовать внедренный объект браузера Playwright для доступа к Browser.browserType().launch(...) и запуска произвольного исполняемого файла на хосте/контейнере зонда. Эта уязвимость исправлена в версии 10.0.20.
Показать оригинальное описание (EN)
OneUptime is a solution for monitoring and managing online services. Prior to 10.0.20, OneUptime Synthetic Monitors allow low-privileged project users to submit custom Playwright code that is executed on the oneuptime-probe service. In the current implementation, this untrusted code is run inside Node's vm and is given live host Playwright objects such as browser and page. This creates a distinct server-side RCE primitive: the attacker does not need the classic this.constructor.constructor(...) sandbox escape. Instead, the attacker can directly use the injected Playwright browser object to reach browser.browserType().launch(...) and spawn an arbitrary executable on the probe host/container. This vulnerability is fixed in 10.0.20.
Характеристики атаки
Последствия
Строка CVSS v3.1