Skip to content

Conversation

@anandsuresh
Copy link
Contributor

@anandsuresh anandsuresh commented Mar 29, 2018

From the zlib v1.2.11 manual:

ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm,
int windowBits));

...
windowBits can also be zero to request that inflate use the window
size in the zlib header of the compressed stream.

The current validation of windowBits in zlib.js doesn't check for this
case.

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

From the zlib v1.2.11 manual:

> ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm,
>                                      int  windowBits));
>
> ...
> windowBits can also be zero to request that inflate use the window
> size in the zlib header of the compressed stream.

The current validation of windowBits in zlib.js doesn't check for this
case.
@nodejs-github-bot nodejs-github-bot added the zlib Issues and PRs related to the zlib subsystem. label Mar 29, 2018
lib/zlib.js Outdated
mode === GUNZIP ||
mode === INFLATERAW ||
mode === UNZIP)) {
windowBits = 0
Copy link
Member

Choose a reason for hiding this comment

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

Can you run make lint? It should complain about the lack of a semicolon here ;)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

whoops. I'm spoiled by standardjs! Will fix.

lib/zlib.js Outdated
if (opts.windowBits === 0 &&
(mode === INFLATE ||
mode === GUNZIP ||
mode === INFLATERAW ||
Copy link
Member

Choose a reason for hiding this comment

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

INFLATERAW means that there is no header, so I think we'd want to drop that case?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Sure. I picked the list from

node/src/node_zlib.cc

Lines 541 to 544 in 22f4a35

case INFLATE:
case GUNZIP:
case INFLATERAW:
case UNZIP:
, since they all end up calling inflateInit2(). Will remove it from the list.

lib/zlib.js Outdated
// windowBits is special. On the compression side, 0 is an invalid value.
// But on the decompression side, a value of 0 for windowBits tells zlib
// to extract the value from the headers of the compressed stream.
if (opts.windowBits === 0 &&
Copy link
Member

Choose a reason for hiding this comment

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

We may actually want to also capture undefined here, so that when decompressing we always go with the header-provided value (instead of the safe maximum) for lower memory usage.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

excellent idea! How about opts.windowBits == null || opts.windowBits === 0?

Copy link
Member

Choose a reason for hiding this comment

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

@anandsuresh Sounds reasonable to me!

@richardlau
Copy link
Member

Test(s)?

@anandsuresh anandsuresh force-pushed the anandsuresh/zlibWindowBits branch from 0eacda7 to 10e9d16 Compare March 29, 2018 23:18
@lpinca
Copy link
Member

lpinca commented Mar 30, 2018

SGTM with tests added.

@anandsuresh anandsuresh force-pushed the anandsuresh/zlibWindowBits branch from 10e9d16 to 736be73 Compare March 30, 2018 16:37
@anandsuresh
Copy link
Contributor Author

tests added.

Copy link
Member

Choose a reason for hiding this comment

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

common.expectsError() instead of try-catch.

Copy link
Member

Choose a reason for hiding this comment

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

common.expectsError() instead of try-catch.

Copy link
Member

@lpinca lpinca Mar 30, 2018

Choose a reason for hiding this comment

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

This is already tested in test-zlib-deflate-constructors.js so it is probably redundant.

Copy link
Member

@lpinca lpinca Mar 30, 2018

Choose a reason for hiding this comment

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

We can simply by using common.expectsError():

common.expectsError(
  () => zlib.createGzip({windowBits: 0}),
  {
    code: 'ERR_INVALID_OPT_VALUE',
    type: RangeError,
    message: '...'
  }
);

@anandsuresh anandsuresh force-pushed the anandsuresh/zlibWindowBits branch 2 times, most recently from bcb88e0 to 1ba53f2 Compare March 30, 2018 19:58
@anandsuresh
Copy link
Contributor Author

standby.... some tests are failing. Working to fix those.

@anandsuresh anandsuresh force-pushed the anandsuresh/zlibWindowBits branch from 1ba53f2 to fda4044 Compare March 30, 2018 20:43
@anandsuresh
Copy link
Contributor Author

all tests passing again.

@lpinca
Copy link
Member

lpinca commented Mar 31, 2018

@BridgeAR BridgeAR added the author ready PRs that have at least one approval, no pending requests for changes, and a CI started. label Apr 9, 2018
@BridgeAR
Copy link
Member

BridgeAR commented Apr 9, 2018

Landed in 7bc5151 🎉

@BridgeAR BridgeAR closed this Apr 9, 2018
BridgeAR pushed a commit to BridgeAR/node that referenced this pull request Apr 9, 2018
From the zlib v1.2.11 manual:

> ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm,
>                                      int  windowBits));
>
> ...
> windowBits can also be zero to request that inflate use the window
> size in the zlib header of the compressed stream.

The current validation of windowBits in zlib.js doesn't check for this
case.

PR-URL: nodejs#19686
Reviewed-By: Richard Lau <riclau@uk.ibm.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
BridgeAR pushed a commit to BridgeAR/node that referenced this pull request May 1, 2018
From the zlib v1.2.11 manual:

> ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm,
>                                      int  windowBits));
>
> ...
> windowBits can also be zero to request that inflate use the window
> size in the zlib header of the compressed stream.

The current validation of windowBits in zlib.js doesn't check for this
case.

PR-URL: nodejs#19686
Reviewed-By: Richard Lau <riclau@uk.ibm.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

author ready PRs that have at least one approval, no pending requests for changes, and a CI started. zlib Issues and PRs related to the zlib subsystem.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

7 participants