Skip to content
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

Update koa-bodyparser to ^4.2.1 (Fixes content-length mismatch) #3229

Merged

Conversation

brendanmoore
Copy link
Contributor

@brendanmoore brendanmoore commented Aug 29, 2019

Issue:

apollo-server-koa will incorrectly throw request size did not match content length from raw-body dependency when a well form request with content-length header is followed by well formed request without a content-length header i.e. (chunked encoding)

Cause:

koa-bodyparser creates singleton options objects for co-body on this line, the version of co-body that Apollo server koa resolves to will mutate that options object fixed in this commit when content-length header is present the value is persisted in the singleton. So any follow-up request that might not contain content-length will use the previous value.

Reproduction

  1. Make any request to apollo-server-koa with a valid body and correct content-length header.
  2. Make another request to apollo-server-koa with transfer-encoding: chunked with a different body so the resultant length is different to the first request
  3. request size did not match content length will be thrown

Fix:

The co-body dependency has been fixed (in 2017!). Updating the koa-bodyparser to a version that supports the fix will resolve the issue.

@apollo-cla
Copy link

@brendanmoore: Thank you for submitting a pull request! Before we can merge it, you'll need to sign the Meteor Contributor Agreement here: https://contribute.meteor.com/

@abernix abernix merged commit 2dd0592 into apollographql:master Aug 29, 2019
@abernix abernix added this to the Release 2.9.2 milestone Aug 29, 2019
abernix added a commit that referenced this pull request Aug 31, 2019
abernix added a commit that referenced this pull request Aug 31, 2019
It was going to come to this sooner or later, since Node.js v6 is no longer
supported by the Node.js Foundation.  In this case, I'm adding this
exception because after bringing #3229 (2dd0592), the `koa-bodyparser`
package was updated to a new major version which, itself, dropped Node.js 6
support.

That update to `koa-bodyparser`, which fixes an incorrect/malformed
`Content-length` header calculation is — I think — important enough that we
should make sure it's included in Apollo Server, which currently drives the
underlying version of Koa for all users because of its close coupling with
Koa itself (via the `apollo-server-koa` package).

This micro-framework-management will no longer be a concern with
Apollo Server, particularly because of the introduction of a transport
abstraction, which I've proposed in #3184.

Ref: #3184
abernix added a commit that referenced this pull request Aug 31, 2019
It was going to come to this sooner or later, since Node.js v6 is no longer
supported by the Node.js Foundation.  In this case, I'm adding this
exception because after bringing #3229 (2dd0592), the `koa-bodyparser`
package was updated to a new major version which, itself, dropped Node.js 6
support.

That update to `koa-bodyparser`, which fixes an incorrect/malformed
`Content-length` header calculation is — I think — important enough that we
should make sure it's included in Apollo Server, which currently drives the
underlying version of Koa for all users because of its close coupling with
Koa itself (via the `apollo-server-koa` package).

This micro-framework-management will no longer be a concern with
Apollo Server, particularly because of the introduction of a transport
abstraction, which I've proposed in #3184.

Ref: #3184
abernix added a commit that referenced this pull request Aug 31, 2019
It was going to come to this sooner or later, since Node.js v6 is no longer
supported by the Node.js Foundation.  In this case, I'm adding this
exception because after bringing #3229 (2dd0592), the `koa-bodyparser`
package was updated to a new major version which, itself, dropped Node.js 6
support.

That update to `koa-bodyparser`, which fixes an incorrect/malformed
`Content-length` header calculation is — I think — important enough that we
should make sure it's included in Apollo Server, which currently drives the
underlying version of Koa for all users because of its close coupling with
Koa itself (via the `apollo-server-koa` package).

This micro-framework-management will no longer be a concern with
Apollo Server, particularly because of the introduction of a transport
abstraction, which I've proposed in #3184.

Ref: #3184
abernix added a commit that referenced this pull request Aug 31, 2019
It was going to come to this sooner or later, since Node.js v6 is no longer
supported by the Node.js Foundation.  In this case, I'm adding this
exception because after bringing #3229 (2dd0592), the `koa-bodyparser`
package was updated to a new major version which, itself, dropped Node.js 6
support.

That update to `koa-bodyparser`, which fixes an incorrect/malformed
`Content-length` header calculation is — I think — important enough that we
should make sure it's included in Apollo Server, which currently drives the
underlying version of Koa for all users because of its close coupling with
Koa itself (via the `apollo-server-koa` package).

This micro-framework-management will no longer be a concern with
Apollo Server, particularly because of the introduction of a transport
abstraction, which I've proposed in #3184.

Ref: #3184
abernix added a commit that referenced this pull request Aug 31, 2019
Since Node.js v6 is no longer supported by the Node.js Foundation, it was
going to come to this sooner or later since transitive packages are inching
their ECMAScript compilation targets to more and more recent versions of the
language.

While Apollo Server itself will drop support for Node.js v6 in 3.x, the
current Koa integration necessitates a more immediate exception since, after
bringing #3229 (2dd0592), the `koa-bodyparser` package was updated to a new
major version which, itself, dropped Node.js 6 support.

That update to `koa-bodyparser`, which fixes an incorrect/malformed
`Content-length` header calculation is important enough on its own, but
there's also a [CVE][1] for the [`qs`][2] dependency, which makes it even
more pressing.

We should make sure both of those are included in Apollo Server, which
currently drives the underlying version of Koa for all users because of its
close coupling with Koa itself (via the `apollo-server-koa` package).

This doesn't necessarily mean that those who are still on Node.js v6 are
completely out of luck, since they could probably modify their
`package-lock.json` files to use an older copy of `koa-bodyparser`, but
anyone still using Node.js v6 should certainly make considerations - sooner
rather than later — about upgrading to more recent and more supported
versions of Node.js!

Luckily, this micro-framework-management will soon no longer be a concern
with Apollo Server, particularly because of the introduction of a transport
abstraction, which I've proposed in #3184.

Ref: #3184

[1]: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2017-1000048
[2]: https://npm.im/qs

Fixes: #3050
abernix added a commit that referenced this pull request Aug 31, 2019
Since Node.js v6 is no longer supported by the Node.js Foundation, it was
going to come to this sooner or later since transitive packages are inching
their ECMAScript compilation targets to more and more recent versions of the
language.

While Apollo Server itself will drop support for Node.js v6 in 3.x, the
current Koa integration necessitates a more immediate exception since, after
bringing #3229 (2dd0592), the `koa-bodyparser` package was updated to a new
major version which, itself, dropped Node.js 6 support.

That update to `koa-bodyparser`, which fixes an incorrect/malformed
`Content-length` header calculation is important enough on its own, but
there's also a [CVE][1] for the [`qs`][2] dependency, which makes it even
more pressing.

We should make sure both of those are included in Apollo Server, which
currently drives the underlying version of Koa for all users because of its
close coupling with Koa itself (via the `apollo-server-koa` package).

This doesn't necessarily mean that those who are still on Node.js v6 are
completely out of luck, since they could probably modify their
`package-lock.json` files to use an older copy of `koa-bodyparser`, but
anyone still using Node.js v6 should certainly make considerations - sooner
rather than later — about upgrading to more recent and more supported
versions of Node.js!

Luckily, this micro-framework-management will soon no longer be a concern
with Apollo Server, particularly because of the introduction of a transport
abstraction, which I've proposed in #3184.

Ref: #3184

[1]: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2017-1000048
[2]: https://npm.im/qs

Fixes: #3050
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Mar 16, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants