Уязвимость выделения ресурсов без ограничений или регулирования в gleam-wisp wisp позволяет осуществить отказ в обслуживании посредством анализа составного тела формы. Функция multipart_body обходит установленные ограничения max_body_size и max_files_size. Если в фрагменте отсутствует составная граница, анализатор использует путь MoreRequiredForBody, который добавляет фрагмент к выходным данным, но передает квоту без изменений в рекурсивный вызов.
С помощью Decrement_quota учитывается только последний фрагмент, содержащий границу. Тот же шаблон существует в multipart_headers, где MoreRequiredForHeaders выполняется рекурсивно без вызова decrement_body_quota. Злоумышленник, не прошедший проверку подлинности, может исчерпать память или диск сервера, отправив произвольно большие многочастные формы в одном HTTP-запросе.
Эта проблема затрагивает Wisp: с 0.2.0 до 2.2.2.
Показать оригинальное описание (EN)
Allocation of Resources Without Limits or Throttling vulnerability in gleam-wisp wisp allows a denial of service via multipart form body parsing. The multipart_body function bypasses configured max_body_size and max_files_size limits. When a multipart boundary is not present in a chunk, the parser takes the MoreRequiredForBody path, which appends the chunk to the output but passes the quota unchanged to the recursive call. Only the final chunk containing the boundary is counted via decrement_quota. The same pattern exists in multipart_headers, where MoreRequiredForHeaders recurses without calling decrement_body_quota. An unauthenticated attacker can exhaust server memory or disk by sending arbitrarily large multipart form submissions in a single HTTP request. This issue affects wisp: from 0.2.0 before 2.2.2.
Характеристики атаки
Последствия
Строка CVSS v4.0