{"api_version":"1","generated_at":"2026-04-23T09:37:04+00:00","cve":"CVE-2016-10536","urls":{"html":"https://cve.report/CVE-2016-10536","api":"https://cve.report/api/cve/CVE-2016-10536.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2016-10536","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2016-10536"},"summary":{"title":"CVE-2016-10536","description":"engine.io-client is the client for engine.io, the implementation of a transport-based cross-browser/cross-device bi-directional communication layer for Socket.IO. The vulnerability is related to the way that node.js handles the `rejectUnauthorized` setting. If the value is something that evaluates to false, certificate verification will be disabled. This is problematic as engine.io-client 1.6.8 and earlier passes in an object for settings that includes the rejectUnauthorized property, whether it has been set or not. If the value has not been explicitly changed, it will be passed in as `null`, resulting in certificate verification being turned off.","state":"PUBLIC","assigner":"support@hackerone.com","published_at":"2018-05-31 20:29:00","updated_at":"2019-10-09 23:16:00"},"problem_types":["CWE-295"],"metrics":[],"references":[{"url":"https://www.cigital.com/blog/node-js-socket-io/","name":"https://www.cigital.com/blog/node-js-socket-io/","refsource":"MISC","tags":["Third Party Advisory"],"title":"Node.js and Socket.IO: How security fails when 'null' is 'false' | Synopsys","mime":"text/html","httpstatus":"200","archivestatus":"200"},{"url":"https://github.com/socketio/engine.io-client/commit/2c55b278a491bf45313ecc0825cf800e2f7ff5c1","name":"https://github.com/socketio/engine.io-client/commit/2c55b278a491bf45313ecc0825cf800e2f7ff5c1","refsource":"MISC","tags":["Patch","Third Party Advisory"],"title":"default `rejectUnauthorized` to `true` · socketio/engine.io-client@2c55b27 · GitHub","mime":"text/html","httpstatus":"200","archivestatus":"200"},{"url":"https://nodesecurity.io/advisories/99","name":"https://nodesecurity.io/advisories/99","refsource":"MISC","tags":["Third Party Advisory"],"title":"Overview","mime":"text/html","httpstatus":"200","archivestatus":"200"},{"url":"https://www.cve.org/CVERecord?id=CVE-2016-10536","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2016-10536","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[],"timeline":[],"solutions":[],"workarounds":[],"exploits":[],"credits":[],"nvd_cpes":[{"cve_year":"2016","cve_id":"10536","vulnerable":"1","versionEndIncluding":"1.6.8","cpe1":"cpe","cpe2":"2.3","cpe3":"a","cpe4":"socket","cpe5":"engine.io-client","cpe6":"*","cpe7":"*","cpe8":"*","cpe9":"*","cpe10":"*","cpe11":"node.js","cpe12":"*","cpe13":"*"}],"vendor_comments":[],"enrichments":{"kev":null,"epss":null,"legacy_qids":[{"cve":"CVE-2016-10536","qid":"983438","title":"Nodejs (npm) Security Update for engine.io-client (GHSA-4r4m-hjwj-43p8)"}]},"source_records":{"cve_program":{"CVE_data_meta":{"ASSIGNER":"support@hackerone.com","DATE_PUBLIC":"2018-04-26T00:00:00","ID":"CVE-2016-10536","STATE":"PUBLIC"},"affects":{"vendor":{"vendor_data":[{"product":{"product_data":[{"product_name":"engine.io-client node module","version":{"version_data":[{"version_value":"<= 1.6.8"}]}}]},"vendor_name":"HackerOne"}]}},"data_format":"MITRE","data_type":"CVE","data_version":"4.0","description":{"description_data":[{"lang":"eng","value":"engine.io-client is the client for engine.io, the implementation of a transport-based cross-browser/cross-device bi-directional communication layer for Socket.IO. The vulnerability is related to the way that node.js handles the `rejectUnauthorized` setting. If the value is something that evaluates to false, certificate verification will be disabled. This is problematic as engine.io-client 1.6.8 and earlier passes in an object for settings that includes the rejectUnauthorized property, whether it has been set or not. If the value has not been explicitly changed, it will be passed in as `null`, resulting in certificate verification being turned off."}]},"problemtype":{"problemtype_data":[{"description":[{"lang":"eng","value":"Man-in-the-Middle (CWE-300)"}]}]},"references":{"reference_data":[{"name":"https://www.cigital.com/blog/node-js-socket-io/","refsource":"MISC","url":"https://www.cigital.com/blog/node-js-socket-io/"},{"name":"https://github.com/socketio/engine.io-client/commit/2c55b278a491bf45313ecc0825cf800e2f7ff5c1","refsource":"MISC","url":"https://github.com/socketio/engine.io-client/commit/2c55b278a491bf45313ecc0825cf800e2f7ff5c1"},{"name":"https://nodesecurity.io/advisories/99","refsource":"MISC","url":"https://nodesecurity.io/advisories/99"}]}},"nvd":{"publishedDate":"2018-05-31 20:29:00","lastModifiedDate":"2019-10-09 23:16:00","problem_types":["CWE-295"],"metrics":{"baseMetricV3":{"cvssV3":{"version":"3.0","vectorString":"CVSS:3.0/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:N/A:N","attackVector":"NETWORK","attackComplexity":"HIGH","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"HIGH","integrityImpact":"NONE","availabilityImpact":"NONE","baseScore":5.9,"baseSeverity":"MEDIUM"},"exploitabilityScore":2.2,"impactScore":3.6},"baseMetricV2":{"cvssV2":{"version":"2.0","vectorString":"AV:N/AC:M/Au:N/C:P/I:N/A:N","accessVector":"NETWORK","accessComplexity":"MEDIUM","authentication":"NONE","confidentialityImpact":"PARTIAL","integrityImpact":"NONE","availabilityImpact":"NONE","baseScore":4.3},"severity":"MEDIUM","exploitabilityScore":8.6,"impactScore":2.9,"obtainAllPrivilege":false,"obtainUserPrivilege":false,"obtainOtherPrivilege":false,"userInteractionRequired":false}},"configurations":{"CVE_data_version":"4.0","nodes":[{"operator":"OR","children":[],"cpe_match":[{"vulnerable":true,"cpe23Uri":"cpe:2.3:a:socket:engine.io-client:*:*:*:*:*:node.js:*:*","versionEndIncluding":"1.6.8","cpe_name":[]}]}]}},"legacy_mitre":{"record":{"CveYear":"2016","CveId":"10536","Ordinal":"113754","Title":"CVE-2016-10536","CVE":"CVE-2016-10536","Year":"2016"},"notes":[{"CveYear":"2016","CveId":"10536","Ordinal":"1","NoteData":"engine.io-client is the client for engine.io, the implementation of a transport-based cross-browser/cross-device bi-directional communication layer for Socket.IO. The vulnerability is related to the way that node.js handles the `rejectUnauthorized` setting. If the value is something that evaluates to false, certificate verification will be disabled. This is problematic as engine.io-client 1.6.8 and earlier passes in an object for settings that includes the rejectUnauthorized property, whether it has been set or not. If the value has not been explicitly changed, it will be passed in as `null`, resulting in certificate verification being turned off.","Type":"Description","Title":null},{"CveYear":"2016","CveId":"10536","Ordinal":"2","NoteData":"2018-05-31","Type":"Other","Title":"Published"},{"CveYear":"2016","CveId":"10536","Ordinal":"3","NoteData":"2018-05-31","Type":"Other","Title":"Modified"}]}}}