Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

github логотип

GHSA-8qvm-5x2c-j2w7

Опубликовано: 16 июн. 2025
Источник: github
Github: Прошло ревью
CVSS4: 8.2

Описание

protobuf-python has a potential Denial of Service issue

Summary

Any project that uses Protobuf pure-Python backend to parse untrusted Protocol Buffers data containing an arbitrary number of recursive groups, recursive messages or a series of SGROUP tags can be corrupted by exceeding the Python recursion limit.

Reporter: Alexis Challande, Trail of Bits Ecosystem Security Team ecosystem@trailofbits.com

Affected versions: This issue only affects the pure-Python implementation of protobuf-python backend. This is the implementation when PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=python environment variable is set or the default when protobuf is used from Bazel or pure-Python PyPi wheels. CPython PyPi wheels do not use pure-Python by default.

This is a Python variant of a previous issue affecting protobuf-java.

Severity

This is a potential Denial of Service. Parsing nested protobuf data creates unbounded recursions that can be abused by an attacker.

Proof of Concept

For reproduction details, please refer to the unit tests decoder_test.py and message_test

Remediation and Mitigation

A mitigation is available now. Please update to the latest available versions of the following packages:

  • protobuf-python(4.25.8, 5.29.5, 6.31.1)

Пакеты

Наименование

protobuf

pip
Затронутые версииВерсия исправления

< 4.25.8

4.25.8

Наименование

protobuf

pip
Затронутые версииВерсия исправления

>= 5.26.0rc1, < 5.29.5

5.29.5

Наименование

protobuf

pip
Затронутые версииВерсия исправления

>= 6.30.0rc1, < 6.31.1

6.31.1

EPSS

Процентиль: 12%
0.00042
Низкий

8.2 High

CVSS4

Дефекты

CWE-674

Связанные уязвимости

ubuntu
4 дня назад

Any project that uses Protobuf Pure-Python backend to parse untrusted Protocol Buffers data containing an arbitrary number of recursive groups, recursive messages or a series of SGROUP tags can be corrupted by exceeding the Python recursion limit. This can result in a Denial of service by crashing the application with a RecursionError. We recommend upgrading to version =>6.31.1 or beyond commit 17838beda2943d08b8a9d4df5b68f5f04f26d901

CVSS3: 5.3
redhat
4 дня назад

Any project that uses Protobuf Pure-Python backend to parse untrusted Protocol Buffers data containing an arbitrary number of recursive groups, recursive messages or a series of SGROUP tags can be corrupted by exceeding the Python recursion limit. This can result in a Denial of service by crashing the application with a RecursionError. We recommend upgrading to version =>6.31.1 or beyond commit 17838beda2943d08b8a9d4df5b68f5f04f26d901

nvd
4 дня назад

Any project that uses Protobuf Pure-Python backend to parse untrusted Protocol Buffers data containing an arbitrary number of recursive groups, recursive messages or a series of SGROUP tags can be corrupted by exceeding the Python recursion limit. This can result in a Denial of service by crashing the application with a RecursionError. We recommend upgrading to version =>6.31.1 or beyond commit 17838beda2943d08b8a9d4df5b68f5f04f26d901

debian
4 дня назад

Any project that uses Protobuf Pure-Python backendto parse untrusted P ...

EPSS

Процентиль: 12%
0.00042
Низкий

8.2 High

CVSS4

Дефекты

CWE-674