Skip to content

Conversation

@mcollina
Copy link
Member

@mcollinamcollina commented Mar 2, 2019

socket.parser can be undefined under unknown circumstances.
This is a fix for a bug I cannot reproduce but it is affecting
people.

Fixes: #26366

Checklist
  • make -j4 test (UNIX), or vcbuild test (Windows) passes
  • tests and/or benchmarks are included
  • documentation is changed or added
  • commit message follows commit guidelines

@nodejs-github-botnodejs-github-bot added the http Issues or PRs related to the http subsystem. label Mar 2, 2019
@mcollinamcollina requested review from addaleax and rvaggMarch 2, 2019 18:11
@mcollina
Copy link
MemberAuthor

cc @nodejs/http

@nodejs/lts @nodejs/release we would likely have to backport this down to 6 for safety, given that we do not know how this condition is triggered.

@mcollina
Copy link
MemberAuthor

@richardlau
Copy link
Member

socket.parser can be undefined under unknown circumstances.
This is a fix for a bug I cannot reproduce but it is affecting
people.

Fixes: #26357

Shouldn't that be #26366? (Commit message too.)

@mcollina
Copy link
MemberAuthor

@richardlau good spot! Fixed.

@Trott
Copy link
Member

Trott commented Mar 2, 2019

Optional typo fix for commit title: s/existance/existence/

@Trott
Copy link
Member

Trott commented Mar 2, 2019

Here's a test that reproduces the error in #26366 in current master.

'use strict';require('../common');consthttp=require('http');constserver=http.createServer((req,res)=>{res.writeHead(200,{'Content-Type': 'text/plain'});res.write('okay',()=>{deleteres.socket.parser});res.end();});server.listen(1337,'127.0.0.1');constreq=http.request({port: 1337,host: '127.0.0.1',method: 'GET',});req.end();

@Trott
Copy link
Member

Trott commented Mar 2, 2019

Is it worth adding the code in the previous comment (or something like it) as a test?

@mcollina
Copy link
MemberAuthor

I think so. However it’s not clear if we are doing it in core or not, or it is just user specific (somehow).

@Trott
Copy link
Member

Trott commented Mar 2, 2019

By the way, #26404 is basically the same thing but on the client end rather than the server end.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Changing to parser != null would work also and be a bit safer

@lpinca
Copy link
Member

I think we need to understand why this happens or we could mask a bug instead of fixing it. It would be great if @bjjenson or @jasine could provide a test case to reproduce the issue.

@mcollina
Copy link
MemberAuthor

The overall problem with supporting a “delete” case is that it could trigger the vulnerability we are trying to protect against.

socket.parser can be undefined under unknown circumstances. This is a fix for a bug I cannot reproduce but it is affecting people. Fixes: nodejs#26366
@mcollina
Copy link
MemberAuthor

@mcollina
Copy link
MemberAuthor

Landed in 3c83f93

@mcollinamcollina closed this Mar 6, 2019
@mcollina
Copy link
MemberAuthor

@nodejs/lts this should be backported asap to all lines.

gireeshpunathil pushed a commit to gireeshpunathil/node that referenced this pull request Mar 6, 2019
socket.parser can be undefined under unknown circumstances. This is a fix for a bug I cannot reproduce but it is affecting people. Fixes: nodejs#26366 PR-URL: nodejs#26402 Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
@richardlau
Copy link
Member

@nodejs/lts this should be backported asap to all lines.

Probably too late for 11.11.0, but ping @BridgeAR.

@BridgeAR
Copy link
Member

@richardlau I would rather pull that into the release afterwards.

@lpinca
Copy link
Member

lpinca commented Mar 7, 2019

I've finally found the root issue behind #26366 or better in https://github.com/eggjs/egg-socket.io.

The problem is that our request.socket is replaced by egg-socket.io with the socket.io Socket. See https://github.com/eggjs/egg-socket.io/blob/9e7f71d835930d3a63c69635488737066f779661/lib/connectionMiddlewareInit.js#L8-L9.

There is nothing wrong with this fix but the problem is in egg-socket.io and may arise again.

I think the regression test added here does not make much sense.

BridgeAR pushed a commit to BridgeAR/node that referenced this pull request Mar 12, 2019
socket.parser can be undefined under unknown circumstances. This is a fix for a bug I cannot reproduce but it is affecting people. Fixes: nodejs#26366 PR-URL: nodejs#26402 Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
BridgeAR pushed a commit that referenced this pull request Mar 14, 2019
socket.parser can be undefined under unknown circumstances. This is a fix for a bug I cannot reproduce but it is affecting people. Fixes: #26366 PR-URL: #26402 Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
BethGriggs pushed a commit that referenced this pull request Apr 16, 2019
socket.parser can be undefined under unknown circumstances. This is a fix for a bug I cannot reproduce but it is affecting people. Fixes: #26366 PR-URL: #26402 Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
@BethGriggsBethGriggs mentioned this pull request May 1, 2019
BethGriggs pushed a commit that referenced this pull request Sep 19, 2019
socket.parser can be undefined under unknown circumstances. This is a fix for a bug I cannot reproduce but it is affecting people. Fixes: #26366 PR-URL: #26402 Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
@BethGriggsBethGriggs mentioned this pull request Sep 19, 2019
Sign up for freeto join this conversation on GitHub. Already have an account? Sign in to comment

Labels

httpIssues or PRs related to the http subsystem.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Cannot set property 'parsingHeadersStart' of undefined on 10.15.2

10 participants

@mcollina@nodejs-github-bot@richardlau@Trott@lpinca@BridgeAR@jasnell@cjihrig@targos@BethGriggs