Security
Headlines
HeadlinesLatestCVEs

Headline

GHSA-q9mw-68c2-j6m5: engine.io Uncaught Exception vulnerability

Impact

A specially crafted HTTP request can trigger an uncaught exception on the Engine.IO server, thus killing the Node.js process.

TypeError: Cannot read properties of undefined (reading 'handlesUpgrades')
    at Server.onWebSocket (build/server.js:515:67)

This impacts all the users of the engine.io package, including those who uses depending packages like socket.io.

Patches

A fix has been released today (2023/05/02): 6.4.2

This bug was introduced in version 5.1.0 and included in version 4.1.0 of the socket.io parent package. Older versions are not impacted.

For socket.io users:

Version rangeengine.io versionNeeds minor update?
[email protected]~6.4.0npm audit fix should be sufficient
[email protected]~6.2.0Please upgrade to [email protected]
[email protected]~6.1.0Please upgrade to [email protected]
[email protected]~6.0.0Please upgrade to [email protected]
[email protected]~5.2.0Please upgrade to [email protected]
[email protected]~5.1.1Please upgrade to [email protected]
[email protected]~5.0.0Not impacted
[email protected]~4.1.0Not impacted
[email protected]~4.0.0Not impacted
[email protected]~3.6.0Not impacted
[email protected] and below~3.5.0Not impacted

Workarounds

There is no known workaround except upgrading to a safe version.

For more information

If you have any questions or comments about this advisory:

Thanks to Thomas Rinsma from Codean for the responsible disclosure.

ghsa
#vulnerability#web#nodejs#js#git

Impact

A specially crafted HTTP request can trigger an uncaught exception on the Engine.IO server, thus killing the Node.js process.

TypeError: Cannot read properties of undefined (reading 'handlesUpgrades')
    at Server.onWebSocket (build/server.js:515:67)

This impacts all the users of the engine.io package, including those who uses depending packages like socket.io.

Patches

A fix has been released today (2023/05/02): 6.4.2

This bug was introduced in version 5.1.0 and included in version 4.1.0 of the socket.io parent package. Older versions are not impacted.

For socket.io users:

Version range

engine.io version

Needs minor update?

[email protected]

~6.4.0

npm audit fix should be sufficient

[email protected]

~6.2.0

Please upgrade to [email protected]

[email protected]

~6.1.0

Please upgrade to [email protected]

[email protected]

~6.0.0

Please upgrade to [email protected]

[email protected]

~5.2.0

Please upgrade to [email protected]

[email protected]

~5.1.1

Please upgrade to [email protected]

[email protected]

~5.0.0

Not impacted

[email protected]

~4.1.0

Not impacted

[email protected]

~4.0.0

Not impacted

[email protected]

~3.6.0

Not impacted

[email protected] and below

~3.5.0

Not impacted

Workarounds

There is no known workaround except upgrading to a safe version.

For more information

If you have any questions or comments about this advisory:

  • Open an issue in engine.io

Thanks to Thomas Rinsma from Codean for the responsible disclosure.

References

  • GHSA-q9mw-68c2-j6m5
  • socketio/engine.io@fc480b4
  • https://github.com/socketio/engine.io/releases/tag/6.4.2

Related news

CVE-2023-28955: Security Bulletin: Multiple security vulnerabilities affecting Watson Knowledge Catalog for IBM Cloud Pak for Data

IBM Watson Knowledge Catalog on Cloud Pak for Data 4.0 could allow an authenticated user send a specially crafted request that could cause a denial of service. IBM X-Force ID: 251704.

CVE-2023-31125: Release 6.4.2 · socketio/engine.io

Engine.IO is the implementation of transport-based cross-browser/cross-device bi-directional communication layer for Socket.IO. An uncaught exception vulnerability was introduced in version 5.1.0 and included in version 4.1.0 of the `socket.io` parent package. Older versions are not impacted. A specially crafted HTTP request can trigger an uncaught exception on the Engine.IO server, thus killing the Node.js process. This impacts all the users of the `engine.io` package, including those who use depending packages like `socket.io`. This issue was fixed in version 6.4.2 of Engine.IO. There is no known workaround except upgrading to a safe version.