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 body-parser to latest version 1.18.3 #3706

Closed
wants to merge 1 commit into from

Conversation

amitzur
Copy link
Contributor

@amitzur amitzur commented Aug 7, 2018

The implication of this change (other than getting the changes in body-parser@1.18.3) is smaller footprint in node_modules for projects which also require body-parser from its latest version.
Currently such projects will have 2 copies of body-parser.

@dougwilson
Copy link
Contributor

Thanks! The original plan was to hold this for the next minor version of Express because we were going to use that to align around safer-buffer so we can not have both safe-buffer and safer-buffer in the tree.

As per your project issue, of course ideally you shouldn't need to depend on body-parser at all, since it's already bundled with Express. If you really need to, pinning it to the same Express version you're using would of course deduplicate as well.

@amitzur
Copy link
Contributor Author

amitzur commented Aug 7, 2018

How do I use the body-parser version that's bundled with express ?
I thought this line was aimed to block it:

throw new Error('Most middleware (like ' + name + ') is no longer bundled with Express and must be installed separately. Please see https://github.com/senchalabs/connect#middleware.');

@dougwilson
Copy link
Contributor

It shouldn't be blocking body-parser usage, otherwise if we were blocking it, we wouldn't have a dependency on it at all. Can you demonstrate the code you are using?

Here is some docs on expressjs.com:

http://expressjs.com/en/4x/api.html#express.json
http://expressjs.com/en/4x/api.html#express.urlencoded

@amitzur
Copy link
Contributor Author

amitzur commented Aug 7, 2018

I wanted to use express.raw but it's not available. Here's my code:

const bodyParser = require('body-parser');
...
app.put('/some-path', bodyParser.raw({type: '*/*', limit: '100mb'}), async (req, res) => {
...

@dougwilson
Copy link
Contributor

Ah. I think the not exposing of raw may have just been an oversight.

@amitzur
Copy link
Contributor Author

amitzur commented Aug 8, 2018

Thanks @dougwilson! I've opened #3708 to have raw available.
Can you shed more light on the safe-buffer/safer-buffer story?
And also when is the next minor version planned?

@amitzur amitzur closed this Aug 8, 2018
@dougwilson dougwilson self-assigned this Sep 19, 2018
dougwilson pushed a commit to felixbuenemann/express that referenced this pull request Sep 19, 2018
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants