zlib — это Ruby-интерфейс для библиотеки сжатия/распаковки zlib. Версии 3.0.0 и ниже, 3.1.0, 3.1.1, 3.2.0 и 3.2.1 содержат уязвимость переполнения буфера в Zlib::GzipReader. Функция zstream_buffer_ungets добавляет байты, предоставленные вызывающей стороной, перед ранее созданным выводом, но не может гарантировать, что поддерживающая строка Ruby имеет достаточную емкость до того, как memmove сдвинет существующие данные.
Это может привести к повреждению памяти, когда длина буфера превышает емкость. Эта проблема исправлена в версиях 3.0.1, 3.1.2 и 3.2.3.
Показать оригинальное описание (EN)
zlib is a Ruby interface for the zlib compression/decompression library. Versions 3.0.0 and below, 3.1.0, 3.1.1, 3.2.0 and 3.2.1 contain a buffer overflow vulnerability in the Zlib::GzipReader. The zstream_buffer_ungets function prepends caller-provided bytes ahead of previously produced output but fails to guarantee the backing Ruby string has enough capacity before the memmove shifts the existing data. This can lead to memory corruption when the buffer length exceeds capacity. This issue has been fixed in versions 3.0.1, 3.1.2 and 3.2.3.
Характеристики атаки
Последствия
Строка CVSS v4.0