jq — это процессор JSON командной строки. Уязвимость целочисленного переполнения существует в версии 1.8.1 в функциях jvp_string_append() и jvp_string_copy_replace_bad, где объединение строк с общей длиной, превышающей 2^31 байт, вызывает переполнение 32-битного беззнакового целого числа при вычислении размера выделения буфера, что приводит к значительному уменьшению размера буфера кучи. Последующие операции копирования памяти затем записывают полные строковые данные в этот буфер уменьшенного размера, вызывая переполнение буфера кучи, классифицированное как CWE-190 (целочисленное переполнение), что приводит к CWE-122 (переполнение буфера на основе кучи).
Это затрагивает любую систему, оценивающую ненадежные запросы jq, поскольку злоумышленник может привести к сбою процесса или потенциально добиться дальнейшей эксплуатации за счет повреждения кучи, создавая запросы, которые создают чрезвычайно большие строки. Основная причина — отсутствие проверки границ размера строки, в отличие от массивов и объектов, у которых уже есть ограничения на размер. Проблема решена в коммите e47e56d226519635768e6aab2f38f0ab037c09e5.
Показать оригинальное описание (EN)
jq is a command-line JSON processor. An integer overflow vulnerability exists through version 1.8.1 within the jvp_string_append() and jvp_string_copy_replace_bad functions, where concatenating strings with a combined length exceeding 2^31 bytes causes a 32-bit unsigned integer overflow in the buffer allocation size calculation, resulting in a drastically undersized heap buffer. Subsequent memory copy operations then write the full string data into this undersized buffer, causing a heap buffer overflow classified as CWE-190 (Integer Overflow) leading to CWE-122 (Heap-based Buffer Overflow). Any system evaluating untrusted jq queries is affected, as an attacker can crash the process or potentially achieve further exploitation through heap corruption by crafting queries that produce extremely large strings. The root cause is the absence of string size bounds checking, unlike arrays and objects which already have size limits. The issue has been addressed in commit e47e56d226519635768e6aab2f38f0ab037c09e5.
Характеристики атаки
Последствия
Строка CVSS v3.1