Active Support — это набор библиотек поддержки и расширений ядра Ruby, извлеченных из платформы Rails. До версий 8.1.2.1, 8.0.4.1 и 7.2.3.1 SafeBuffer#% не распространял флаг @html_unsafe во вновь созданный буфер. Если `SafeBuffer` изменен на месте (например, через `gsub!`), а затем отформатирован с помощью `%` с использованием ненадежных аргументов, в результате будет неверно указано `html_safe? == true`, минуя автоматическое экранирование ERB и, возможно, приводя к XSS.
Версии 8.1.2.1, 8.0.4.1 и 7.2.3.1 содержат исправление.
Показать оригинальное описание (EN)
Active Support is a toolkit of support libraries and Ruby core extensions extracted from the Rails framework. Prior to versions 8.1.2.1, 8.0.4.1, and 7.2.3.1, `SafeBuffer#%` does not propagate the `@html_unsafe` flag to the newly created buffer. If a `SafeBuffer` is mutated in place (e.g. via `gsub!`) and then formatted with `%` using untrusted arguments, the result incorrectly reports `html_safe? == true`, bypassing ERB auto-escaping and possibly leading to XSS. Versions 8.1.2.1, 8.0.4.1, and 7.2.3.1 contain a patch.
Характеристики атаки
Последствия
Строка CVSS v4.0
Тип уязвимости (CWE)
Уязвимые продукты 3
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
Rubyonrails Rails
cpe:2.3:a:rubyonrails:rails:*:*:*:*:*:*:*:*
|
— |
7.2.3.1
|
|
Rubyonrails Rails
cpe:2.3:a:rubyonrails:rails:*:*:*:*:*:*:*:*
|
8.0.0
|
8.0.4.1
|
|
Rubyonrails Rails
cpe:2.3:a:rubyonrails:rails:*:*:*:*:*:*:*:*
|
8.1.0
|
8.1.2.1
|