CVE-2022-29247

Electron is a framework for writing cross-platform desktop applications using JavaScript (JS), HTML, and CSS. A vulnerability in versions prior to 18.0.0-beta.6, 17.2.0, 16.2.6, and 15.5.5 allows a renderer with JS execution to obtain access to a new renderer process with `nodeIntegrationInSubFrames` enabled which in turn allows effective access to `ipcRenderer`. The `nodeIntegrationInSubFrames` option does not implicitly grant Node.js access. Rather, it depends on the existing sandbox setting. If an application is sandboxed, then `nodeIntegrationInSubFrames` just gives access to the sandboxed renderer APIs, which include `ipcRenderer`. If the application then additionally exposes IPC messages without IPC `senderFrame` validation that perform privileged actions or return confidential data this access to `ipcRenderer` can in turn compromise your application / user even with the sandbox enabled. Electron versions 18.0.0-beta.6, 17.2.0, 16.2.6, and 15.5.5 contain a fix for this issue. As a workaround, ensure that all IPC message handlers appropriately validate `senderFrame`.
ProviderTypeBase ScoreAtk. VectorAtk. ComplexityPriv. RequiredVector
NISTNIST
2.2 LOW
NETWORK
HIGH
HIGH
CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:L/I:N/A:N
GitHub_MCNA
2.2 LOW
NETWORK
HIGH
HIGH
CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:L/I:N/A:N
CVEADP
---
---
CISA-ADPADP
---
---
Base Score
CVSS 3.x
EPSS Score
Percentile: 36%
VendorProductVersion
electronjselectron
𝑥
< 15.5.5
electronjselectron
16.0.1 ≤
𝑥
< 16.2.6
electronjselectron
17.0.1 ≤
𝑥
< 17.2.0
electronjselectron
16.0.0:beta1
electronjselectron
16.0.0:beta2
electronjselectron
16.0.0:beta3
electronjselectron
16.0.0:beta4
electronjselectron
16.0.0:beta5
electronjselectron
16.0.0:beta6
electronjselectron
16.0.0:beta7
electronjselectron
16.0.0:beta8
electronjselectron
16.0.0:beta9
electronjselectron
17.0.0:beta1
electronjselectron
17.0.0:beta2
electronjselectron
17.0.0:beta3
electronjselectron
17.0.0:beta4
electronjselectron
17.0.0:beta5
electronjselectron
17.0.0:beta6
electronjselectron
17.0.0:beta7
electronjselectron
17.0.0:beta8
electronjselectron
17.0.0:beta9
electronjselectron
18.0.0:beta1
electronjselectron
18.0.0:beta2
electronjselectron
18.0.0:beta3
electronjselectron
18.0.0:beta4
electronjselectron
18.0.0:beta5
𝑥
= Vulnerable software versions