From d67be241ee4879f39e770700fe51cb5e6bdd238b Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Mon, 4 Nov 2024 17:20:37 -0800 Subject: [PATCH] Break source code into modules --- .gitignore | 7 +- action.js | 2 +- eol-versions.js | 125 -- is-vulnerable.js | 213 --- package.json | 2 +- setup-test.js | 6 +- ascii.js => src/ascii.js | 0 src/cache/schedule.etag | 1 + src/cache/schedule.json | 141 ++ src/cache/security.etag | 1 + src/cache/security.json | 1960 +++++++++++++++++++++++++++ src/cli.js | 40 + index.js => src/index.js | 8 +- src/is-node-eol.js | 28 + src/is-node-vulnerable.js | 24 + src/store.js | 18 + src/utils/check-platform.js | 8 + src/utils/debug.js | 7 + src/utils/fetch-json.js | 32 + src/utils/get-json.js | 33 + src/utils/get-version-info.js | 23 + src/utils/get-vulnerability-list.js | 23 + src/utils/is-system-affected.js | 14 + src/utils/load-etag.js | 14 + test.js | 2 +- 25 files changed, 2378 insertions(+), 354 deletions(-) delete mode 100644 eol-versions.js delete mode 100644 is-vulnerable.js rename ascii.js => src/ascii.js (100%) create mode 100644 src/cache/schedule.etag create mode 100644 src/cache/schedule.json create mode 100644 src/cache/security.etag create mode 100644 src/cache/security.json create mode 100644 src/cli.js rename index.js => src/index.js (69%) create mode 100644 src/is-node-eol.js create mode 100644 src/is-node-vulnerable.js create mode 100644 src/store.js create mode 100644 src/utils/check-platform.js create mode 100644 src/utils/debug.js create mode 100644 src/utils/fetch-json.js create mode 100644 src/utils/get-json.js create mode 100644 src/utils/get-version-info.js create mode 100644 src/utils/get-vulnerability-list.js create mode 100644 src/utils/is-system-affected.js create mode 100644 src/utils/load-etag.js diff --git a/.gitignore b/.gitignore index fe51038..86344b6 100644 --- a/.gitignore +++ b/.gitignore @@ -121,9 +121,4 @@ out .clinic/ tags -tags.* - -schedule.etag -schedule.json -security.etag -security.json +tags.* \ No newline at end of file diff --git a/action.js b/action.js index bed2f6c..28d0a9a 100644 --- a/action.js +++ b/action.js @@ -1,5 +1,5 @@ const core = require('@actions/core') -const { isNodeVulnerable } = require('./index') +const { isNodeVulnerable } = require('./src/index') async function run () { // Inputs diff --git a/eol-versions.js b/eol-versions.js deleted file mode 100644 index 0a42ebb..0000000 --- a/eol-versions.js +++ /dev/null @@ -1,125 +0,0 @@ -// Sync from https://raw.githubusercontent.com/nodejs/Release/master/schedule.json -// These are the list of versions that might be affected by this module dependencies -const versionMap = { - // v0.12 - v0: { - start: '2015-02-06', - end: '2016-12-31' - }, - v4: { - start: '2015-09-08', - lts: '2015-10-12', - maintenance: '2017-04-01', - end: '2018-04-30', - codename: 'Argon' - }, - v5: { - start: '2015-10-29', - maintenance: '2016-04-30', - end: '2016-06-30' - }, - v6: { - start: '2016-04-26', - lts: '2016-10-18', - maintenance: '2018-04-30', - end: '2019-04-30', - codename: 'Boron' - }, - v7: { - start: '2016-10-25', - maintenance: '2017-04-30', - end: '2017-06-30' - }, - v8: { - start: '2017-05-30', - lts: '2017-10-31', - maintenance: '2019-01-01', - end: '2019-12-31', - codename: 'Carbon' - }, - v9: { - start: '2017-10-01', - maintenance: '2018-04-01', - end: '2018-06-30' - }, - v10: { - start: '2018-04-24', - lts: '2018-10-30', - maintenance: '2020-05-19', - end: '2021-04-30', - codename: 'Dubnium' - }, - v11: { - start: '2018-10-23', - maintenance: '2019-04-22', - end: '2019-06-01' - }, - v12: { - start: '2019-04-23', - lts: '2019-10-21', - maintenance: '2020-11-30', - end: '2022-04-30', - codename: 'Erbium' - }, - v13: { - start: '2019-10-22', - maintenance: '2020-04-01', - end: '2020-06-01' - }, - v14: { - start: '2020-04-21', - lts: '2020-10-27', - maintenance: '2021-10-19', - end: '2023-04-30', - codename: 'Fermium' - }, - v15: { - start: '2020-10-20', - maintenance: '2021-04-01', - end: '2021-06-01' - }, - v16: { - start: '2021-04-20', - lts: '2021-10-26', - maintenance: '2022-10-18', - end: '2023-09-11', - codename: 'Gallium' - }, - v17: { - start: '2021-10-19', - maintenance: '2022-04-01', - end: '2022-06-01' - }, - v19: { - start: '2022-10-18', - maintenance: '2023-04-01', - end: '2023-06-01' - } -} - -function isOldEnough (version) { - const versionInfo = getVersionInfo(version) - - if (!versionInfo) { - return false - } else if (!versionInfo.end) { - return true // Versions without an EOL date are considered EOL - } - - const now = new Date() - const end = new Date(versionInfo.end) - return now > end -} - -function getVersionInfo (version) { - const majorVersion = extractMajorVersion(version) - return versionMap[majorVersion] || null -} - -function extractMajorVersion (version) { - // Extracts the major version number from a version string like 'v12.22.12' - const major = version.split('.')[0] - return major -} - -module.exports = isOldEnough diff --git a/is-vulnerable.js b/is-vulnerable.js deleted file mode 100644 index 63b399f..0000000 --- a/is-vulnerable.js +++ /dev/null @@ -1,213 +0,0 @@ -const { danger, allGood, bold, vulnerableWarning, separator } = require('./ascii') -const { request } = require('https') -const fs = require('fs') -const path = require('path') -const satisfies = require('semver/functions/satisfies') - -const STORE = { - security: { - url: 'https://raw.githubusercontent.com/nodejs/security-wg/main/vuln/core/index.json', - jsonFile: path.join(__dirname, 'security.json'), - etagFile: path.join(__dirname, 'security.etag'), - etagValue: '' - }, - schedule: { - url: 'https://raw.githubusercontent.com/nodejs/Release/main/schedule.json', - jsonFile: path.join(__dirname, 'schedule.json'), - etagFile: path.join(__dirname, 'schedule.etag'), - etagValue: '' - } -} - -async function readLocal (file) { - return require(file) -} - -function debug (msg) { - if (process.env.DEBUG) { - console.debug(msg) - } -} - -function loadETag () { - for (const [key, obj] of Object.entries(STORE)) { - if (fs.existsSync(obj.etagFile)) { - debug(`Loading local ETag for '${key}'`) - obj.etagValue = fs.readFileSync(obj.etagFile).toString() - } - } -} - -async function fetchJson (obj) { - await new Promise((resolve) => { - request(obj.url, (res) => { - if (res.statusCode !== 200) { - console.error(`Request to Github returned http status ${res.statusCode}. Aborting...`) - process.nextTick(() => { process.exit(1) }) - } - - const fileStream = fs.createWriteStream(obj.jsonFile) - res.pipe(fileStream) - - fileStream.on('finish', () => { - fileStream.close() - resolve() - }) - - fileStream.on('error', (err) => { - console.error(`Error ${err.message} while writing to '${obj.jsonFile}'. Aborting...`) - process.nextTick(() => { process.exit(1) }) - }) - }).on('error', (err) => { - console.error(`Request to Github returned error ${err.message}. Aborting...`) - process.nextTick(() => { process.exit(1) }) - }).end() - }) - return readLocal(obj.jsonFile) -} - -async function getJson (obj) { - return new Promise((resolve) => { - request(obj.url, { method: 'HEAD' }, (res) => { - if (res.statusCode !== 200) { - console.error(`Request to Github returned http status ${res.statusCode}. Aborting...`) - process.nextTick(() => { process.exit(1) }) - } - - res.on('data', () => {}) - - const { etag } = res.headers - if (!obj.etagValue || obj.eTagValue !== etag || !fs.existsSync(obj.jsonFile)) { - obj.etagValue = etag - fs.writeFileSync(obj.etagFile, etag) - debug('Creating local core.json') - resolve(fetchJson(obj)) - } else { - debug(`No updates from upstream. Getting a cached version: ${obj.jsonFile}`) - resolve(readLocal(obj.jsonFile)) - } - }).on('error', (err) => { - console.error(`Request to Github returned error ${err.message}. Aborting...`) - process.nextTick(() => { process.exit(1) }) - }).end() - }) -} - -const checkPlatform = platform => { - const availablePlatforms = ['aix', 'darwin', 'freebsd', 'linux', 'openbsd', 'sunos', 'win32', 'android'] - if (platform && !availablePlatforms.includes(platform)) { - throw new Error(`platform ${platform} is not valid. Please use ${availablePlatforms.join(',')}.`) - } -} - -const isSystemAffected = (platform, affectedEnvironments) => { - // No platform specified (legacy mode) - if (!platform || !Array.isArray(affectedEnvironments)) { - return true - } - // If the environment is matching or all the environments are affected - if (affectedEnvironments.includes(platform) || affectedEnvironments.includes('all')) { - return true - } - // Default to false - return false -} - -function getVulnerabilityList (currentVersion, data, platform) { - const list = [] - for (const key in data) { - const vuln = data[key] - - if ( - ( - satisfies(currentVersion, vuln.vulnerable) && - !satisfies(currentVersion, vuln.patched) - ) && isSystemAffected(platform, vuln.affectedEnvironments) - ) { - const severity = vuln.severity === 'unknown' ? '' : `(${vuln.severity})` - list.push(`${bold(vuln.cve)}${severity}: ${vuln.overview}\n${bold('Patched versions')}: ${vuln.patched}`) - } - } - return list -} - -async function cli (currentVersion, platform) { - checkPlatform(platform) - - const isEOL = await isNodeEOL(currentVersion) - if (isEOL) { - console.error(danger) - console.error(`${currentVersion} is end-of-life. There are high chances of being vulnerable. Please upgrade it.`) - process.exit(1) - } - - const securityJson = await getJson(STORE.security) - const list = getVulnerabilityList(currentVersion, securityJson, platform) - - if (list.length) { - console.error(danger) - console.error(vulnerableWarning + '\n') - console.error(`${list.join(`\n${separator}\n\n`)}\n${separator}`) - process.exit(1) - } else { - console.info(allGood) - } -} - -async function getVersionInfo (version) { - const scheduleJson = await getJson(STORE.schedule) - - if (scheduleJson[version.toLowerCase()]) { - return scheduleJson[version.toLowerCase()] - } - - for (const [key, value] of Object.entries(scheduleJson)) { - if (satisfies(version, key)) { - return value - } - } - - return null -} - -/** - * @param {string} version - * @returns {Promise} true if the version is end-of-life - */ -async function isNodeEOL (version) { - const myVersionInfo = await getVersionInfo(version) - - if (!myVersionInfo) { - // i.e. isNodeEOL('abcd') or isNodeEOL('lts') or isNodeEOL('99') - throw Error(`Could not fetch version information for ${version}`) - } else if (!myVersionInfo.end) { - // We got a record, but.. - // v0.12.18 etc does not have an EOL date, which probably means too old. - return true - } - - const now = new Date() - const end = new Date(myVersionInfo.end) - return now > end -} - -async function isNodeVulnerable (version, platform) { - checkPlatform(platform) - const isEOL = await isNodeEOL(version) - if (isEOL) { - return true - } - - const coreIndex = await getJson(STORE.security) - const list = getVulnerabilityList(version, coreIndex, platform) - return list.length > 0 -} - -if (process.argv[2] !== '-r') { - loadETag() -} - -module.exports = { - isNodeVulnerable, - cli -} diff --git a/package.json b/package.json index 0b48101..1b696f7 100644 --- a/package.json +++ b/package.json @@ -4,7 +4,7 @@ "description": "package that checks if your Node.js installation is vulnerable to known security vulnerabilities", "main": "index.js", "bin": { - "is-my-node-vulnerable": "./index.js" + "is-my-node-vulnerable": "./src/index.js" }, "keywords": [ "security", diff --git a/setup-test.js b/setup-test.js index 0837840..cb3f207 100644 --- a/setup-test.js +++ b/setup-test.js @@ -1,8 +1,8 @@ -const isOldEnough = require('./eol-versions') +const isNodeEOL = require('./src/is-node-eol') const assert = require('assert') // When old enough an error is thrown -if (isOldEnough(process.version)) { +if (isNodeEOL(process.version)) { runCompatibilityTest() } else { require('./test') @@ -11,7 +11,7 @@ if (isOldEnough(process.version)) { function runCompatibilityTest () { const childProcess = require('child_process') const path = require('path') - const isNodeVulnerablePath = path.resolve('./index.js') + const isNodeVulnerablePath = path.resolve('./src/index.js') const child = childProcess.spawnSync(process.execPath, [isNodeVulnerablePath]) assert.strictEqual(child.status, 1) assert(child.stdout.toString().indexOf('is end-of-life. There are high chances of being vulnerable') !== -1) diff --git a/ascii.js b/src/ascii.js similarity index 100% rename from ascii.js rename to src/ascii.js diff --git a/src/cache/schedule.etag b/src/cache/schedule.etag new file mode 100644 index 0000000..b2f0eb3 --- /dev/null +++ b/src/cache/schedule.etag @@ -0,0 +1 @@ +"f333f2f1aaaec1ea47b3107fd989b1e1a736a46106a5910fc2f8672a01ba6754" \ No newline at end of file diff --git a/src/cache/schedule.json b/src/cache/schedule.json new file mode 100644 index 0000000..75da4b8 --- /dev/null +++ b/src/cache/schedule.json @@ -0,0 +1,141 @@ +{ + "v0.8": { + "start": "2012-06-25", + "end": "2014-07-31" + }, + "v0.10": { + "start": "2013-03-11", + "end": "2016-10-31" + }, + "v0.12": { + "start": "2015-02-06", + "end": "2016-12-31" + }, + "v4": { + "start": "2015-09-08", + "lts": "2015-10-12", + "maintenance": "2017-04-01", + "end": "2018-04-30", + "codename": "Argon" + }, + "v5": { + "start": "2015-10-29", + "maintenance": "2016-04-30", + "end": "2016-06-30" + }, + "v6": { + "start": "2016-04-26", + "lts": "2016-10-18", + "maintenance": "2018-04-30", + "end": "2019-04-30", + "codename": "Boron" + }, + "v7": { + "start": "2016-10-25", + "maintenance": "2017-04-30", + "end": "2017-06-30" + }, + "v8": { + "start": "2017-05-30", + "lts": "2017-10-31", + "maintenance": "2019-01-01", + "end": "2019-12-31", + "codename": "Carbon" + }, + "v9": { + "start": "2017-10-01", + "maintenance": "2018-04-01", + "end": "2018-06-30" + }, + "v10": { + "start": "2018-04-24", + "lts": "2018-10-30", + "maintenance": "2020-05-19", + "end": "2021-04-30", + "codename": "Dubnium" + }, + "v11": { + "start": "2018-10-23", + "maintenance": "2019-04-22", + "end": "2019-06-01" + }, + "v12": { + "start": "2019-04-23", + "lts": "2019-10-21", + "maintenance": "2020-11-30", + "end": "2022-04-30", + "codename": "Erbium" + }, + "v13": { + "start": "2019-10-22", + "maintenance": "2020-04-01", + "end": "2020-06-01" + }, + "v14": { + "start": "2020-04-21", + "lts": "2020-10-27", + "maintenance": "2021-10-19", + "end": "2023-04-30", + "codename": "Fermium" + }, + "v15": { + "start": "2020-10-20", + "maintenance": "2021-04-01", + "end": "2021-06-01" + }, + "v16": { + "start": "2021-04-20", + "lts": "2021-10-26", + "maintenance": "2022-10-18", + "end": "2023-09-11", + "codename": "Gallium" + }, + "v17": { + "start": "2021-10-19", + "maintenance": "2022-04-01", + "end": "2022-06-01" + }, + "v18": { + "start": "2022-04-19", + "lts": "2022-10-25", + "maintenance": "2023-10-18", + "end": "2025-04-30", + "codename": "Hydrogen" + }, + "v19": { + "start": "2022-10-18", + "maintenance": "2023-04-01", + "end": "2023-06-01" + }, + "v20": { + "start": "2023-04-18", + "lts": "2023-10-24", + "maintenance": "2024-10-22", + "end": "2026-04-30", + "codename": "Iron" + }, + "v21": { + "start": "2023-10-17", + "maintenance": "2024-04-01", + "end": "2024-06-01" + }, + "v22": { + "start": "2024-04-24", + "lts": "2024-10-29", + "maintenance": "2025-10-21", + "end": "2027-04-30", + "codename": "Jod" + }, + "v23": { + "start": "2024-10-16", + "maintenance": "2025-04-01", + "end": "2025-06-01" + }, + "v24": { + "start": "2025-04-22", + "lts": "2025-10-28", + "maintenance": "2026-10-20", + "end": "2028-04-30", + "codename": "" + } +} diff --git a/src/cache/security.etag b/src/cache/security.etag new file mode 100644 index 0000000..0130c01 --- /dev/null +++ b/src/cache/security.etag @@ -0,0 +1 @@ +"25e8b7c386ec726bd3ca00e0605fb0e6f77b69d529f938bdb9ed12b838712874" \ No newline at end of file diff --git a/src/cache/security.json b/src/cache/security.json new file mode 100644 index 0000000..93161ca --- /dev/null +++ b/src/cache/security.json @@ -0,0 +1,1960 @@ +{ + "1": { + "cve": [ + "CVE-2017-1000381" + ], + "ref": "https://nodejs.org/en/blog/vulnerability/july-2017-security-releases/", + "vulnerable": "8.x || 7.x || 4.x || 6.x || 5.x", + "patched": "^8.1.4 || ^7.10.1 || ^4.8.4 || ^6.11.1", + "description": "memory overread when parsing invalid NAPTR responses", + "overview": "The c-ares function ares_parse_naptr_reply(), which is used for parsing NAPTR\nresponses, could be triggered to read memory outside of the given input buffer\nif the passed in DNS response packet was crafted in a particular way.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "2": { + "cve": [], + "vulnerable": "4.x || 5.x || 6.x || 7.x || 8.x", + "patched": "^4.8.4 || ^6.11.1 || ^7.10.1 || ^8.1.4", + "description": "DoS possible in V8 object lookup", + "overview": "Disable V8 snapshots - The hashseed embedded in the snapshot is\ncurrently the same for all runs of the binary. This opens node up to\ncollision attacks which could result in a Denial of Service. We have\ntemporarily disabled snapshots until a more robust solution is found\nFixed: Ali Ijaz Sheikh\nReported: Fedor Indutny\nref: https://nodejs.org/en/blog/vulnerability/july-2017-security-releases/\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "3": { + "cve": [ + "CVE-2017-3731" + ], + "description": "Truncated packet could crash via OOB read", + "vulnerable": "4.x || 5.x || 6.x || 7.x", + "patched": "^4.7.3 || ^6.9.5 || ^7.5.0", + "ref": "https://nodejs.org/en/blog/vulnerability/openssl-january-2017/", + "overview": "This is a moderate severity flaw in OpenSSL. By default, Node.js disables RC4 so\nmost users are not affected. As RC4 can be enabled programmatically, it is\npossible for a Node.js developer to craft code that may be vulnerable to this\nflaw. Any user activating RC4 in their codebase should prioritise this update.\n\nAll active versions of Node.js are affected, but the severity is very low for\nmost users.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "4": { + "cve": [ + "CVE-2017-3732" + ], + "vulnerable": "4.x || 5.x || 6.x || 7.x", + "patched": "^4.7.3 || ^6.9.5 || ^7.5.0", + "ref": "https://nodejs.org/en/blog/vulnerability/openssl-january-2017/", + "description": "BN_mod_exp may produce incorrect results on x86_64", + "overview": "As noted by the OpenSSL team, the likelihood of being able to craft a practical\nattack that uses this flaw is very low. In addition, Node.js enables\nSSL_OP_SINGLE_DH_USE, further decreasing the chance of a successful exploit of\nthis vulnerability in a Node.js service.\n\nAll active versions of Node.js are affected, but the severity is very low for\nNode.js users.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "5": { + "cve": [ + "CVE-2016-7055" + ], + "description": "Montgomery multiplication may produce incorrect results", + "vulnerable": "4.x || 5.x || 6.x || 7.x", + "patched": "^4.7.3 || ^6.9.5 || ^7.5.0", + "ref": "https://nodejs.org/en/blog/vulnerability/openssl-january-2017/", + "overview": "Some calculations, when run on an Intel Broadwell or later CPU, can produce in\nerroneous results. This flaw has been previously discussed by the Node.js team\non GitHub. It is not believed that practical attacks can be crafted to exploit\nthis vulnerability except in very specific circumstances. Therefore this is a\nlow severity flaw.\n\nAll active versions of Node.js are affected, but the severity is very low for\nNode.js users.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "6": { + "cve": [ + "CVE-2016-9551" + ], + "description": "potential buffer overflow when writing data to console on Windows 10", + "vulnerable": "^7.1.0", + "patched": "^7.2.0", + "ref": "https://github.com/nodejs/node/pull/9647", + "overview": "Please be aware that Node.js v7.2.0 was released today and includes a small\nsecurity update arising from libuv: https://nodejs.org/en/blog/release/v7.2.0/\n\nlibuv v1.10.1 reverts a change that was introduced in v1.10.0, included in\nNode.js v7.1.0. The reverted code was found to contain a potential buffer\noverflow in output written to the console. We are not aware of any exploit of\nthis flaw and it only impacts Windows 10 (November update and later). This flaw\nhas been assigned the identifier CVE-2016-9551 and was originally discovered and\nreported by Hitesh Kanwathirtha of Microsoft.\n\nUsers of the v7 release line running on Windows 10 should upgrade to Node.js\nv7.2.0 at their earliest convenience.\n\nNo other version of Node.js is known to be impacted by this flaw.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "7": { + "cve": [ + "CVE-2016-9840", + "CVE-2016-9841", + "CVE-2016-9842", + "CVE-2016-9843" + ], + "ref": "https://github.com/madler/zlib/commit/d1d577490c15a0c6862473d7576352a9f18ef811", + "description": "undefined language constructs that may have security impact", + "vulnerable": "4.x || 5.x || 6.x || 7.x", + "patched": "^4.8.2 || ^6.10.2 || ^7.6.0", + "overview": "An upgrade to zlib 1.2.11 to fix a number of low severity CVEs\nthat were present in zlib 1.2.8.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "8": { + "cve": [ + "CVE-2016-5180" + ], + "vulnerable": "0.10.x || 0.12.x || 4.x", + "patched": "^0.10.48 || ^0.12.17 || ^4.6.1", + "description": "ares_create_query single byte out of buffer write", + "ref": "https://c-ares.haxx.se/adv_20160929.html", + "overview": "A security vulnerability has been discovered in the c-ares library that is\nbundled with all versions of Node.js. Due to the difficulty of triggering and\nmaking use of this vulnerability we currently consider this a low-severity\nsecurity flaw for Node.js users.\n\nMore information at https://c-ares.haxx.se/adv_20160929.html\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "9": { + "cve": [], + "vulnerable": "6.x", + "patched": "^6.9.0", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2016-security-releases/", + "description": "automatically loading OPENSSL_CONF is unsafe", + "overview": "Always triggering a configuration file load attempt from `OPENSSL_CONF` or the\ndefault location for the current platform may allow an attacker to load\ncompromised OpenSSL configuration into a Node.js process if they are able to\nplace a file in a default location.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "10": { + "cve": [ + "CVE-2016-5172" + ], + "vulnerable": "6.x", + "patched": "^6.9.0", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2016-security-releases/", + "overview": "The V8 parser mishandled scopes, potentially allowing an attacker to obtain\nsensitive information from arbitrary memory locations via crafted JavaScript\ncode. This vulnerability would require an attacker to be able to execute\narbitrary JavaScript code in a Node.js process.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "11": { + "cve": [], + "vulnerable": "6.x", + "patched": "^6.9.0", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2016-security-releases/", + "author": "Jann Horn", + "description": "unauthorized clients can easily access inspector port", + "overview": "Generate a UUID for each execution of the inspector. This provides additional\nsecurity to prevent unauthorized clients from connecting to the Node.js process\nvia the v8_inspector port when running with `--inspect`. Since the debugging\nprotocol allows extensive access to the internals of a running process, and the\nexecution of arbitrary code, it is important to limit connections to authorized\ntools only.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "12": { + "cve": [ + "CVE-2016-6304" + ], + "ref": "https://github.com/nodejs/node/pull/8714", + "vulnerable": "6.x || 5.x || 4.x", + "patched": "^6.7.0 || ^4.6.0", + "description": "openssl 1.0.2h vulnerabilities", + "overview": "A malicious client can exhaust a server's memory, resulting in a denial of\nservice (DoS) by sending very large OCSP Status Request extensions in a single\nsession.\n\nThis flaw is labelled high severity due to the ease of use for a DoS attack and\nNode.js servers using TLS are vulnerable.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "13": { + "cve": [ + "CVE-2016-2183" + ], + "ref": "https://github.com/nodejs/node/pull/8714", + "vulnerable": "6.x || 5.x || 4.x", + "patched": "^6.7.0 || ^4.6.0", + "description": "openssl 1.0.2h vulnerabilities", + "overview": "SWEET32 is a new attack on older block cipher algorithms that use a block size\nof 64 bits.\n\nAs mitigation, OpenSSL has moved DES-based ciphers from the HIGH to MEDIUM\ngroup. As Node.js includes HIGH, but not MEDIUM, in its default suite, affected\nciphers are no longer included unless the default suite is not used. Node's\ndefault TLS cipher suite can be found in the API documentation.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "14": { + "cve": [ + "CVE-2016-6303" + ], + "ref": "https://github.com/nodejs/node/pull/8714", + "vulnerable": "6.x || 5.x || 4.x", + "patched": "^6.7.0 || ^4.6.0", + "description": "openssl 1.0.2h vulnerabilities", + "overview": "An overflow can occur in MDC2_Update() under certain circumstances resulting in\nan out of bounds (OOB) error. This attack is impractical on most platforms due\nto the size of data required to trigger the OOB error.\n\nNode.js is impacted by this flaw but due to the impracticalities of exploiting\nit and the very low usage of of MDC-2, it is very low severity for Node.js\nusers.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "15": { + "cve": [ + "CVE-2016-2178" + ], + "ref": "https://github.com/nodejs/node/pull/8714", + "vulnerable": "6.x || 5.x || 4.x", + "patched": "^6.7.0 || ^4.6.0", + "description": "openssl 1.0.2h vulnerabilities", + "overview": "A flaw in the OpenSSL DSA implementation means that a non-constant time codepath\nis followed for certain operations. This has been demonstrated through a\ncache-timing attack to be sufficient for an attacker to recover the private DSA\nkey.\n\nThis is very low severity for Node.js users due to the difficulty in taking\nadvantage of this attack and because DSA is very rarely used.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "16": { + "cve": [ + "CVE-2016-6306" + ], + "ref": "https://github.com/nodejs/node/pull/8714", + "vulnerable": "6.x || 5.x || 4.x", + "patched": "^6.7.0 || ^4.6.0", + "description": "openssl 1.0.2h vulnerabilities", + "overview": "Some missing message length checks can result in out of bounds (OOB) reads of up\nto 2 bytes beyond an allocated buffer. There is a theoretical denial of service\n(DoS) risk. This only impacts a client or a server which enables client\nauthentication.\n\nNode.js is impacted by this low severity flaw.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "17": { + "cve": [], + "ref": "https://github.com/nodejs/node-private/pull/73", + "vulnerable": "6.x", + "patched": "^6.7.0", + "author": "Ahmed Zaki", + "overview": "Remove support for loading dynamic third-party engine modules. An attacker\nmay be able to hide malicious code to be inserted into Node.js at runtime by\nmasquerading as one of the dynamic engine modules. Originally reported by\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "18": { + "cve": [ + "CVE-2016-5325" + ], + "ref": "https://github.com/nodejs/node-private/pull/60", + "vulnerable": "6.x || 4.x || 5.x", + "patched": "^6.7.0 || ^4.6.0", + "author": "Romain Gaucher", + "description": "HTTP processing security defect (CVE-2016-5325)", + "cvss": "3.0/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:L/A:N", + "cvss_score": 4.8, + "overview": "**http**: Properly validate for allowable characters in the `reason` argument in\n`ServerResponse#writeHead()`. Fixes a possible response splitting attack vector.\nThis introduces a new case where `throw` may occur when configuring HTTP\nresponses, users should already be adopting try/catch here.\n\nThis is a low severity security defect that that may make HTTP response\nsplitting possible under certain circumstances. If user-input is passed to the\nreason argument to writeHead() on an HTTP response, a new-line character may be\nused to inject additional responses.\n\nThe fix for this defect introduces a new case where throw may occur when\nconfiguring HTTP responses. Users should already be adopting try/catch here.\n\nCommon Vulnerability Scoring System (CVSS) v3 Base Score:\n\n\tMetric\tScore\n\tBase Score:\t4.8 (Medium)\n\tBase Vector:\tCVSS:3.0/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:L/A:N\n\tAttack Vector:\tNetwork (AV:N)\n\tAttack Complexity:\tHigh (AC:H)\n\tPrivileges Required:\tNone (PR:N)\n\tUser Interaction:\tNone (UI:N)\n\tScope of Impact:\tUnchanged (S:U)\n\tConfidentiality Impact:\tLow (C:L)\n\tIntegrity Impact:\tLow (I:L)\n\tAvailability Impact:\tNone (A:N)\n\nRefer to the\n[CVSS v3 Specification](https://www.first.org/cvss/specification-document)\nfor details on the meanings and application of the vector components.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "19": { + "cve": [ + "CVE-2016-7099" + ], + "ref": "https://github.com/nodejs/node/commit/743f0c9164", + "vulnerable": "6.x || 4.x || 5.x", + "patched": "^6.7.0 || ^4.6.0", + "author": "Alexander Minozhenko and James Bunton (Atlassian)", + "description": "invalid wildcard certificate validation check", + "overview": "Fix invalid wildcard certificate validation check whereby a TLS server may be\nable to serve an invalid wildcard certificate for its hostname due to improper\nvalidation of `*.` in the wildcard string. \n\nThis is a high severity defect that would allow a malicious TLS server to serve\nan invalid wildcard certificate for its hostname and be improperly validated by\na Node.js client. This is due to a flaw in the validation of *. in the wildcard\nname string.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "20": { + "cve": [], + "ref": "https://github.com/nodejs/node-private/pull/73", + "vulnerable": "6.x || 4.x", + "patched": "^6.7.0 || ^4.6.0", + "description": "**crypto**: don't build hardware engines (Ben Noordhuis)", + "overview": "This is a low severity security defect. By default, OpenSSL will load a list of\nthird-party engine modules when the ENGINE_load_builtin_engines() function is\nused. These are normally not present on a user's system. An attacker may be able\nto make Node.js load malicious code by masquerading it as one of the dynamic\nengine modules.\n\nThis defect primarily impacts Windows due to the standard DLL search paths.\nHowever, UNIX users may also be at risk with a poorly configured LD_LIBRARY_PATH\nenvironment variable or /etc/ld.so.conf path list.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "21": { + "cve": [], + "vulnerable": "6.x || 5.x || 4.x", + "patched": "^6.2.1 || ^4.5.0", + "description": "Ignore negative lengths in calls to `Buffer()` and `Buffer.allocUnsafe()`.", + "ref": "https://github.com/nodejs/node/issues/7047#issuecomment-222393982", + "overview": "This fixes a possible security concern (reported by Feross Aboukhadijeh) where\nuser input is passed unchecked to the Buffer constructor or `allocUnsafe()` as\nit can expose parts of the memory slab used by other Buffers in the application.\nNote that negative lengths are not supported by the Buffer API and user input to\nthe constructor should always be sanitised and type-checked.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "22": { + "cve": [ + "CVE-2016-2107" + ], + "vulnerable": "4.x || 5.x || 6.x", + "patched": "^4.4.4 || ^5.11.1 || ^6.1.0", + "ref": "https://nodejs.org/en/blog/vulnerability/openssl-may-2016/#cve-2016-2107-padding-oracle-in-aes-ni-cbc-mac-check", + "description": "Padding oracle in AES-NI CBC MAC check", + "overview": "A man-in-the-middle (MITM) attacker may be able to execute a padding oracle\nattack to decrypt traffic when a connection uses an AES-CBC cipher and the\nserver runs on an Intel CPU supporting AES-NI. This is a common configuration\nfor TLS servers.\n\nThe OpenSSL project has labelled this vulnerability high severity.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "23": { + "cve": [ + "CVE-2016-2105" + ], + "vulnerable": "4.x || 5.x || 6.x", + "patched": "^4.4.4 || ^5.11.1 || ^6.1.0", + "ref": "https://nodejs.org/en/blog/vulnerability/openssl-may-2016/#cve-2016-2107-padding-oracle-in-aes-ni-cbc-mac-check", + "description": "EVP_EncodeUpdate overflow", + "overview": "An overflow can occur in the OpenSSL EVP_EncodeUpdate() function which is used\nfor Base64 encoding of binary data. An attacker must be able to supply large\namounts of input data in order to cause an overflow.\n\nNode.js uses the EVP_EncodeUpdate() internally during calls to\ncrypto.Certificate#exportPublicKey() for SPKAC Certificate Signing\nRequests. User-supplied data must be passed to this method for\napplications to be vulnerable. This method has been available since\nNode.js v0.12.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "24": { + "cve": [ + "CVE-2016-1669" + ], + "vulnerable": ">=6.0.0 <6.2.0 || 5.x || 4.x", + "patched": "^4.4.6 || ^5.12.0", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2016-security-releases", + "description": "Buffer overflow in V8", + "overview": "Under certain conditions, V8 may improperly expand memory allocations in the\nZone::New function. This could potentially be used to cause a Denial of Service\nvia buffer overflow or as a trigger for a remote code execution.\n\nAlthough this bug is marked as high severity in the corresponding Chromium\nrelease (50.0.2661.102), our assessment is that this is low severity for\nNode.js users due to the level of difficulty in making use of this\nvulnerability. However, users are encouraged to upgrade their Node.js\ninstallation to ensure they are properly protected.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "25": { + "cve": [], + "vulnerable": "5.x || 4.x || 6.x", + "patched": "^5.12.0 || ^4.5.0 || ^6.2.1", + "ref": "https://github.com/nodejs/node/pull/7562", + "description": "ignore negative allocation lengths", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "26": { + "cve": [], + "description": "security flaw in the use of npm authentication tokens in HTTP requests", + "vulnerable": "5.x || 4.x", + "patched": "^5.10.0 || 4.4.2", + "ref": "https://github.com/npm/node/pull/6", + "overview": "Upgrade npm to fixes a security flaw in the use of\nauthentication tokens in HTTP requests that would allow an attacker to set up a\nserver that could collect tokens from users of the command-line interface.\nAuthentication tokens have previously been sent with every request made by the\nCLI for logged-in users, regardless of the destination of the request. This\nupdate fixes this by only including those tokens for requests made against the\nregistry or registries used for the current install.\n\nThis is a flaw in the version of npm included with node.\n\nnpm is updated to 3.8.3 in node 5.10.1, and to 2.15.1 in node 4.4.2.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "27": { + "cve": [ + "CVE-2016-2086" + ], + "vulnerable": "5.x || 4.x", + "patched": "^5.6.0 || ^4.3.0", + "overview": "Fix defects in HTTP header parsing for requests and responses that\ncan allow request smuggling (CVE-2016-2086).\n\nHTTP header parsing now aligns more closely with the HTTP spec\nincluding restricting the acceptable characters.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "28": { + "cve": [ + "CVE-2016-2216" + ], + "vulnerable": "5.x || 4.x", + "patched": "^5.6.0 || ^4.3.0", + "overview": "Fix defects in HTTP header parsing for requests and responses that\ncan allow response splitting (CVE-2016-2216).\n\nHTTP header parsing now aligns more closely with the HTTP spec\nincluding restricting the acceptable characters.\n\nIntroduce new `--security-revert={cvenum}` command line flag for selective\nreversion of specific CVE fixes allow the fix for CVE-2016-2216 to be\nselectively reverted using `--security-revert=CVE-2016-2216`.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "29": { + "cve": [], + "vulnerable": "4.x || 5.x", + "patched": "^5.11.1 || ^4.4.4", + "description": "buffer safeguard against accidental kNoZeroFill", + "overview": "To reproduce: try { Buffer(1e10); } catch (e) {} new Uint8Array(100);.\n\nTo be affected, one would need to:\n\nHave any way how the user could make the API pass huge numbers to\nBuffer/SlowBuffer/Buffer.allocUnsafe, e.g. by sending invalid input\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "30": { + "cve": [], + "vulnerable": "4.x || 5.x", + "patched": "^4.3.2 || ^5.7.1", + "ref": "https://github.com/nodejs/node/pull/5507", + "overview": "Fix a double-free defect in parsing malformed DSA keys that may potentially be\nused for DoS or memory corruption attacks. It is likely to be very difficult to\nuse this defect for a practical attack and is therefore considered low severity\nfor Node.js users. More info is available at\ncve: CVE-2016-0705\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "31": { + "cve": [ + "CVE-2016-0797" + ], + "vulnerable": "4.x || 5.x", + "patched": "^4.3.2 || ^5.7.1", + "ref": "https://github.com/nodejs/node/pull/5507", + "overview": "Fix a defect that can cause memory corruption in certain very rare cases\nrelating to the internal `BN_hex2bn()` and `BN_dec2bn()` functions. It is\nbelieved that Node.js is not invoking the code paths that use these functions so\npractical attacks via Node.js using this defect are _unlikely_ to be possible.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "32": { + "cve": [ + "CVE-2016-0702" + ], + "vulnerable": "4.x || 5.x", + "patched": "^4.3.2 || ^5.7.1", + "ref": "https://ssrg.nicta.com.au/projects/TS/cachebleed", + "overview": "Fix a defect that makes the _[CacheBleed\nAttack](https://ssrg.nicta.com.au/projects/TS/cachebleed/)_ possible. This\ndefect enables attackers to execute side-channel attacks leading to the\npotential recovery of entire RSA private keys. It only affects the Intel Sandy\nBridge (and possibly older) microarchitecture when using hyper-threading. Newer\nmicroarchitectures, including Haswell, are unaffected.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "33": { + "cve": [], + "vulnerable": "4.x || 5.x", + "patched": "^5.6.0 || ^4.3.0", + "description": "mitigate against the Logjam attack", + "overview": "To mitigate against the Logjam attack, TLS clients now reject Diffie-Hellman\nhandshakes with parameters shorter than 1024-bits, up from the previous limit of\n768-bits.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "34": { + "cve": [ + "CVE-2015-8027" + ], + "vulnerable": "5.x || 4.x", + "patched": "^5.1.1 || ^4.2.3", + "overview": "A bug whereby an HTTP socket may no longer have a parser associated with it but\na pipelined request attempts to trigger a pause or resume on the non-existent\nparser, a potential denial-of-service vulnerability.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "35": { + "cve": [ + "CVE-2015-6764" + ], + "vulnerable": "5.x || 4.x", + "patched": "^5.1.1 || ^4.2.3", + "overview": "Backport fix for CVE-2015-6764, a bug in v8's `JSON.stringify()` that can result\nin out-of-bounds reads for arrays.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "36": { + "cve": [ + "CVE-2015-3193" + ], + "vulnerable": "5.x || 4.x", + "patched": "^5.1.1 || ^4.2.3", + "ref": "http://openssl.org/news/secadv/20151203.txt", + "description": "BN_mod_exp may produce incorrect results on x86_64", + "overview": "An attack may be possible against a Node.js TLS server using DHE key exchange.\nDetails are available at .\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "37": { + "cve": [ + "CVE-2015-3194" + ], + "vulnerable": "5.x || 4.x", + "patched": "^5.1.1 || ^4.2.3", + "ref": "https://github.com/nodejs/node/pull/4134", + "description": "Certificate verify crash with missing PSS parameter", + "overview": "A potential denial-of-service vector for Node.js TLS servers using client\ncertificate authentication; TLS clients are also impacted. Details are available\nat .\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "38": { + "cve": [], + "vulnerable": "4.x || 6.x", + "patched": "^4.7.2 || ^6.9.4", + "description": "no shasum exists to verify downloads", + "overview": "While promoting additional platforms for v4.7.1 and v6.9.3 after the release,\nthe tarballs on the release server were overwritten and now have different\nshasums.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "39": { + "cve": [], + "vulnerable": "4.x", + "patched": "^4.1.1", + "description": "data leakage via reuse of memory space in TypedArrays", + "ref": "https://github.com/nodejs/node/pull/2931", + "overview": "A bug was introduced in v4.1.0 where allocating a new zero-length buffer can\nresult in the _next_ allocation of a TypedArray in JavaScript not being\nzero-filled. In certain circumstances this could result in data leakage via\nreuse of memory space in TypedArrays, breaking the normally safe assumption that\nTypedArrays should be always zero-filled.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "40": { + "cve": [ + "CVE-2015-7384" + ], + "vulnerable": "4.x", + "patched": "^4.1.2", + "cvss": "3.0/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:H", + "cvss_score": 5.9, + "ref": "https://github.com/nodejs/node/pull/3128", + "description": "out-of-order 'finish' event bug in pipelining can abort execution", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "41": { + "cve": [], + "vulnerable": "4.x", + "patched": "^4.1.1", + "ref": "https://github.com/nodejs/node/pull/2945", + "overview": "Guard against response-splitting of HTTP trailing headers added via\n[`response.addTrailers()`](https://nodejs.org/api/http.html#http_response_addtrailers_headers)\nby removing new-line (`[\\r\\n]`) characters from values. Note that standard\nheader values are already stripped of new-line characters. The expected security\nimpact is low because trailing headers are rarely used.\n\n", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "42": { + "cve": [ + "CVE-2017-14849" + ], + "vulnerable": "8.5.0", + "patched": "^8.6.0", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2017-path-validation/", + "overview": "Node.js version 8.5.0 included a change which caused a security vulnerability in the checks on paths made by some community modules. As a result, an attacker may be able to access file system paths other than those intended.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "43": { + "cve": [ + "CVE-2017-14919" + ], + "vulnerable": "^4.8.2 || ^6.10.2 || 8.x", + "patched": "^4.8.5 || ^6.11.5 || ^8.8.0", + "ref": "https://nodejs.org/en/blog/vulnerability/oct-2017-dos/", + "overview": "Node.js was susceptible to a remote DoS attack due to a change that came in as part of zlib v1.2.9. In zlib v1.2.9 8 became an invalid value for the windowBits parameter and Node's zlib module will crash or throw an exception (depending on the version) if you call zlib.createDeflateRaw({windowBits: 8}).", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "44": { + "cve": [ + "CVE-2017-15896" + ], + "vulnerable": "4.x || 6.x || 8.x || 9.x", + "patched": "^4.8.7 || ^6.12.2 || ^8.9.3 || ^9.2.1", + "ref": "https://nodejs.org/en/blog/vulnerability/december-2017-security-releases/", + "overview": "Node.js was affected by OpenSSL vulnerability CVE-2017-3737 in regards to the use of SSL_read() due to TLS handshake failure. The result was that an active network attacker could send application data to Node.js using the TLS or HTTP2 modules in a way that bypassed TLS authentication and encryption.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "45": { + "cve": [ + "CVE-2017-15897" + ], + "vulnerable": "8.x || 9.x", + "patched": "^8.9.3 || ^9.2.1", + "ref": "https://nodejs.org/en/blog/vulnerability/december-2017-security-releases/", + "overview": "Node.js had a bug in versions 8.X and 9.X which caused buffers to not be initialized when the encoding for the fill value did not match the encoding specified. For example, 'Buffer.alloc(0x100, \"This is not correctly encoded\", \"hex\");' The buffer implementation was updated such that the buffer will be initialized to all zeros in these cases.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "46": { + "cve": [ + "CVE-2018-7158" + ], + "vulnerable": "4.x", + "patched": "^4.9.0", + "ref": "https://nodejs.org/en/blog/vulnerability/march-2018-security-releases/", + "overview": "The `'path'` module in the Node.js 4.x release line contains a potential regular expression denial of service (ReDoS) vector. The code in question was replaced in Node.js 6.x and later so this vulnerability only impacts all versions of Node.js 4.x. The regular expression, `splitPathRe`, used within the `'path'` module for the various path parsing functions, including `path.dirname()`, `path.extname()` and `path.parse()` was structured in such a way as to allow an attacker to craft a string, that when passed through one of these functions, could take a significant amount of time to evaluate, potentially leading to a full denial of service.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "47": { + "cve": [ + "CVE-2018-7159" + ], + "vulnerable": "4.x || 6.x || 8.x || 9.x", + "patched": "^4.9.0 || ^6.14.0 || ^8.11.0 || ^9.10.0", + "ref": "https://nodejs.org/en/blog/vulnerability/march-2018-security-releases/", + "overview": "The HTTP parser in all current versions of Node.js ignores spaces in the `Content-Length` header, allowing input such as `Content-Length: 1 2` to be interpreted as having a value of `12`. The HTTP specification does not allow for spaces in the `Content-Length` value and the Node.js HTTP parser has been brought into line on this particular difference. The security risk of this flaw to Node.js users is considered to be VERY LOW as it is difficult, and may be impossible, to craft an attack that makes use of this flaw in a way that could not already be achieved by supplying an incorrect value for `Content-Length`. Vulnerabilities may exist in user-code that make incorrect assumptions about the potential accuracy of this value compared to the actual length of the data supplied. Node.js users crafting lower-level HTTP utilities are advised to re-check the length of any input supplied after parsing is complete.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "48": { + "cve": [ + "CVE-2018-7160" + ], + "vulnerable": "6.x || 8.x || 9.x", + "patched": "^6.14.0 || ^8.11.0 || ^9.10.0", + "ref": "https://nodejs.org/en/blog/vulnerability/march-2018-security-releases/", + "overview": "The Node.js inspector, in 6.x and later is vulnerable to a DNS rebinding attack which could be exploited to perform remote code execution. An attack is possible from malicious websites open in a web browser on the same computer, or another computer with network access to the computer running the Node.js process. A malicious website could use a DNS rebinding attack to trick the web browser to bypass same-origin-policy checks and to allow HTTP connections to localhost or to hosts on the local network. If a Node.js process with the debug port active is running on localhost or on a host on the local network, the malicious website could connect to it as a debugger, and get full code execution access.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "49": { + "cve": [ + "CVE-2018-7161" + ], + "vulnerable": "8.x || 9.x || 10.x", + "patched": "^8.11.3 || ^9.11.2 || ^10.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2018-security-releases/", + "overview": "All versions of 8.x and later are vulnerable and the severity is HIGH. An attacker can cause a denial of service (DoS) by causing a node server providing an http2 server to crash. This can be accomplished by interacting with the http2 server in a manner that triggers a cleanup bug where objects are used in native code after they are no longer available. This has been addressed by updating the http2 implementation. Thanks to Jordan Zebor at F5 Networks for reporting this issue.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "50": { + "cve": [ + "CVE-2018-7162" + ], + "vulnerable": "9.x || 10.x", + "patched": "^9.11.2 || ^10.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2018-security-releases/", + "overview": "All versions of 9.x and later are vulnerable and the severity is HIGH. An attacker can cause a denial of service (DoS) by causing a node process which provides an http server supporting TLS server to crash. This can be accomplished by sending duplicate/unexpected messages during the handshake. This vulnerability has been addressed by updating the TLS implementation. Thanks to Jordan Zebor at F5 Networks all of his help investigating this issue with the Node.js team.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "51": { + "cve": [ + "CVE-2018-7164" + ], + "vulnerable": "9.7.x || 10.x", + "patched": "^9.11.2 || ^10.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2018-security-releases/", + "overview": "Versions 9.7.0 and later are vulnerable and the severity is MEDIUM. A bug introduced in 9.7.0 increases the memory consumed when reading from the network into JavaScript using the net.Socket object directly as a stream. An attacker could use this cause a denial of service by sending tiny chunks of data in short succession. This vulnerability was restored by reverting to the prior behaviour.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "52": { + "cve": [ + "CVE-2018-7167" + ], + "vulnerable": "6.x || 8.x || 9.x", + "patched": "^6.14.3 || ^8.11.3 || ^9.11.2", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2018-security-releases/", + "overview": "Calling Buffer.fill() or Buffer.alloc() with some parameters can lead to a hang which could result in a Denial of Service.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "53": { + "cve": [ + "CVE-2018-7166" + ], + "vulnerable": "10.x", + "patched": ">= 10.9.0", + "publish_date": "2018-08-16", + "author": "Сковорода Никита Андреевич (Nikita Skovoroda / @ChALkeR)", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2018-security-releases/", + "type": "CWE-226: Sensitive Information Uncleared Before Release", + "overview": "An argument processing flaw can cause `Buffer.alloc()` to return uninitialized memory. This method is intended to be safe and only return initialized, or cleared, memory. The third argument specifying `encoding` can be passed as a number, this is misinterpreted by `Buffer's` internal \"fill\" method as the `start` to a fill operation. This flaw may be abused where `Buffer.alloc()` arguments are derived from user input to return uncleared memory blocks that may contain sensitive information.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "54": { + "cve": [ + "CVE-2018-12115" + ], + "vulnerable": "<= 10", + "patched": "^6.14.4 || ^8.11.4 || >= 10.9.0", + "publish_date": "2018-08-16", + "author": "Сковорода Никита Андреевич (Nikita Skovoroda / @ChALkeR)", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2018-security-releases/", + "type": "CWE-787: Out-of-bounds Write", + "overview": "When used with UCS-2 encoding (recognized by Node.js under the names `'ucs2'`, `'ucs-2'`, `'utf16le'` and `'utf-16le'`), `Buffer#write()` can be abused to write outside of the bounds of a single `Buffer`. Writes that start from the second-to-last position of a buffer cause a miscalculation of the maximum length of the input bytes to be written.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "55": { + "cve": [ + "CVE-2018-12116" + ], + "vulnerable": "6.x || 8.x", + "patched": "^6.15.0 || ^8.14.0", + "publish_date": "2018-11-27", + "author": "Matteo Collina", + "reported_by": "Arkadiy Tetelman", + "ref": "https://nodejs.org/en/blog/vulnerability/november-2018-security-releases/", + "type": "CWE-115: Misinterpretation of Input", + "overview": "HTTP request splitting: If Node.js can be convinced to use unsanitized user-provided Unicode data for the `path` option of an HTTP request, then data can be provided which will trigger a second, unexpected, and user-defined HTTP request to made to the same server.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "56": { + "cve": [ + "CVE-2018-12120" + ], + "vulnerable": "6.x || 8.x", + "patched": "^6.15.0 || ^8.14.0", + "publish_date": "2018-11-27", + "author": "Ben Noordhuis", + "reported_by": "Ben Noordhuis", + "ref": "https://nodejs.org/en/blog/vulnerability/november-2018-security-releases/", + "type": "CWE-419: Unprotected Primary Channel", + "overview": "Debugger port 5858 listens on any interface by default: When the debugger is enabled with `node --debug` or `node debug`, it listens to port 5858 on all interfaces by default. This may allow remote computers to attach to the debug port and evaluate arbitrary JavaScript. The default interface is now localhost. It has always been possible to start the debugger on a specific interface, such as `node --debug=localhost`. The debugger was removed in Node.js 8 and replaced with the inspector, so no versions from 8 and later are vulnerable.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "57": { + "cve": [ + "CVE-2018-12121" + ], + "vulnerable": "6.x || 8.x || 10.x || 11.x", + "patched": "^6.15.0 || ^8.14.0 || ^10.14.0 || ^11.3.0", + "publish_date": "2018-11-27", + "author": "Matteo Collina", + "reported_by": "Trevor Norris", + "ref": "https://nodejs.org/en/blog/vulnerability/november-2018-security-releases/", + "type": "CWE-400: Uncontrolled Resource Consumption / Denial of Service", + "overview": "Denial of Service with large HTTP headers: By using a combination of many requests with maximum sized headers (almost 80 KB per connection), and carefully timed completion of the headers, it is possible to cause the HTTP server to abort from heap allocation failure. Attack potential is mitigated by the use of a load balancer or other proxy layer.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "58": { + "cve": [ + "CVE-2018-12122" + ], + "vulnerable": "6.x || 8.x || 10.x || 11.x", + "patched": "^6.15.0 || ^8.14.0 || ^10.14.0 || ^11.3.0", + "publish_date": "2018-11-27", + "author": "Matteo Collina", + "reported_by": "Jan Maybach", + "ref": "https://nodejs.org/en/blog/vulnerability/november-2018-security-releases/", + "type": "CWE-400: Uncontrolled Resource Consumption / Denial of Service", + "overview": "Slowloris HTTP Denial of Service: An attacker can cause a Denial of Service (DoS) by sending headers very slowly keeping HTTP or HTTPS connections and associated resources alive for a long period of time.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "59": { + "cve": [ + "CVE-2018-12123" + ], + "vulnerable": "6.x || 8.x || 10.x || 11.x", + "patched": "^6.15.0 || ^8.14.0 || ^10.14.0 || ^11.3.0", + "publish_date": "2018-11-27", + "author": "Matteo Collina", + "reported_by": "Martin Bajanik", + "ref": "https://nodejs.org/en/blog/vulnerability/november-2018-security-releases/", + "type": "CWE-115: Misinterpretation of Input", + "overview": "Hostname spoofing in URL parser for javascript protocol: If a Node.js application is using url.parse() to determine the URL hostname, that hostname can be spoofed by using a mixed case \"javascript:\" (e.g. \"javAscript:\") protocol (other protocols are not affected). If security decisions are made about the URL based on the hostname, they may be incorrect.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "60": { + "cve": [ + "CVE-2019-5737" + ], + "vulnerable": "6.x || 8.x || 10.x || 11.x", + "patched": "^6.17.0 || ^8.15.1 || ^10.15.2 || ^11.10.1", + "publish_date": "2019-02-28", + "author": "Matteo Collina", + "reported_by": "Marco Pracucci", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2019-security-releases/", + "type": "CWE-400: Uncontrolled Resource Consumption / Denial of Service", + "overview": "An attacker can cause a Denial of Service (DoS) by establishing an HTTP or HTTPS connection in keep-alive mode and by sending headers very slowly thereby keeping the connection and associated resources alive for a long period of time. Attack potential is mitigated by the use of a load balancer or other proxy layer. This vulnerability is an extension of CVE-2018-12121, addressed in November and impacts all active release lines including 6, 8, 10 and 11.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "61": { + "cve": [ + "CVE-2019-5739" + ], + "vulnerable": "6.x", + "patched": "^6.17.0", + "publish_date": "2019-02-28", + "author": "Matteo Collina", + "reported_by": "Timur Shemsedinov", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2019-security-releases/", + "type": "CWE-400: Uncontrolled Resource Consumption / Denial of Service", + "overview": "Keep-alive HTTP and HTTPS connections can remain open and inactive for up to 2 minutes in Node.js 6.16.0 and earlier. Node.js 8.0.0 introduced a dedicated server.keepAliveTimeout which defaults to 5 seconds. The behavior in Node.js 6.16.0 and earlier is a potential Denial of Service (DoS) attack vector. Node.js 6.17.0 introduces server.keepAliveTimeout and the 5-second default.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "62": { + "cve": [ + "CVE-2019-9511", + "CVE-2019-9512", + "CVE-2019-9513", + "CVE-2019-9514", + "CVE-2019-9515", + "CVE-2019-9516", + "CVE-2019-9517", + "CVE-2019-9518" + ], + "vulnerable": "8.x || 10.x || 12.x", + "patched": "^8.16.1 || ^10.16.3 || ^12.8.1", + "publish_date": "2019-08-15", + "author": "Sam Roberts", + "reported_by": "Jonathan Looney, Piotr Sikora", + "ref": "https://nodejs.org/en/blog/vulnerability/aug-2019-security-releases/", + "type": "CWE-400: Uncontrolled Resource Consumption / Denial of Service", + "overview": "Netflix has discovered several resource exhaustion vectors affecting a variety of third-party HTTP/2 implementations. These attack vectors can be used to launch DoS attacks against servers that support HTTP/2 communication. Netflix worked with Google and CERT/CC to coordinate disclosure to the Internet community.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "63": { + "cve": [ + "CVE-2019-15604" + ], + "vulnerable": "10.x || 12.x || 13.x", + "patched": "^10.19.0 || ^12.15.0 || ^13.8.0", + "reported_by": "Rogier Schouten", + "ref": "https://hackerone.com/reports/746733", + "overview": "Remotely trigger an assertion on a TLS server with a malformed certificate string", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "64": { + "cve": [ + "CVE-2019-15605" + ], + "vulnerable": "10.x || 12.x || 13.x", + "patched": "^10.19.0 || ^12.15.0 || ^13.8.0", + "reported_by": "Ethan Rubinson", + "ref": "https://hackerone.com/reports/735748", + "overview": "HTTP request smuggling using malformed Transfer-Encoding header", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "65": { + "cve": [ + "CVE-2019-15606" + ], + "vulnerable": "10.x || 12.x || 13.x", + "patched": "^10.19.0 || ^12.15.0 || ^13.8.0", + "reported_by": "Alyssa Wilk", + "ref": "https://hackerone.com/reports/730779", + "overview": "HTTP header values do not have trailing OWS trimmed", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "66": { + "cve": [ + "CVE-2020-8201" + ], + "vulnerable": "12.x || 14.x", + "patched": "^12.18.4 || ^14.11.0", + "reported_by": "Amit Klein", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2020-security-releases/", + "overview": "HTTP Request Smuggling due to CR-to-Hyphen conversion", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "67": { + "cve": [ + "CVE-2020-8251" + ], + "vulnerable": "14.x", + "patched": "^14.11.0", + "reported_by": "Paolo Insogna and Matteo Collina", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2020-security-releases/", + "overview": "Denial of Service by resource exhaustion CWE-400 due to unfinished HTTP/1.1 requests", + "affectedEnvironments": [ + "all" + ], + "severity": "critical" + }, + "68": { + "cve": [ + "CVE-2020-8252" + ], + "vulnerable": "10.x || 12.x || 14.x", + "patched": "^10.22.1 || ^12.18.4 || ^14.9.0", + "reported_by": "Xiaoyi Shi", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2020-security-releases/", + "overview": "fs.realpath.native on may cause buffer overflow", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "69": { + "cve": [ + "CVE-2020-8277" + ], + "vulnerable": " 12.x || 14.x || 15.x", + "patched": " ^12.19.1 || ^14.15.1 || 15.2.1", + "ref": "https://nodejs.org/en/blog/vulnerability/november-2020-security-releases/", + "overview": "Denial of Service through DNS request", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "70": { + "cve": [ + "CVE-2020-8265" + ], + "vulnerable": "10.x || 12.x || 14.x || 15.x", + "patched": "^10.23.1 || ^12.20.1 || ^14.15.4 || ^15.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/january-2021-security-releases/", + "overview": "use-after-free in TLSWrap - affected Node.js versions are vulnerable to a use-after-free bug in its TLS implementation. When writing to a TLS enabled socket, node::StreamBase::Write calls node::TLSWrap::DoWrite with a freshly allocated WriteWrap object as first argument. If the DoWrite method does not return an error, this object is passed back to the caller as part of a StreamWriteResult structure. This may be exploited to corrupt memory leading to a Denial of Service or potentially other exploits.", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "71": { + "cve": [ + "CVE-2020-8287" + ], + "vulnerable": "10.x || 12.x || 14.x || 15.x", + "patched": "^10.23.1 || ^12.20.1 || ^14.15.4 || ^15.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/january-2021-security-releases/", + "overview": "HTTP Request Smuggling in nodejs - Affected versions of Node.js allow two copies of a header field in a http request. For example, two Transfer-Encoding header fields. In this case Node.js identifies the first header field and ignores the second. This can lead to HTTP Request Smuggling (https://cwe.mitre.org/data/definitions/444.html)", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "72": { + "cve": [ + "CVE-2020-1971" + ], + "vulnerable": "10.x || 12.x || 14.x || 15.x", + "patched": "^10.23.1 || ^12.20.1 || ^14.15.4 || ^15.5.0", + "ref": "https://nodejs.org/en/blog/vulnerability/january-2021-security-releases/", + "overview": "OpenSSL - EDIPARTYNAME NULL pointer de-reference - This is a vulnerability in OpenSSL which may be exploited through Node.js. You can read more about it in https://www.openssl.org/news/secadv/20201208.txt", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "73": { + "cve": [ + "CVE-2021-22883" + ], + "vulnerable": " 10.x || 12.x || 14.x || 15.x", + "patched": " ^10.24.0 || ^12.21.0 || ^14.16.0 || ^15.10.0", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2021-security-releases/", + "overview": "HTTP2 'unknownProtocol' cause Denial of Service by resource exhaustion - Affected Node.js versions are vulnerable to denial of service attacks when too many connection attempts with an 'unknownProtocol' are established. This leads to a leak of file descriptors. If a file descriptor limit is configured on the system, then the server is unable to accept new connections and prevent the process also from opening, e.g. a file. If no file descriptor limit is configured, then this lead to an excessive memory usage and cause the system to run out of memory.", + "affectedEnvironments": [ + "all" + ], + "severity": "critical" + }, + "74": { + "cve": [ + "CVE-2021-22884" + ], + "vulnerable": " 10.x || 12.x || 14.x || 15.x", + "patched": " ^10.24.0 || ^12.21.0 || ^14.16.0 || ^15.10.0", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2021-security-releases/", + "overview": "DNS rebinding in --inspect - Affected Node.js versions are vulnerable to denial of service attacks when the whitelist includes “localhost6”. When “localhost6” is not present in /etc/hosts, it is just an ordinary domain that is resolved via DNS, i.e., over network. If the attacker controls the victim's DNS server or can spoof its responses, the DNS rebinding protection can be bypassed by using the “localhost6” domain. As long as the attacker uses the “localhost6” domain, they can still apply the attack described in CVE-2018-7160.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "75": { + "cve": [ + "CVE-2021-23840" + ], + "vulnerable": " 10.x || 12.x || 14.x || 15.x", + "patched": " ^10.24.0 || ^12.21.0 || ^14.16.0 || ^15.10.0", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2021-security-releases/", + "overview": "OpenSSL - Integer overflow in CipherUpdate - This is a vulnerability in OpenSSL which may be exploited through Node.js. You can read more about it in https://www.openssl.org/news/secadv/20210216.txt", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "76": { + "cve": [ + "CVE-2021-3450" + ], + "vulnerable": " 10.x || 12.x || 14.x || 15.x", + "patched": " ^10.24.1 || ^12.22.1 || ^14.16.1 || ^15.14.0", + "ref": "https://nodejs.org/en/blog/vulnerability/april-2021-security-releases/", + "overview": "This is a vulnerability in OpenSSL which may be exploited through Node.js. You can read more about it in https://www.openssl.org/news/secadv/20210325.txt", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "77": { + "cve": [ + "CVE-2021-3449" + ], + "vulnerable": " 10.x || 12.x || 14.x || 15.x", + "patched": " ^10.24.1 || ^12.22.1 || ^14.16.1 || ^15.14.0", + "ref": "https://nodejs.org/en/blog/vulnerability/april-2021-security-releases/", + "overview": "This is a vulnerability in OpenSSL which may be exploited through Node.js. You can read more about it in https://www.openssl.org/news/secadv/20210325.txt", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "78": { + "cve": [ + "CVE-2020-7774" + ], + "vulnerable": " 10.x || 12.x || 14.x", + "patched": " ^10.24.1 || ^12.22.1 || ^14.16.1", + "ref": "https://nodejs.org/en/blog/vulnerability/april-2021-security-releases/", + "overview": "This is a vulnerability in the y18n npm module which may be exploited by prototype pollution. You can read more about it in https://github.com/advisories/GHSA-c4w7-xm78-47vh", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "79": { + "cve": [ + "CVE-2021-22930" + ], + "vulnerable": " 12.x || 14.x || 16.x", + "patched": " ^12.22.4 || ^14.17.4 || ^16.6.0", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2021-security-releases-2/", + "overview": "Node.js before is vulnerable to a use after free attack where an attacker might be able to exploit the memory corruption, to change process behavior. You can read more about it in https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-22930", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "80": { + "cve": [ + "CVE-2021-22921" + ], + "vulnerable": " 12.x || 14.x || 16.x", + "patched": " ^12.22.2 || ^14.17.2 || ^16.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2021-security-releases/", + "overview": "Node.js is vulnerable to local privilege escalation attacks under certain conditions on Windows platforms. More specifically, improper configuration of permissions in the installation directory allows an attacker to perform two different escalation attacks: PATH and DLL hijacking. You can read more about it in https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-22921", + "affectedEnvironments": [ + "win32" + ], + "severity": "medium" + }, + "81": { + "cve": [ + "CVE-2021-27290" + ], + "vulnerable": " 12.x", + "patched": " ^12.22.2", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2021-security-releases/", + "overview": "This is a vulnerability in the ssri npm module which may be vulnerable to denial of service attacks. You can read more about it in https://github.com/advisories/GHSA-vx3p-948g-6vhq", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "82": { + "cve": [ + "CVE-2021-23362" + ], + "vulnerable": " 12.x", + "patched": " ^12.22.2", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2021-security-releases/", + "overview": "This is a vulnerability in the hosted-git-info npm module which may be vulnerable to denial of service attacks. You can read more about it in https://nvd.nist.gov/vuln/detail/CVE-2021-23362", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "83": { + "cve": [ + "CVE-2021-22918" + ], + "vulnerable": " 12.x || 14.x || 16.x", + "patched": " ^12.22.2 || ^14.17.2 || ^16.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2021-security-releases/", + "overview": "Node.js is vulnerable to out-of-bounds read in libuv's uv__idna_toascii() function which is used to convert strings to ASCII. This is called by Node's dns module's lookup() function and can lead to information disclosures or crashes. You can read more about it in https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-22918", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "84": { + "cve": [ + "CVE-2021-22931" + ], + "vulnerable": "12.x || 14.x || 16.x", + "patched": "^12.22.5 || ^14.17.5 || ^16.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/aug-2021-security-releases/", + "overview": "Node.js was vulnerable to Remote Code Execution, XSS, application crashes due to missing input validation of host names returned by Domain Name Servers in the Node.js DNS library which can lead to output of wrong hostnames (leading to Domain Hijacking) and injection vulnerabilities in applications using the library. You can read more about it in: https://nvd.nist.gov/vuln/detail/CVE-2021-22931", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "85": { + "cve": [ + "CVE-2021-22940" + ], + "vulnerable": "12.x || 14.x || 16.x", + "patched": "^12.22.5 || ^14.17.5 || ^16.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/aug-2021-security-releases/", + "overview": "Node.js was vulnerable to a use after free attack where an attacker might be able to exploit memory corruption to change process behavior. The issue is a follow on to CVE-2021-22930 as the issue was not completely resolved in the fix for CVE-2021-22930. You can read more about it in: https://nvd.nist.gov/vuln/detail/CVE-2021-22940", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "86": { + "cve": [ + "CVE-2021-22939" + ], + "vulnerable": "12.x || 14.x || 16.x", + "patched": "^12.22.5 || ^14.17.5 || ^16.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/aug-2021-security-releases/", + "overview": "If the Node.js https API was used incorrectly and \"undefined\" was in passed for the \"rejectUnauthorized\" parameter, no error was returned and connections to servers with an expired certificate would have been accepted. You can read more about it in: https://nvd.nist.gov/vuln/detail/CVE-2021-22939", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "87": { + "cve": [ + "CVE-2021-37701", + "CVE-2021-37712", + "CVE-2021-37713", + "CVE-2021-39134", + "CVE-2021-39135" + ], + "vulnerable": " 12.x || 14.x", + "patched": " ^12.22.6 || ^14.17.6", + "ref": "https://nodejs.org/en/blog/vulnerability/aug-2021-security-releases2/", + "overview": "npm 6 update - node-tar, aborist, npm client modules. These are vulnerabilities in the node-tar, arborist, and npm cli modules which are related to the initial reports and subsequent remediation of node-tar vulnerabilities CVE-2021-32803 and CVE-2021-32804. Subsequent internal security review of node-tar and additional external bounty reports have resulted in another 5 CVE being remediated in core npm CLI dependencies including node-tar, and npm arborist. You can read more about it in: https://github.com/npm/node-tar/security/advisories/GHSA-9r2w-394v-53qc, https://github.com/npm/node-tar/security/advisories/GHSA-qq89-hq3f-393p, https://github.com/npm/node-tar/security/advisories/GHSA-5955-9wpr-37jh, https://github.com/npm/arborist/security/advisories/GHSA-2h3h-q99f-3fhc), https://github.com/npm/arborist/security/advisories/GHSA-gmw6-94gg-2rc2", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "88": { + "cve": [ + "CVE-2021-22959", + "CVE-2021-22960" + ], + "vulnerable": "12.x || 14.x || 16.x", + "patched": " ^12.22.7 || ^14.18.1 || ^16.11.1", + "ref": "https://nodejs.org/en/blog/vulnerability/oct-2021-security-releases/", + "overview": "The http parser accepts requests with a space (SP) right after the header name before the colon. The http parser ignores chunk extensions when parsing the body of chunked requests. These can lead to HTTP Request Smuggling (HRS). See https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-22959 and https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-22960 for more details.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "89": { + "cve": [ + "CVE-2021-44531" + ], + "vulnerable": "12.x || 14.x || 16.x || 17.x", + "patched": "^12.22.9 || ^14.18.3 || ^16.13.2 || ^17.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/jan-2022-security-releases/", + "overview": "Accepting arbitrary Subject Alternative Name (SAN) types, unless a PKI is specifically defined to use a particular SAN type, can result in bypassing name-constrained intermediates. Node.js was accepting URI SAN types, which PKIs are often not defined to use. Additionally, when a protocol allows URI SANs, Node.js did not match the URI correctly. See https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-44531 for more details.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "90": { + "cve": [ + "CVE-2021-44532" + ], + "vulnerable": "12.x || 14.x || 16.x || 17.x", + "patched": "^12.22.9 || ^14.18.3 || ^16.13.2 || ^17.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/jan-2022-security-releases/", + "overview": "Node.js converts SANs (Subject Alternative Names) to a string format. It uses this string to check peer certificates against hostnames when validating connections. The string format was subject to an injection vulnerability when name constraints were used within a certificate chain, allowing the bypass of these name constraints. See https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-44532 for more details.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "91": { + "cve": [ + "CVE-2021-44533" + ], + "vulnerable": "12.x || 14.x || 16.x || 17.x", + "patched": "^12.22.9 || ^14.18.3 || ^16.13.2 || ^17.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/jan-2022-security-releases/", + "overview": "Node.js did not handle multi-value Relative Distinguished Names correctly. Attackers could craft certificate subjects containing a single-value Relative Distinguished Name that would be interpreted as a multi-value Relative Distinguished Name, for example, in order to inject a Common Name that would allow bypassing the certificate subject verification. See https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-44533 for more details.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "92": { + "cve": [ + "CVE-2022-21824" + ], + "vulnerable": "12.x || 14.x || 16.x || 17.x", + "patched": "^12.22.9 || ^14.18.3 || ^16.13.2 || ^17.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/jan-2022-security-releases/", + "overview": "Due to the formatting logic of the console.table() function it was not safe to allow user controlled input to be passed to the properties parameter while simultaneously passing a plain object with at least one property as the first parameter, which could be __proto__. The prototype pollution has very limited control, in that it only allows an empty string to be assigned to numerical keys of the object prototype. See https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-21824 for more details.", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "93": { + "cve": [ + "CVE-2022-0778" + ], + "vulnerable": "12.x || 14.x || 16.x || 17.x", + "patched": "^12.22.11 || ^14.19.1 || ^16.14.2 || ^17.7.2", + "ref": "https://nodejs.org/en/blog/vulnerability/mar-2022-security-releases/", + "overview": "This is a vulnerability in OpenSSL: Infinite loop in BN_mod_sqrt() reachable when parsing certificates. More details are available at https://www.openssl.org/news/secadv/20220315.txt.", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "94": { + "cve": [ + "CVE-2022-32215" + ], + "vulnerable": "14.x || 16.x || 18.x", + "patched": "^14.20.1 || ^16.17.1 || ^18.9.1", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2022-security-releases/", + "overview": "The llhttp parser in the http module in Node does not correctly handle multi-line Transfer-Encoding headers. This can lead to HTTP Request Smuggling (HRS).", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "95": { + "cve": [ + "CVE-2022-32214" + ], + "vulnerable": "14.x || 16.x || 18.x", + "patched": "^14.20.0 || ^16.20.0 || ^18.5.0", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2022-security-releases/", + "overview": "The llhttp parser in the http module in Node.js does not strictly use the CRLF sequence to delimit HTTP requests. This can lead to HTTP Request Smuggling (HRS).", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "96": { + "cve": [ + "CVE-2022-32212" + ], + "vulnerable": "14.x || 16.x || 18.x", + "patched": "^14.20.1 || ^16.17.1 || ^18.9.1", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2022-security-releases/", + "overview": "The IsAllowedHost check in https://github.com/nodejs/node/blob/fdf0a84e826d3a9ec0ce6f5a3f5adc967fe99408/src/inspector_socket.cc#L580 can easily be bypassed because IsIPAddress does not properly check if an IP address is invalid or not. When an invalid IPv4 address is provided (for instance 10.0.2.555 is provided), the browser will make a DNS requests to the DNS server, providing a vector for an attacker-controlled DNS server to perform a rebinding attack and hence access the JSON file containing the WebSocket file.\n The fix we introduced in https://hackerone.com/reports/1069487 was not complete.", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "97": { + "cve": [ + "CVE-2022-32213" + ], + "vulnerable": "14.x || 16.x || 18.x", + "patched": "^14.20.1 || ^16.17.1 || ^18.9.1", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2022-security-releases/", + "overview": "The llhttp parser in the http module in Node.js does not correctly parse and validate Transfer-Encoding headers. This can lead to HTTP Request Smuggling (HRS).", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "98": { + "cve": [ + "CVE-2022-32223" + ], + "vulnerable": "14.x || 16.x || 18.x", + "patched": "^14.20.0 || ^16.20.0 || ^18.5.0", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2022-security-releases/", + "overview": "Node.js is vulnerable to Hijack Execution Flow: DLL Hijacking under certain conditions on Windows platforms.\nThis vulnerability can be exploited if the victim has the following dependencies on a Windows machine:\n* OpenSSL has been installed and “C:\\Program Files\\Common Files\\SSL\\openssl.cnf” exists.\n\nWhenever the above conditions are present, `node.exe` will search for `providers.dll` in the current user directory.\nAfter that, `node.exe` will try to search for `providers.dll` by the DLL Search Order in Windows.\n\nIt is possible for an attacker to place the malicious file `providers.dll` under a variety of paths and exploit this vulnerability.", + "affectedEnvironments": [ + "win32" + ], + "severity": "high" + }, + "99": { + "cve": [ + "CVE-2022-32222" + ], + "vulnerable": "14.x || 16.x || 18.x", + "patched": "^14.20.0 || ^16.20.0 || ^18.9.1", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2022-security-releases/", + "overview": "On linux, versions of 18.x prior to Y used a default path for openssl.cnf that was within a path that might be accessible under some circumstances to a non-admin user instead of /etc/ssl as was the case in versions prior to the upgrade to OpenSSL 3.", + "affectedEnvironments": [ + "linux" + ], + "severity": "medium" + }, + "100": { + "cve": [ + "CVE-2022-35256" + ], + "vulnerable": "14.x || 16.x || 18.x", + "patched": "^14.20.1 || ^16.17.1 || ^18.9.1", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2022-security-releases/", + "overview": "The llhttp parser in the http module in Node.js v18.7.0 does not correctly handle header fields that are not terminated with CLRF. This may result in HTTP Request Smuggling.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "101": { + "cve": [ + "CVE-2022-35255" + ], + "vulnerable": "18.x", + "patched": "^18.9.1", + "ref": "https://nodejs.org/en/blog/vulnerability/september-2022-security-releases/", + "overview": "Node.js made calls to EntropySource() in SecretKeyGenTraits::DoKeyGen() in src/crypto/crypto_keygen.cc. However, it does not check the return value, it assumes EntropySource() always succeeds, but it can (and sometimes will) fail.", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "102": { + "cve": [ + "CVE-2022-43548" + ], + "vulnerable": "14.x || 16.x || 18.x || 19.x", + "patched": "^14.21.1 || ^16.18.1 || ^18.12.1 || ^19.0.1", + "ref": "https://nodejs.org/en/blog/vulnerability/november-2022-security-releases/", + "overview": "The Node.js rebinding protector for --inspect still allows invalid IP address, specifically, the octal format.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "103": { + "cve": [ + "CVE-2023-23918" + ], + "vulnerable": "14.x || 16.x || 18.x || 19.x", + "patched": "^14.21.3 || ^16.19.1 || ^18.14.1 || ^19.6.1", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2023-security-releases/", + "overview": "It was possible to bypass Permissions and access non authorized modules by using process.mainModule.require(). This only affects users who had enabled the experimental permissions option with --experimental-policy.", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "104": { + "cve": [ + "CVE-2023-23919" + ], + "vulnerable": "14.x || 16.x || 18.x || 19.x", + "patched": "^14.21.3 || ^16.19.1 || ^18.14.1 || ^19.2.0", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2023-security-releases/", + "overview": "In some cases Node.js did does not clear the OpenSSL error stack after operations that may set it. This may lead to false positive errors during subsequent cryptographic operations that happen to be on the same thread. This in turn could be used to cause a denial of service.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "105": { + "cve": [ + "CVE-2023-23936" + ], + "vulnerable": "14.x || 16.x || 18.x || 19.x", + "patched": "^14.21.3 || ^16.19.1 || ^18.14.1 || ^19.6.1", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2023-security-releases/", + "overview": "The fetch API in Node.js did not prevent CRLF injection in the 'host' header potentially allowing attacks such as HTTP response splitting and HTTP header injection.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "106": { + "cve": [ + "CVE-2023-24807" + ], + "vulnerable": "14.x || 16.x || 18.x || 19.x", + "patched": "^14.21.3 || ^16.19.1 || ^18.14.1 || ^19.6.1", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2023-security-releases/", + "overview": "The Headers.set() and Headers.append() methods in the fetch API in Node.js where vulnerable to Regular a Expression Denial of Service (ReDoS) attacks.", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "107": { + "cve": [ + "CVE-2023-23920" + ], + "vulnerable": "14.x || 16.x || 18.x || 19.x", + "patched": "^14.21.3 || ^16.19.1 || ^18.14.1 || ^19.6.1", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2023-security-releases/", + "overview": "Node.js would search and potentially load ICU data when running with elevated priviledges. Node.js was modified to build with ICU_NO_USER_DATA_OVERRIDE to avoid this.", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "108": { + "cve": [ + "CVE-2023-30581" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.1 || ^18.16.1 || ^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "The use of proto in process.mainModule.proto.require() can bypass the policy mechanism and require modules outside of the policy.json definition", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "109": { + "cve": [ + "CVE-2023-30582" + ], + "vulnerable": "20.x", + "patched": "^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "A vulnerability has been identified in Node.js version 20, affecting users of the experimental permission model when the --allow-fs-read flag is used with a non-* argument.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "110": { + "cve": [ + "CVE-2023-30583" + ], + "vulnerable": "20.x", + "patched": "^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "fs.openAsBlob() can bypass the experimental permission model when using the file system read restriction with the --allow-fs-read flag in Node.js 20", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "111": { + "cve": [ + "CVE-2023-30584" + ], + "vulnerable": "20.x", + "patched": "^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "A vulnerability has been discovered in Node.js version 20, specifically within the experimental permission model. This flaw relates to improper handling of path traversal bypass when verifying file permissions.", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "112": { + "cve": [ + "CVE-2023-30585" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.1 || ^18.16.1 || ^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "Privilege escalation via Malicious Registry Key manipulation during Node.js installer repair process", + "affectedEnvironments": [ + "win32" + ], + "severity": "medium" + }, + "113": { + "cve": [ + "CVE-2023-30586" + ], + "vulnerable": "20.x", + "patched": "^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "Node.js 20 allows loading arbitrary OpenSSL engines when the experimental permission model is enabled, which can bypass and/or disable the permission model.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "114": { + "cve": [ + "CVE-2023-30587" + ], + "vulnerable": "20.x", + "patched": "^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "A vulnerability in Node.js version 20 allows for bypassing restrictions set by the --experimental-permission flag using the built-in inspector module (node:inspector).", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "115": { + "cve": [ + "CVE-2023-30589" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.1 || ^18.16.1 || ^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "The llhttp parser in the http module in Node.js does not strictly use the CRLF sequence to delimit HTTP requests.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "116": { + "cve": [ + "CVE-2023-30588" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.1 || ^18.16.1 || ^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "When an invalid public key is used to create an x509 certificate using the crypto.X509Certificate() API a non-expect termination occurs.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "117": { + "cve": [ + "CVE-2023-30590" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.1 || ^18.16.1 || ^20.3.1", + "ref": "https://nodejs.org/en/blog/vulnerability/june-2023-security-releases/", + "overview": "The generateKeys() API function returned from crypto.createDiffieHellman() only generates missing (or outdated) keys, that is, it only generates a private key if none has been set yet.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "118": { + "cve": [ + "CVE-2023-32002" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.2 || ^18.17.1 || ^20.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2023-security-releases/", + "overview": "The use of Module._load() can bypass the policy mechanism and require modules outside of the policy.json definition for a given module.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "119": { + "cve": [ + "CVE-2023-32004" + ], + "vulnerable": "20.x", + "patched": "^20.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2023-security-releases/", + "overview": "Improper handling of Buffers in file system APIs causing a traversal path to bypass when verifying file permissions.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "120": { + "cve": [ + "CVE-2023-32558" + ], + "vulnerable": "20.x", + "patched": "^20.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2023-security-releases/", + "overview": "The use of the deprecated API process.binding() can bypass the permission model through path traversal.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "121": { + "cve": [ + "CVE-2023-32006" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.2 || ^18.17.1 || ^20.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2023-security-releases/", + "overview": "The use of module.constructor.createRequire() can bypass the policy mechanism and require modules outside of the policy.json definition for a given module.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "122": { + "cve": [ + "CVE-2023-32559" + ], + "vulnerable": "16.x || 18.x || 20.x", + "patched": "^16.20.2 || ^18.17.1 || ^20.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2023-security-releases/", + "overview": "The use of the deprecated API process.binding() can bypass the policy mechanism by requiring internal modules and eventually take advantage of process.binding('spawn_sync') run arbitrary code, outside of the limits defined in a policy.json file.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "123": { + "cve": [ + "CVE-2023-32005" + ], + "vulnerable": "20.x", + "patched": "^20.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2023-security-releases/", + "overview": "A vulnerability has been identified in Node.js version 20, affecting users of the experimental permission model when the --allow-fs-read flag is used with a non-* argument.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "124": { + "cve": [ + "CVE-2023-32003" + ], + "vulnerable": "20.x", + "patched": "^20.5.1", + "ref": "https://nodejs.org/en/blog/vulnerability/august-2023-security-releases/", + "overview": "fs.mkdtemp() and fs.mkdtempSync() can be used to bypass the permission model check using a path traversal attack.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "125": { + "cve": [ + "CVE-2023-45143" + ], + "vulnerable": "18.x || 20.x", + "patched": "^18.18.2 || ^20.8.1", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2023-security-releases/", + "overview": "Cookie headers are not cleared in cross-domain redirect in undici-fetch (High)", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "126": { + "cve": [ + "CVE-2023-44487" + ], + "vulnerable": "18.x || 20.x", + "patched": "^18.18.2 || ^20.8.1", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2023-security-releases/", + "overview": "Rapidly creating and cancelling streams (HEADERS frame immediately followed by RST_STREAM) without bound causes denial of service (High)", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "127": { + "cve": [ + "CVE-2023-39331" + ], + "vulnerable": "20.x", + "patched": "^20.8.1", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2023-security-releases/", + "overview": "A previously disclosed vulnerability (CVE-2023-30584) was patched insufficiently. The implementation does not protect itself against the application overwriting built-in utility functions with user-defined implementations (High)", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "128": { + "cve": [ + "CVE-2023-39332" + ], + "vulnerable": "20.x", + "patched": "^20.8.1", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2023-security-releases/", + "overview": "Path traversal through path stored in Uint8Array (High)", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "129": { + "cve": [ + "CVE-2023-38552" + ], + "vulnerable": "18.x || 20.x", + "patched": "^18.18.2 || ^20.8.1", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2023-security-releases/", + "overview": "Integrity checks according to experimental policies can be circumvented (Medium)", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "130": { + "cve": [ + "CVE-2023-39333" + ], + "vulnerable": "18.x || 20.x", + "patched": "^18.18.2 || ^20.8.1", + "ref": "https://nodejs.org/en/blog/vulnerability/october-2023-security-releases/", + "overview": "Code injection via WebAssembly export names (Low)", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "131": { + "cve": [ + "CVE-2023-46809" + ], + "vulnerable": "18.x || 20.x || 21.x", + "patched": "^18.19.1 || ^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "A vulnerability in the privateDecrypt() API of the crypto library, allowed a covert timing side-channel during PKCS#1 v1.5 padding error handling.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "132": { + "cve": [ + "CVE-2024-21891" + ], + "vulnerable": "20.x || 21.x", + "patched": "^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "Node.js depends on multiple built-in utility functions to normalize paths provided to node:fs functions, which can be overwitten with user-defined implementations leading to filesystem permission model bypass through path traversal attack.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "133": { + "cve": [ + "CVE-2024-21890" + ], + "vulnerable": "20.x || 21.x", + "patched": "^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "Improper handling of wildcards in --allow-fs-read and --allow-fs-write", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "134": { + "cve": [ + "CVE-2024-21892" + ], + "vulnerable": "18.x || 20.x || 21.x", + "patched": "^18.19.1 || ^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "Code injection and privilege escalation through Linux capabilities", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "135": { + "cve": [ + "CVE-2024-22019" + ], + "vulnerable": "18.x || 20.x || 21.x", + "patched": "^18.19.1 || ^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "A vulnerability in Node.js HTTP servers allows an attacker to send a specially crafted HTTP request with chunked encoding, leading to resource exhaustion and denial of service (DoS).", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "136": { + "cve": [ + "CVE-2024-21896" + ], + "vulnerable": "20.x || 21.x", + "patched": "^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "The permission model protects itself against path traversal attacks by calling path.resolve() on any paths given by the user. If the path is to be treated as a Buffer, the implementation uses Buffer.from() to obtain a Buffer from the result of path.resolve().", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "137": { + "cve": [ + "CVE-2024-22017" + ], + "vulnerable": "20.x || 21.x", + "patched": "^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "setuid() does not affect libuv's internal io_uring operations if initialized before the call to setuid(). This allows the process to perform privileged operations despite presumably having dropped such privileges through a call to setuid()", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "138": { + "cve": [ + "CVE-2024-22025" + ], + "vulnerable": "18.x || 20.x || 21.x", + "patched": "^18.19.1 || ^20.11.1 || ^21.6.2", + "ref": "https://nodejs.org/en/blog/vulnerability/february-2024-security-releases/", + "overview": "A vulnerability in Node.js has been identified, allowing for a Denial of Service (DoS) attack through resource exhaustion when using the fetch() function to retrieve content from an untrusted URL.", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + }, + "139": { + "cve": [ + "CVE-2024-27983" + ], + "vulnerable": "18.x || 20.x || 21.x", + "patched": "^18.20.1 || ^20.12.1 || ^21.7.2", + "ref": "https://nodejs.org/en/blog/vulnerability/april-2024-security-releases/", + "overview": "An attacker can make the Node.js HTTP/2 server completely unavailable by sending a small amount of HTTP/2 frames packets with a few HTTP/2 frames inside. It is possible to leave some data in nghttp2 memory after reset when headers with HTTP/2 CONTINUATION frame are sent to the server and then a TCP connection is abruptly closed by the client triggering the Http2Session destructor while header frames are still being processed (and stored in memory) causing a race condition.", + "affectedEnvironments": [ + "all" + ], + "severity": "high" + }, + "140": { + "cve": [ + "CVE-2024-27982" + ], + "vulnerable": "18.x || 20.x || 21.x", + "patched": "^18.20.1 || ^20.12.1 || ^21.7.2", + "ref": "https://nodejs.org/en/blog/vulnerability/april-2024-security-releases/", + "overview": "The team has identified a critical vulnerability in the http server of the most recent version of Node, where malformed headers can lead to HTTP request smuggling. Specifically, if a space is placed before a content-length header, it is not interpreted correctly, enabling attackers to smuggle in a second request within the body of the first.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "141": { + "cve": [ + "CVE-2024-27982" + ], + "vulnerable": "18.x || 20.x || 21.x", + "patched": "^18.20.2 || ^20.12.2 || ^21.7.3", + "ref": "https://nodejs.org/en/blog/vulnerability/april-2024-security-releases-2/", + "overview": "Due to the improper handling of batch files in child_process.spawn / child_process.spawnSync, a malicious command line argument can inject arbitrary commands and achieve code execution even if the shell option is not enabled.", + "affectedEnvironments": [ + "win32" + ], + "severity": "medium" + }, + "142": { + "cve": [ + "CVE-2024-36137" + ], + "vulnerable": "20.x || 22.x", + "patched": "^20.15.1 || ^22.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2024-security-releases/", + "overview": "A vulnerability has been identified in Node.js, affecting users of the experimental permission model when the --allow-fs-write flag is used.\n\nNode.js Permission Model do not operate on file descriptors, however, operations such as `fs.fchown` or `fs.fchmod` can use a \"read-only\" file descriptor to change the owner and permissions of a file.\n\nThis vulnerability affects all users using the experimental permission model in Node.js 20 and Node.js 21.\n\nPlease note that at the time this CVE was issued, the permission model is an experimental feature of Node.js.", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "143": { + "cve": [ + "CVE-2024-36138" + ], + "vulnerable": "18.x || 20.x || 22.x", + "patched": "^18.20.4 || ^20.15.1 || ^22.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2024-security-releases/", + "overview": "The CVE-2024-27980 was identified as an incomplete fix for the BatBadBut vulnerability. This vulnerability arises from improper handling of batch files with all possible extensions on Windows via `child_process.spawn` / `child_process.spawnSync`. A malicious command line argument can inject arbitrary commands and achieve code execution even if the shell option is not enabled.\n\nThis vulnerability affects all users of `child_process.spawn` and `child_process.spawnSync` on Windows in all active release lines.", + "affectedEnvironments": [ + "win32" + ], + "severity": "high" + }, + "144": { + "cve": [ + "CVE-2024-22018" + ], + "vulnerable": "20.x || 22.x", + "patched": "^20.15.1 || ^22.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2024-security-releases/", + "overview": "A vulnerability has been identified in Node.js, affecting users of the experimental permission model when the --allow-fs-read flag is used.\nThis flaw arises from an inadequate permission model that fails to restrict file stats through the `fs.lstat` API. As a result, malicious actors can retrieve stats from files that they do not have explicit read access to.\n\nThis vulnerability affects all users using the experimental permission model in Node.js 20 and Node.js 22.\n\nPlease note that at the time this CVE was issued, the permission model is an experimental feature of Node.js.", + "affectedEnvironments": [ + "all" + ], + "severity": "low" + }, + "145": { + "cve": [ + "CVE-2024-22020" + ], + "vulnerable": "18.x || 20.x || 22.x", + "patched": "^18.20.4 || ^20.15.1 || ^22.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2024-security-releases/", + "overview": "A security flaw in Node.js allows a bypass of network import restrictions.\nBy embedding non-network imports in data URLs, an attacker can execute arbitrary code, compromising system security.\n\nVerified on various platforms, the vulnerability is mitigated by forbidding data URLs in network imports.\n\nExploiting this flaw can violate network import security, posing a risk to developers and servers.", + "affectedEnvironments": [ + "all" + ], + "severity": "medium" + }, + "146": { + "cve": [ + "CVE-2024-37372" + ], + "vulnerable": "20.x || 22.x", + "patched": "^20.15.1 || ^22.4.1", + "ref": "https://nodejs.org/en/blog/vulnerability/july-2024-security-releases/", + "overview": "The Permission Model assumes that any path starting with two backslashes \\\\ has a four-character prefix that can be ignored, which is not always true. This subtle bug leads to vulnerable edge cases.\n\nThis vulnerability affects Windows users of the Node.js Permission Model in version v20.x and v22.x", + "affectedEnvironments": [ + "all" + ], + "severity": "unknown" + } +} \ No newline at end of file diff --git a/src/cli.js b/src/cli.js new file mode 100644 index 0000000..e4fe057 --- /dev/null +++ b/src/cli.js @@ -0,0 +1,40 @@ +const { allGood, danger, separator, vulnerableWarning } = require('./ascii') +const isNodeEOL = require('./is-node-eol') + +const checkPlatform = require('./utils/check-platform') +const getJson = require('./utils/get-json') +const getVulnerabilityList = require('./utils/get-vulnerability-list') +const loadETag = require('./utils/load-etag') + +const STORE = require('./store') + +async function cli (version, platform) { + checkPlatform(platform) + + const scheduleJson = await getJson(STORE.schedule) + const isEOL = isNodeEOL(version, scheduleJson) + + if (isEOL) { + console.error(danger) + console.error(`${version} is end-of-life. There are high chances of being vulnerable. Please upgrade it.`) + process.exit(1) + } + + const securityJson = await getJson(STORE.security) + const list = getVulnerabilityList(version, securityJson, platform) + + if (list.length) { + console.error(danger) + console.error(vulnerableWarning + '\n') + console.error(`${list.join(`\n${separator}\n\n`)}\n${separator}`) + process.exit(1) + } else { + console.info(allGood) + } +} + +if (process.argv[2] !== '-r') { + loadETag() +} + +module.exports = cli diff --git a/index.js b/src/index.js similarity index 69% rename from index.js rename to src/index.js index 64b232a..f07fbc4 100755 --- a/index.js +++ b/src/index.js @@ -1,12 +1,12 @@ #!/usr/bin/env node -const isOldEnough = require('./eol-versions') +const isNodeEOL = require('./is-node-eol') const ascii = require('./ascii') // To guarantee support on older versions and do not drastically impact // the maintenance of this module, we check if process.version is too old // and throw EOL warning when true. -if (isOldEnough(process.version)) { +if (isNodeEOL(process.version)) { console.log(ascii.danger) const msg = process.version + ' is end-of-life. There are high chances of being vulnerable. Please upgrade it.' console.log(msg) @@ -14,10 +14,10 @@ if (isOldEnough(process.version)) { } else { // CLI if (require.main === module) { - require('./is-vulnerable').cli(process.version, require('os').platform()) + require('./cli')(process.version, require('os').platform()) } else { module.exports = { - isNodeVulnerable: require('./is-vulnerable').isNodeVulnerable + isNodeVulnerable: require('./is-node-vulnerable') } } } diff --git a/src/is-node-eol.js b/src/is-node-eol.js new file mode 100644 index 0000000..b9adae0 --- /dev/null +++ b/src/is-node-eol.js @@ -0,0 +1,28 @@ +const getVersionInfo = require('./utils/get-version-info') + +/** + * @param {string} version The Node.js version to be checked. + * @param {JSON|undefined} scheduleJson The JSON object that contains the schedule. + * @returns {boolean} true if the version is end-of-life. + */ +function isNodeEOL (version, scheduleJson) { + const myVersionInfo = getVersionInfo(version, scheduleJson) + + if (!myVersionInfo) { + // i.e. isNodeEOL('abcd') or isNodeEOL('lts') or isNodeEOL('99') + if (scheduleJson) { + throw Error(`Could not fetch version information for ${version}`) + } + return false + } else if (!myVersionInfo.end) { + // We got a record, but.. + // v0.12.18 etc does not have an EOL date, which probably means too old. + return true + } + + const now = new Date() + const end = new Date(myVersionInfo.end) + return now > end +} + +module.exports = isNodeEOL diff --git a/src/is-node-vulnerable.js b/src/is-node-vulnerable.js new file mode 100644 index 0000000..fee9aa1 --- /dev/null +++ b/src/is-node-vulnerable.js @@ -0,0 +1,24 @@ +const isNodeEOL = require('./is-node-eol') +const STORE = require('./store') + +const checkPlatform = require('./utils/check-platform') +const getJson = require('./utils/get-json') +const getVulnerabilityList = require('./utils/get-vulnerability-list') + +async function isNodeVulnerable (version, platform) { + checkPlatform(platform) + + const scheduleJson = await getJson(STORE.schedule) + const isEOL = isNodeEOL(version, scheduleJson) + + if (isEOL) { + return true + } + + const securityJson = await getJson(STORE.security) + const list = getVulnerabilityList(version, securityJson, platform) + + return list.length > 0 +} + +module.exports = isNodeVulnerable diff --git a/src/store.js b/src/store.js new file mode 100644 index 0000000..69f7c31 --- /dev/null +++ b/src/store.js @@ -0,0 +1,18 @@ +const path = require('path') + +const CACHE_DIR = path.join(__dirname, 'cache') + +module.exports = { + security: { + url: 'https://raw.githubusercontent.com/nodejs/security-wg/main/vuln/core/index.json', + jsonFile: path.join(CACHE_DIR, 'security.json'), + etagFile: path.join(CACHE_DIR, 'security.etag'), + etagValue: '' + }, + schedule: { + url: 'https://raw.githubusercontent.com/nodejs/Release/main/schedule.json', + jsonFile: path.join(CACHE_DIR, 'schedule.json'), + etagFile: path.join(CACHE_DIR, 'schedule.etag'), + etagValue: '' + } +} diff --git a/src/utils/check-platform.js b/src/utils/check-platform.js new file mode 100644 index 0000000..e2453e6 --- /dev/null +++ b/src/utils/check-platform.js @@ -0,0 +1,8 @@ +function checkPlatform (platform) { + const availablePlatforms = ['aix', 'darwin', 'freebsd', 'linux', 'openbsd', 'sunos', 'win32', 'android'] + if (platform && !availablePlatforms.includes(platform)) { + throw new Error(`platform ${platform} is not valid. Please use ${availablePlatforms.join(',')}.`) + } +} + +module.exports = checkPlatform diff --git a/src/utils/debug.js b/src/utils/debug.js new file mode 100644 index 0000000..40754fb --- /dev/null +++ b/src/utils/debug.js @@ -0,0 +1,7 @@ +function debug (msg) { + if (process.env.DEBUG) { + console.debug(msg) + } +} + +module.exports = debug diff --git a/src/utils/fetch-json.js b/src/utils/fetch-json.js new file mode 100644 index 0000000..62929ba --- /dev/null +++ b/src/utils/fetch-json.js @@ -0,0 +1,32 @@ +const { request } = require('https') +const fs = require('fs') + +async function fetchJson (obj) { + await new Promise((resolve) => { + request(obj.url, (res) => { + if (res.statusCode !== 200) { + console.error(`Request to Github returned http status ${res.statusCode}. Aborting...`) + process.nextTick(() => { process.exit(1) }) + } + + const fileStream = fs.createWriteStream(obj.jsonFile) + res.pipe(fileStream) + + fileStream.on('finish', () => { + fileStream.close() + resolve() + }) + + fileStream.on('error', (err) => { + console.error(`Error ${err.message} while writing to '${obj.jsonFile}'. Aborting...`) + process.nextTick(() => { process.exit(1) }) + }) + }).on('error', (err) => { + console.error(`Request to Github returned error ${err.message}. Aborting...`) + process.nextTick(() => { process.exit(1) }) + }).end() + }) + return require(obj.jsonFile) +} + +module.exports = fetchJson diff --git a/src/utils/get-json.js b/src/utils/get-json.js new file mode 100644 index 0000000..9c69522 --- /dev/null +++ b/src/utils/get-json.js @@ -0,0 +1,33 @@ +const { request } = require('https') +const debug = require('./debug') +const fetchJson = require('./fetch-json') +const fs = require('fs') + +async function getJson (obj) { + return new Promise((resolve) => { + request(obj.url, { method: 'HEAD' }, (res) => { + if (res.statusCode !== 200) { + console.error(`Request to Github returned http status ${res.statusCode}. Aborting...`) + process.nextTick(() => { process.exit(1) }) + } + + res.on('data', () => {}) + + const { etag } = res.headers + if (!obj.etagValue || obj.eTagValue !== etag || !fs.existsSync(obj.jsonFile)) { + obj.etagValue = etag + fs.writeFileSync(obj.etagFile, etag) + debug('Creating local core.json') + resolve(fetchJson(obj)) + } else { + debug(`No updates from upstream. Getting a cached version: ${obj.jsonFile}`) + resolve(require(obj.jsonFile)) + } + }).on('error', (err) => { + console.error(`Request to Github returned error ${err.message}. Aborting...`) + process.nextTick(() => { process.exit(1) }) + }).end() + }) +} + +module.exports = getJson diff --git a/src/utils/get-version-info.js b/src/utils/get-version-info.js new file mode 100644 index 0000000..be91d48 --- /dev/null +++ b/src/utils/get-version-info.js @@ -0,0 +1,23 @@ +const STORE = require('../store') +const fs = require('fs') +const satisfies = require('semver/functions/satisfies') + +function getVersionInfo (version, scheduleJson) { + if (!scheduleJson) { + scheduleJson = fs.readFileSync(STORE.schedule.jsonFile) + } + + if (scheduleJson[version.toLowerCase()]) { + return scheduleJson[version.toLowerCase()] + } + + for (const [key, value] of Object.entries(scheduleJson)) { + if (satisfies(version, key)) { + return value + } + } + + return null +} + +module.exports = getVersionInfo diff --git a/src/utils/get-vulnerability-list.js b/src/utils/get-vulnerability-list.js new file mode 100644 index 0000000..fa0e886 --- /dev/null +++ b/src/utils/get-vulnerability-list.js @@ -0,0 +1,23 @@ +const { bold } = require('../ascii') +const isSystemAffected = require('./is-system-affected') +const satisfies = require('semver/functions/satisfies') + +function getVulnerabilityList (currentVersion, data, platform) { + const list = [] + for (const key in data) { + const vuln = data[key] + + if ( + ( + satisfies(currentVersion, vuln.vulnerable) && + !satisfies(currentVersion, vuln.patched) + ) && isSystemAffected(platform, vuln.affectedEnvironments) + ) { + const severity = vuln.severity === 'unknown' ? '' : `(${vuln.severity})` + list.push(`${bold(vuln.cve)}${severity}: ${vuln.overview}\n${bold('Patched versions')}: ${vuln.patched}`) + } + } + return list +} + +module.exports = getVulnerabilityList diff --git a/src/utils/is-system-affected.js b/src/utils/is-system-affected.js new file mode 100644 index 0000000..9ed8df2 --- /dev/null +++ b/src/utils/is-system-affected.js @@ -0,0 +1,14 @@ +const isSystemAffected = (platform, affectedEnvironments) => { + // No platform specified (legacy mode) + if (!platform || !Array.isArray(affectedEnvironments)) { + return true + } + // If the environment is matching or all the environments are affected + if (affectedEnvironments.includes(platform) || affectedEnvironments.includes('all')) { + return true + } + // Default to false + return false +} + +module.exports = isSystemAffected diff --git a/src/utils/load-etag.js b/src/utils/load-etag.js new file mode 100644 index 0000000..4ebd21c --- /dev/null +++ b/src/utils/load-etag.js @@ -0,0 +1,14 @@ +const STORE = require('../store') +const debug = require('./debug') +const fs = require('fs') + +function loadETag () { + for (const [key, obj] of Object.entries(STORE)) { + if (fs.existsSync(obj.etagFile)) { + debug(`Loading local ETag for '${key}'`) + obj.etagValue = fs.readFileSync(obj.etagFile).toString() + } + } +} + +module.exports = loadETag diff --git a/test.js b/test.js index 3617115..c95ae2d 100644 --- a/test.js +++ b/test.js @@ -1,5 +1,5 @@ const assert = require('assert') -const { isNodeVulnerable } = require('./index') +const { isNodeVulnerable } = require('./src/index') async function t () { // of course, this test is fragile