VDB
KO
HIGH 7.5

GHSA-cgwc-pv48-fhj5

python-engineio has unbound thread allocation that can cause denial of service

Details

### Impact An attacker can cause the creation of unnecessary background threads in the python-engineio server by exploiting the heartbeat mechanism, which launches a thread when a new connection is received, and when the client sends a PONG packet.

Note: this issue primarily affects synchronous servers. Asynchronous servers allocate background tasks instead of physical threads, which are lightweight and less likely to cause denial of service. However, the fix that was implemented was also applied to the asynchronous case.

### Patches Version 4.13.2 addresses this issue as follows:

- The initial background thread (or async task( for heartbeat management is only launched if a client passes authentication in the `connect` handler. - The server now ensures that there is only one background heatbeat thread (or async task) per client at a given point in time. Out of sequence PONG packets are now discarded when an active heartbeat thread is already running.

Are you affected?

Enter the version of the package you're using.

Affected packages

PyPI / python-engineio
Introduced in: 0 Fixed in: 4.13.2
Fix pip install --upgrade 'python-engineio>=4.13.2'

References