CVE-2022-29247

Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
13/06/2022
Last modified:
27/06/2022

Description

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`.

Vulnerable products and versions

CPE From Up to
cpe:2.3:a:electronjs:electron:*:*:*:*:*:*:*:* 15.5.5 (excluding)
cpe:2.3:a:electronjs:electron:*:*:*:*:*:*:*:* 16.0.1 (including) 16.2.6 (excluding)
cpe:2.3:a:electronjs:electron:*:*:*:*:*:*:*:* 17.0.1 (including) 17.2.0 (excluding)
cpe:2.3:a:electronjs:electron:16.0.0:beta1:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta2:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta3:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta4:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta5:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta6:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta7:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta8:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:16.0.0:beta9:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:17.0.0:beta1:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:17.0.0:beta2:*:*:*:*:*:*
cpe:2.3:a:electronjs:electron:17.0.0:beta3:*:*:*:*:*:*