ewe — веб-сервер Gleam. До версии 3.0.6 функция encode_headers в src/ewe/internal/encoder.gleam напрямую интерполирует ключи и значения заголовка ответа в необработанные байты HTTP без проверки или удаления последовательностей CRLF (\r\n). Приложение, которое передает контролируемые пользователем данные в заголовки ответов (например, устанавливая заголовок перенаправления местоположения из параметра запроса), позволяет злоумышленнику внедрить произвольное содержимое ответа HTTP, что приводит к разделению ответа, отравлению кеша и возможному межсайтовому сценарию.
Примечательно, что ewe проверяет CRLF во входящих заголовках запросов с помощью validate_field_value() в парсере HTTP/1.1, но не обеспечивает эквивалентной защиты для заголовков исходящих ответов в кодировщике. Эта проблема исправлена в версии 3.0.6.
Показать оригинальное описание (EN)
ewe is a Gleam web server. Prior to version 3.0.6, the encode_headers function in src/ewe/internal/encoder.gleam directly interpolates response header keys and values into raw HTTP bytes without validating or stripping CRLF (\r\n) sequences. An application that passes user-controlled data into response headers (e.g., setting a Location redirect header from a request parameter) allows an attacker to inject arbitrary HTTP response content, leading to response splitting, cache poisoning, and possible cross-site scripting. Notably, ewe does validate CRLF in incoming request headers via validate_field_value() in the HTTP/1.1 parser — but provides no equivalent protection for outgoing response headers in the encoder. This issue has been patched in version 3.0.6.
Характеристики атаки
Последствия
Строка CVSS v3.1
Тип уязвимости (CWE)
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
Vshakitskiy Ewe
cpe:2.3:a:vshakitskiy:ewe:*:*:*:*:*:*:*:*
|
— |
3.0.6
|