跳过内容

Electron Updater API 参考

__CAPGO_KEEP_3__

__CAPGO_KEEP_4__

__CAPGO_KEEP_5__

__CAPGO_KEEP_6__

__CAPGO_KEEP_7__

__CAPGO_KEEP_8__ __CAPGO_KEEP_9__

await updater.notifyAppReady();

download(options)

下载选项

从 URL 下载一个包。

const bundle = await updater.download({
url: 'https://example.com/bundle.zip',
version: '1.0.1',
checksum: 'sha256-hash', // Optional but recommended
sessionKey: '...', // For encrypted bundles
});

参数:

选项类型是否必填描述
urlstring下载包的 URL
versionstring李架标凹代码
checksumstring因队强为码配缀的配缀
sessionKeystring当前的管球服务号

返回: BundleInfo 对象 id, version, status

在下一次应用重启时将包队列加载。

await updater.next({ id: 'bundle-id' });

参数:

选项类型必填描述
id字符串Bundle ID到队列

立即切换到一个捆绑包并重新加载应用。

await updater.set({ id: 'bundle-id' });

参数:

选项类型必填描述
id字符串激活包ID

手动重新加载当前包

await updater.reload();

从存储中删除包

await updater.delete({ id: 'bundle-id' });

参数:

选项类型必填描述
id字符串要删除的包ID

重置为内置版本或最后一次成功的包。

// Reset to builtin
await updater.reset({ toLastSuccessful: false });
// Reset to last successful bundle
await updater.reset({ toLastSuccessful: true });

参数:

选项类型必填描述
toLastSuccessfulboolean如果为真,则重置为最后一次成功的捆绑包而不是内置捆绑包

获取当前捆绑包和本机版本的信息

const info = await updater.current();
// { bundle: { id, version, status }, native: '1.0.0' }

list(options)

列表(options)

列出所有下载的包。

const bundles = await updater.list();
// [{ id, version, status, downloaded, checksum }, ...]

复制到剪贴板

const next = await updater.getNextBundle();
// { id, version, status } or null

获取最后一次失败的更新信息(用于调试回滚)

复制到剪贴板

getFailedUpdate()

const failed = await updater.getFailedUpdate();
// { id, version, reason } or null

获取内置版本()

标题:获取内置版本()

获取与应用程序二进制文件一起发布的版本。

const version = await updater.getBuiltinVersion();
// '1.0.0'

获取最新版本(options)

标题:获取最新版本(options)

检查服务器以获取最新可用版本。

const latest = await updater.getLatest();
if (latest.url && !latest.error) {
// Update available
console.log('New version:', latest.version);
console.log('Download URL:', latest.url);
} else if (latest.error) {
console.error('Error checking updates:', latest.error);
}

返回:

属性类型描述
url字符串下载 URL (如果没有更新则为空)
version字符串可用版本
checksumSHA256 校验和字符串
sessionKey加密会话密钥字符串
error检查失败时的错误消息__CAPGO_KEEP_0__
messagestring服务器消息

频道管理

频道管理

设置频道(options)

设置频道(options)

将设备分配到特定的频道。

await updater.setChannel({ channel: 'beta' });

取消频道(options)

设置频道(options)

移除频道分配并使用默认值。

await updater.unsetChannel();

获取当前频道分配。

频道获取(getChannel())

获取当前频道分配。

const channel = await updater.getChannel();
// { channel: 'production', status: 'set' }

获取所有可用频道(listChannels())

频道列表(listChannels())

列出此应用程序的所有可用频道。

const channels = await updater.listChannels();
// ['production', 'beta', 'staging']

控制下载的更新何时应用。

设置多延迟(setMultiDelay(options))

setMultiDelay(options)

设置更新应用之前必须满足的条件。

// Wait for app to be backgrounded
await updater.setMultiDelay({
delayConditions: [{ kind: 'background' }]
});
// Wait until specific date
await updater.setMultiDelay({
delayConditions: [{ kind: 'date', value: '2024-12-25T00:00:00Z' }]
});
// Wait for app to be killed and restarted
await updater.setMultiDelay({
delayConditions: [{ kind: 'kill' }]
});
// Multiple conditions (all must be met)
await updater.setMultiDelay({
delayConditions: [
{ kind: 'background' },
{ kind: 'date', value: '2024-12-25T00:00:00Z' }
]
});

延迟条件类型:

类型描述
background可选持续时间(毫秒)等待应用进入后台
kill-等待应用被杀死并重启
dateISO 日期字符串等待特定日期/时间
nativeVersion版本字符串等待原生应用更新

清除所有延迟条件并在下一次检查时立即应用更新。

await updater.cancelDelay();

获取设备的唯一标识符。

const deviceId = await updater.getDeviceId();
// 'uuid-xxxx-xxxx-xxxx'

为设备设置一个自定义标识符(用于分析)。

await updater.setCustomId({ customId: 'user-123' });

在运行时更改更新服务器 URL。

await updater.setUpdateUrl({ url: 'https://my-server.com/updates' });

设置统计URL(options)

标题:设置统计URL(options)

修改统计报告URL

await updater.setStatsUrl({ url: 'https://my-server.com/stats' });

设置渠道URL(options)

标题:设置渠道URL(options)

修改渠道管理URL

await updater.setChannelUrl({ url: 'https://my-server.com/channel' });

设置应用ID(options)

标题:设置应用ID(options)

在运行时更改 App ID。

await updater.setAppId({ appId: 'com.example.newapp' });

获取当前 App ID。

const appId = await updater.getAppId();

设置调试菜单(options)

标题:设置调试菜单(options)

启用或禁用调试菜单。

await updater.setDebugMenu({ enabled: true });

isDebugMenuEnabled()

标题:isDebugMenuEnabled()

检查是否启用了调试菜单。

const enabled = await updater.isDebugMenuEnabled();

使用 addListener:

updater.addListener('eventName', (event) => {
// Handle event
});

可用事件

可用事件
事件事件数据描述
download{ percent, status }下载进度更新
updateAvailable{ bundle }新版本可用
noNeedUpdate{ message }已是最新
downloadComplete{ bundle }下载成功
downloadFailed{ bundle, error }下载失败
breakingAvailable{ bundle }不兼容的更新 (需要原生更新)
updateFailed{ bundle, reason }更新安装失败
appReloaded{}App 已经重新加载
appReady{}notifyAppReady() __CAPGO_KEEP_0__被调用

示例:全事件处理

标题:示例:全事件处理
// Progress tracking
updater.addListener('download', (event) => {
updateProgressBar(event.percent);
});
// Update available notification
updater.addListener('updateAvailable', (event) => {
showNotification(`Update ${event.bundle.version} available!`);
});
// Handle completion
updater.addListener('downloadComplete', async (event) => {
// Queue for next restart
await updater.next({ id: event.bundle.id });
showNotification('Update will apply on next restart');
});
// Handle failures
updater.addListener('updateFailed', (event) => {
console.error('Update failed:', event.reason);
reportError(event);
});

构造函数选项

标题:构造函数选项

全配置选项 ElectronUpdater:

const updater = new ElectronUpdater({
// Required
appId: 'com.example.app',
// Version override
version: '1.0.0', // Override builtin version detection
// Server URLs
updateUrl: 'https://plugin.capgo.app/updates',
channelUrl: 'https://plugin.capgo.app/channel_self',
statsUrl: 'https://plugin.capgo.app/stats',
// Behavior
autoUpdate: true, // Enable automatic update checks
appReadyTimeout: 10000, // Milliseconds before rollback (default: 10000)
autoDeleteFailed: true, // Auto-delete failed bundles
autoDeletePrevious: true, // Auto-delete old bundles
resetWhenUpdate: true, // Reset to builtin on native update
// Channels
defaultChannel: 'production',
// Direct Update Mode
directUpdate: false, // 'atInstall' | 'onLaunch' | 'always' | false
// Security
publicKey: '...', // RSA public key for E2E encryption
// Dynamic Configuration
allowModifyUrl: false, // Allow runtime URL changes
allowModifyAppId: false, // Allow runtime App ID changes
persistCustomId: false, // Persist custom ID across updates
persistModifyUrl: false, // Persist URL changes
// Debug
debugMenu: false, // Enable debug menu (Ctrl+Shift+D)
disableJSLogging: false, // Disable console logs
// Periodic Updates
periodCheckDelay: 0, // Seconds between auto-checks (0 = disabled, min 600)
});

从 Electron Updater 继续 API 参考

标题:从 Electron Updater 继续 API 参考

如果您正在使用 Electron Updater API Reference 为了计划仪表板和API操作,连接它 使用@capgo/electron-updater 使用@capgo/electron-updater的本机功能 API Overview 查看API Overview中的实现细节 介绍 查看介绍中的实现细节 API Keys 查看API Keys中的实现细节 设备 查看设备中的实现细节