According to two unmerged docs PRs, when directly calling new tls.TLSSocket(...) it is the user's responsibility to validate peer certificates and identity.
It is important to remember, however,
that it is the caller's responsibility to manage the lifecycle of the provided
net.Socket, including establishing the connection and validating peer
certificates and identity. See the ['secure'][] event.
Both PRs demonstrate how to do this validation, but require use of:
The 'secure' event. In the current Node.js documentation, the only mention of 'secure' is under the deprecated tls.SecurePair, and is itself deprecated. It is also not clear that the 'secure' event is also emitted on tls.TLSSocket.
https://nodejs.org/docs/latest-v18.x/api/tls.html#event-secure
The current documentation does not indicate that using new tls.TLSSocket(...) by itself does not result in a secure connection.
As far as I can tell it is impossible to use new tls.TLSSocket(...) to establish a secure connection without relying on APIs that are undocumented, deprecated, and/or legacy.
Affected URL(s)
https://nodejs.org/docs/latest-v18.x/api/tls.html
Description of the problem
What is the correct, non-deprecated way to use the
new tls.TLSSocket(...)
constructor to establish a secure connection? Context: https://github.com/typelevel/fs2/security/advisories/GHSA-2cpx-6pqp-wf35According to two unmerged docs PRs, when directly calling
new tls.TLSSocket(...)
it is the user's responsibility to validate peer certificates and identity.In https://github.com/nodejs/node/pull/10846 it says:
In https://github.com/nodejs/node/pull/23915 it says:
And includes an example:
Both PRs demonstrate how to do this validation, but require use of:
'secure'
event. In the current Node.js documentation, the only mention of'secure'
is under the deprecatedtls.SecurePair
, and is itself deprecated. It is also not clear that the'secure'
event is also emitted ontls.TLSSocket
. https://nodejs.org/docs/latest-v18.x/api/tls.html#event-securetlsSocket.ssl.verifyError()
, which does not appear at all in the current documentation. Furthermore, according to https://github.com/nodejs/node/pull/840#issuecomment-74343250tlsSocket.ssl
is a "legacy property".Note that the described validation steps appear to be consistent with internal use https://github.com/nodejs/node/blob/5fbf33ef8641cf57bfbb7f0c87f83447c44266b8/lib/_tls_wrap.js#L1106 https://github.com/nodejs/node/blob/5fbf33ef8641cf57bfbb7f0c87f83447c44266b8/lib/_tls_wrap.js#L1044-L1055
This leaves me with two concerns:
new tls.TLSSocket(...)
by itself does not result in a secure connection.new tls.TLSSocket(...)
to establish a secure connection without relying on APIs that are undocumented, deprecated, and/or legacy.