update-electron-app

🌲 A drop-in module that adds autoUpdating capabilities to Electron apps

  • 所有者: electron/update-electron-app
  • 平台:
  • 許可證: MIT License
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

update-electron-app

A drop-in module that adds autoUpdating capabilities to Electron apps

Powered by the free and open-source update.electronjs.org service.

screenshot

Requirements

Before using this module, make sure your Electron app meets these criteria:

  • Your app runs on macOS or Windows
  • Your app has a public GitHub repository
  • Your builds are published to GitHub Releases
  • Your builds are code signed

Installation

npm i update-electron-app

Usage

Drop this anywhere in your main process:

require('update-electron-app')()

That's it! Here's what happens by default:

  • Repository URL is found in your app's package.json file.
  • Your app will check for updates at startup, then every ten minutes. This interval is configurable.
  • No need to wait for your app's ready event; the module figures that out.
  • If an update is found, it will automatically be downloaded in the background.
  • When an update is finished downloading, a dialog is displayed allowing the user to restart the app now or later.

You can also specify custom options:

require('update-electron-app')({
  repo: 'github-user/repo',
  updateInterval: '1 hour',
  logger: require('electron-log')
})

API

update(options)

Options:

  • repo String (optional) - A GitHub repository in the format owner/repo. Defaults to your package.json's "repository" field
  • host String (optional) - Defaults to https://update.electronjs.org
  • updateInterval String (optional) - How frequently to check for updates. Defaults to 10 minutes. Minimum allowed interval is 5 minutes.
  • logger Object (optional) - A custom logger object that defines a log function. Defaults to console. See electron-log, a module that aggregates logs from main and renderer processes into a single file.
  • notifyUser Boolean (optional) - Defaults to true. When enabled the user will be
    prompted to apply the update immediately after download.

FAQ

What kinds of assets do I need to build?

For macOS, you'll need to build a .zip file and include it in your GitHub Release.
Use electron-forge or electron-installer-zip to package your app as a zip.

For Windows, you'll need to build a .exe file and include it in your GitHub Release.

Why is my app launching multiple times?

Windows apps have an update process that requires multiple application restarts.
You can use the electron-squirrel-startup module to improve this
behavior.

Can I use this module by uploading my private app's builds to a public GitHub repository?

Yes :)

License

MIT

See Also

If your app is packaged with electron-builder, you may not need this module.
Builder has its own built-in mechanism for updating apps. Find out more at
electron.build/auto-update.

主要指標

概覽
名稱與所有者electron/update-electron-app
主編程語言TypeScript
編程語言JavaScript (語言數: 2)
平台
許可證MIT License
所有者活动
創建於2018-04-18 03:37:36
推送於2025-04-01 07:59:12
最后一次提交
發布數15
最新版本名稱v3.1.1 (發布於 )
第一版名稱v1.0.1 (發布於 2018-04-17 21:18:04)
用户参与
星數777
關注者數70
派生數136
提交數116
已啟用問題?
問題數57
打開的問題數23
拉請求數84
打開的拉請求數2
關閉的拉請求數27
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?