Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(deps): update dependency electron-updater to v6 [security] #5136

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Sep 25, 2024

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
electron-updater (source) ^4.2.0 -> ^6.0.0 age adoption passing confidence

Warning

Some dependencies could not be looked up. Check the Dependency Dashboard for more information.

GitHub Vulnerability Alerts

CVE-2024-39698

Observations

The file packages/electron-updater/src/windowsExecutableCodeSignatureVerifier.ts implements the signature validation routine for Electron applications on Windows. It executes the following command in a new shell (process.env.ComSpec on Windows, usually C:\Windows\System32\cmd.exe):

https://github.com/electron-userland/electron-builder/blob/140e2f0eb0df79c2a46e35024e96d0563355fc89/packages/electron-updater/src/windowsExecutableCodeSignatureVerifier.ts#L35-L41

Because of the surrounding shell, a first pass by cmd.exe expands any environment variable found in command-line above.

Exploitation

This creates a situation where verifySignature() can be tricked into validating the certificate of a different file than the one that was just downloaded. If the step is successful, the malicious update will be executed even if its signature is invalid.

Impact

This attack assumes a compromised update manifest (server compromise, Man-in-the-Middle attack if fetched over HTTP, Cross-Site Scripting to point the application to a malicious updater server, etc.).

Patch

This vulnerability was patched in #​8295, by comparing the path in the output of Get-AuthenticodeSignature with the intended one. The patch is available starting from 6.3.0-alpha.6.


Release Notes

electron-userland/electron-builder (electron-updater)

v6.3.0

Compare Source

Minor Changes
Patch Changes

v6.2.1

Compare Source

Patch Changes

v6.2.0

Compare Source

Minor Changes

v6.1.9

Compare Source

Patch Changes

v6.1.8

Compare Source

Patch Changes

v6.1.7

Compare Source

Patch Changes

v6.1.6

Compare Source

Patch Changes

v6.1.5

Compare Source

Patch Changes
  • #​7767 21f3069c Thanks @​jackple! - fix: When error code is ENOENT, try to use electron.shell.openPath to run installer on Windows

v6.1.4

Compare Source

Patch Changes

v6.1.3

Compare Source

Patch Changes

v6.1.2

Compare Source

Patch Changes

v6.1.1

Compare Source

Patch Changes

v6.1.0

Compare Source

Minor Changes
Patch Changes

v6.0.4

Compare Source

Patch Changes

v6.0.3

Compare Source

Patch Changes
  • #​7524 1a134800 Thanks @​NoahAndrews! - Fixed error handling when launching updater (fixes NSIS updates when isAdminRightsRequired is incorrectly set to false)

v6.0.2

Compare Source

Patch Changes

v6.0.1

Compare Source

Patch Changes

v6.0.0

Compare Source

Major Changes
Minor Changes
Patch Changes

v5.3.0

Compare Source

Minor Changes

v5.2.4

Compare Source

Patch Changes

v5.2.3

Compare Source

Patch Changes

v5.2.2

Compare Source

Patch Changes

v5.2.1

Compare Source

Patch Changes

v5.2.0

Compare Source

Minor Changes
  • #​6907 e7f28677 Thanks @​panther7! - Add installDir property for NsisUpdater. Now is it posible change install folder from AppUpdater.

v5.1.0

Compare Source

Minor Changes
Patch Changes

v5.0.6

Compare Source

Patch Changes

v5.0.5

Compare Source

Patch Changes

v5.0.4

Compare Source

Patch Changes

v5.0.3

Compare Source

Patch Changes

v5.0.2

Compare Source

Patch Changes

v5.0.1

Compare Source

Patch Changes

v5.0.0

Compare Source

Major Changes
Minor Changes
Patch Changes
  • #​6589 633ee5dc Thanks @​devinbinnie! - - Removed backtick escaping for Windows code signing as it is unnecessary for Powershell and can cause the script to attempt to access the wrong file
    • Updated the proxy filename to be more secure (512-bit string)

v4.6.5

Patch Changes

v4.6.4

Patch Changes

v4.6.3

Patch Changes

v4.6.2

Patch Changes

v4.6.1

Patch Changes

v4.6.0

Minor Changes
Patch Changes

v4.5.2

Patch Changes

v4.5.1

Patch Changes

v4.5.0

Minor Changes
Patch Changes

v4.4.6

Patch Changes
  • a3c72b2: fix(electron-updater): workaround vite's process.env.* replacement
  • ca0e845: fix(electron-updater): null object error when MacUpdater attempts to log the server port before it is listening

v4.4.5

Patch Changes
  • a3f2cd1: fix(electron-updater): default import throws error for fs and path leading to always requiring elevation
  • ae363e5: fix: removing data from error being thrown. It's unnecessary and also unnecessarily large to be passing to the console. Resolves: #​6131

v4.4.4

Patch Changes
  • ae81dfa: fix(electron-updater): small cleanup and add more debug logging for MacUpdater to investigate #​6120

v4.4.3

Patch Changes
  • a4eae34: Synchronizing CLI and package.json versions. Updating auto-publish values + changeset generation to be more frictionless
  • Updated dependencies [a4eae34]

v4.4.2

Patch Changes

v4.4.1

Patch Changes
Bug Fixes
  • Remove dependency on pako module, use native API instead.

Configuration

📅 Schedule: Branch creation - "" (UTC), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

@renovate renovate bot added the renovate PR automatically generated by renovate label Sep 25, 2024
Copy link

bundlemon bot commented Sep 25, 2024

BundleMon

Unchanged files (4)
Status Path Size Limits
renderer.(hash).js
6.88MB -
vendors~renderer.(hash).js
4.7MB -
updater.js
115.28KB -
guest-api.js
40.19KB -

No change in files bundle size

Final result: ✅

View report in BundleMon website ➡️


Current branch size history | Target branch size history

@renovate renovate bot changed the title fix(deps): update dependency electron-updater to v6 [security] fix(deps): update dependency electron-updater to v6 [security] - autoclosed Sep 25, 2024
@renovate renovate bot closed this Sep 25, 2024
@renovate renovate bot deleted the renovate/npm-electron-updater-vulnerability branch September 25, 2024 16:55
@renovate renovate bot changed the title fix(deps): update dependency electron-updater to v6 [security] - autoclosed fix(deps): update dependency electron-updater to v6 [security] Sep 26, 2024
@renovate renovate bot reopened this Sep 26, 2024
@renovate renovate bot restored the renovate/npm-electron-updater-vulnerability branch September 26, 2024 19:33
@renovate renovate bot force-pushed the renovate/npm-electron-updater-vulnerability branch from 96003aa to f578702 Compare September 26, 2024 19:34
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
renovate PR automatically generated by renovate
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants