-
Notifications
You must be signed in to change notification settings - Fork 30.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
kIncomingMessage undefined for socket.server #19231
Comments
do you have the full code to reproduce? |
Hi, please refer to the socket was initially created by a net/Server & bound to the server, which does not have a kIncomingMessage defined Processor.prototype.add = function(socket, data) {
if(this.state !== ST_STARTED) {
return;
}
this.httpServer.emit('connection', socket);
if(typeof socket.ondata === 'function') {
// compatible with stream2
socket.ondata(data, 0, data.length);
} else {
// compatible with old stream
socket.emit('data', data);
}
}; my current hacky fix involves doing this Processor.prototype.add = function(socket, data) {
if(this.state !== ST_STARTED) {
return;
}
socket.server = this.httpServer
this.httpServer.emit('connection', socket);
if(typeof socket.ondata === 'function') {
// compatible with stream2
socket.ondata(data, 0, data.length);
} else {
// compatible with old stream
socket.emit('data', data);
}
}; |
/cc @nodejs/http - is the hybrid use case (mixing |
Yes that’s the case. A net socket is reused for http when it detects that
the incoming data looks like http
…On Mon, 9 Apr 2018 at 18:50, Gireesh Punathil ***@***.***> wrote:
/cc @nodejs/http <https://github.com/orgs/nodejs/teams/http> - is the
hybrid use case (mixing net' socket to be fused into the http server and
the problems arises there on) supported?
—
You are receiving this because you modified the open/close state.
Reply to this email directly, view it on GitHub
<#19231 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAGXzfrgaiIV20oPtXQLTRhTnITu10Ovks5tmzzdgaJpZM4Si3ca>
.
|
@gireeshpunathil I don't think it's meant to be supported in the way that it's used here but it did work until now... We should probably resolve. |
The current check for socket.server[kIncomingMessage] does not account for the possibility of a socket.server that doesn't have that property defined. Fix it. PR-URL: #20029 Fixes: #19231 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Khaidi Chu <i@2333.moe>
The current check for socket.server[kIncomingMessage] does not account for the possibility of a socket.server that doesn't have that property defined. Fix it. PR-URL: nodejs#20029 Fixes: nodejs#19231 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Khaidi Chu <i@2333.moe>
The current check for socket.server[kIncomingMessage] does not account for the possibility of a socket.server that doesn't have that property defined. Fix it. Backport-PR-URL: #22880 PR-URL: #20029 Fixes: #19231 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Khaidi Chu <i@2333.moe>
after upgrading to node 9.7 some existing code started crashing when calling socket.emit('data', data)
the socket was created by net/Server, and later added to an httpServer through httpServer.emit('connection', socket)
I understand that the usage may be a bit hacky, but this was how some third party library implemented a hybrid server (one that takes both tcp & ws connections)
The text was updated successfully, but these errors were encountered: