メニューに進む

Electron Updater API リファレンス

Electron Updaterの利用可能なすべてのメソッド、イベント、および設定オプションをドキュメント化しています。

Core Methods

「Core Methods」

notifyAppReady()

「notifyAppReady()」

アプリ起動毎に呼び出す必要があります。 bundleの正常なロードを確認し、自動ロールバックを防止します。

await updater.notifyAppReady();

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
});

パラメータ:

オプション必要説明
urlstringYesURL to download the bundle from
versionstringYesVersion identifier for the bundle
checksumstringNoSHA256 checksum for verification
sessionKeystringNoSession key for encrypted bundles

戻り値: BundleInfo オブジェクト id, version, status

アプリ再起動時にバンドルをロードするように予約します。

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

引数:

オプション必要説明
id文字列YesBundle IDをキューに追加

アプリを即座にバンドルに切り替え、リロードします。

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

引数:

オプション必要説明
id文字列YesBundle ID to activate

Manually reload the app with the current bundle.

await updater.reload();

Delete a bundle from storage.

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

Parameters:

Optionタイプ必要説明
id文字列はい削除するBundle ID

バンドルバージョンまたは最後の成功バンドルにリセットします。

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

パラメータ:

オプション種類必要説明
toLastSuccessfulbooleanNotrueの場合、ビルトインの代わりに最後の成功バンドルにリセットします。

現在のバンドルとネイティブバージョンの情報を取得します。

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

ダウンロードしたすべてのバンドルをリストアップします。

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

次の再起動で実行されるバンドルの情報を取得します。

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

最後の更新でエラーが発生した際の詳細情報を取得します。(ロールバックのデバッグに役立ちます)。

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

アプリバイナリに組み込まれたバージョンを取得します。

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

サーバーから最新のバージョンをチェックします。

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__CAPGO_KEEP_0____CAPGO_KEEP_0__
version__CAPGO_KEEP_0__利用可能なバージョン
checksum__CAPGO_KEEP_0__SHA256チェックサム
sessionKey__CAPGO_KEEP_0__暗号化セッションキー
error__CAPGO_KEEP_0__エラー メッセージ (チェック失敗時)
messagestringサーバーからのメッセージ

チャンネル管理

チャンネル管理

setChannel(options)

setChannel(options)

デバイスを特定のチャンネルに割り当てる。

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

unsetChannel(options)

setChannel(options)

チャンネル割り当てを解除し、デフォルトを使用。

await updater.unsetChannel();

現在のチャネル割り当てを取得します。

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

このアプリの利用可能なチャネルの一覧を表示します。

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

ダウンロードした更新を適用するタイミングを制御します。

更新が適用される前に満たす必要のある条件を設定します。

// 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任意の時間 (ms)アプリがバックグラウンドに移動するのを待つ
kill-アプリが終了して再起動されるのを待つ
dateISO 日付文字列特定の日時まで待つ
nativeVersionバージョン文字列ネイティブアプリの更新を待つ

cancelDelay()

「cancelDelay()」

すべての遅延条件をクリアし、次のチェックで即座に更新を適用する。

await updater.cancelDelay();

デバイス識別

「デバイス識別」

getDeviceId()

「getDeviceId()」

一意のデバイス識別子を取得する。

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' });

Change the statistics reporting URL.

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

Change the channel management URL.

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

実行時でApp IDを変更します。

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

現在のApp IDを取得します。

const appId = await updater.getAppId();

デバッグメニューの有効化/無効化

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

デバッグメニューが有効かどうかを確認

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);
});

Electron Updater から続けて __CAPGO_KEEP_0__ リファレンス 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 リファレンスから続けてください」のセクション

Capgo を使用している場合 Electron Updater API Reference ダッシュボードとAPIの計画と運用のために接続する Using @capgo/electron-updater Capacitorのネイティブ機能のためにUsing @capgo/electron-updater API Overview Capacitorの実装詳細のためにAPI Overview Introduction 実装詳細のためにIntroduction API Keys 実装詳細のためにAPI Keys Devices 実装詳細のためにDevices