A specially crafted HTTP request can trigger an uncaught exception on the Engine.IO server, thus killing the Node.js process.
events.js:292
throw er; // Unhandled 'error' event
^
Error: read ECONNRESET
at TCP.onStreamRead (internal/stream_base_commons.js:209:20)
Emitted 'error' event on Socket instance at:
at emitErrorNT (internal/streams/destroy.js:106:8)
at emitErrorCloseNT (internal/streams/destroy.js:74:3)
at processTicksAndRejections (internal/process/task_queues.js:80:21) {
errno: -104,
code: 'ECONNRESET',
syscall: 'read'
}
There is no known workaround except upgrading to a safe version.
Impact
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.iopackage, including those who uses depending packages likesocket.io.Patches
A fix has been released today (2022/11/20):
[email protected]3.6.1[email protected]6.2.1For
socket.iousers:engine.ioversion[email protected]~6.2.0npm audit fixshould be sufficient[email protected]~6.1.0[email protected][email protected]~6.0.0[email protected][email protected]~5.2.0[email protected][email protected]~5.1.1[email protected][email protected]~5.0.0[email protected][email protected]~4.1.0[email protected](see here)[email protected]~4.0.0[email protected](see here)[email protected]~3.6.0npm audit fixshould be sufficient[email protected]and below~3.5.0[email protected]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:
engine.ioThanks to Jonathan Neve for the responsible disclosure.