Events
Capacitor Updaterプラグインは、更新プロセスを監視し、さまざまな状態に応答するためにリッスンできるいくつかのイベントを提供します。
イベントリスナーのセットアップ
Section titled “イベントリスナーのセットアップ”イベントをリッスンするには、CapacitorUpdaterオブジェクトのaddListenerメソッドを使用します:
import { CapacitorUpdater } from '@capgo/capacitor-updater';
// Add a listenerconst listener = await CapacitorUpdater.addListener('eventName', (event) => { // Handle the event});
// Remove the listener when no longer neededlistener.remove();
// Remove all listenersawait CapacitorUpdater.removeAllListeners();利用可能なイベント
Section titled “利用可能なイベント”download
Section titled “download”バンドルのダウンロードプロセス中に発火します。ダウンロードの進行状況情報を提供します。
CapacitorUpdater.addListener('download', (event) => { console.log(`Download progress: ${event.percent}%`); console.log('Bundle info:', event.bundle);});イベントデータ:
percent: number - ダウンロードの進行状況(パーセンテージ、0-100)bundle: BundleInfo - ダウンロード中のバンドルに関する情報
noNeedUpdate
Section titled “noNeedUpdate”更新の確認により、更新が不要であると判断されたときに発火します。
CapacitorUpdater.addListener('noNeedUpdate', (event) => { console.log('App is up to date'); console.log('Current bundle:', event.bundle);});イベントデータ:
bundle: BundleInfo - 現在のバンドルに関する情報
updateAvailable
Section titled “updateAvailable”ダウンロード可能な新しい更新が利用可能なときに発火します。
CapacitorUpdater.addListener('updateAvailable', (event) => { console.log('Update available'); console.log('New bundle:', event.bundle); // You can trigger a download here if needed});イベントデータ:
bundle: BundleInfo - 利用可能な更新バンドルに関する情報
downloadComplete
Section titled “downloadComplete”バンドルのダウンロードが正常に完了したときに発火します。
CapacitorUpdater.addListener('downloadComplete', (event) => { console.log('Download completed'); console.log('Downloaded bundle:', event.bundle); // You might want to set this bundle as next});イベントデータ:
bundle: BundleInfo - ダウンロードされたバンドルに関する情報
majorAvailable
Section titled “majorAvailable”メジャーアップデートが利用可能だが、自動更新設定によってブロックされているときに発火します。
CapacitorUpdater.addListener('majorAvailable', (event) => { console.log('Major update available:', event.version); // Notify user about major update});イベントデータ:
version: string - メジャーアップデートのバージョン番号
updateFailed
Section titled “updateFailed”次回のアプリ起動時に更新のインストールが失敗したときに発火します。
CapacitorUpdater.addListener('updateFailed', (event) => { console.error('Update failed to install'); console.log('Failed bundle:', event.bundle); // Handle rollback or retry logic});イベントデータ:
bundle: BundleInfo - インストールに失敗したバンドルに関する情報
downloadFailed
Section titled “downloadFailed”バンドルのダウンロードが失敗したときに発火します。
CapacitorUpdater.addListener('downloadFailed', (event) => { console.error('Download failed for version:', event.version); // Handle download retry logic});イベントデータ:
version: string - ダウンロードに失敗したバージョン
appReloaded
Section titled “appReloaded”アプリがリロードされたときに発火します。
CapacitorUpdater.addListener('appReloaded', () => { console.log('App has been reloaded'); // Perform any necessary reinitialization});イベントデータ: なし
appReady
Section titled “appReady”更新後にアプリが使用可能になったときに発火します。
CapacitorUpdater.addListener('appReady', (event) => { console.log('App is ready'); console.log('Current bundle:', event.bundle); console.log('Status:', event.status);});イベントデータ:
bundle: BundleInfo - 現在のバンドルに関する情報status: string - 準備完了ステータス
BundleInfoオブジェクト
Section titled “BundleInfoオブジェクト”多くのイベントには、次のプロパティを持つBundleInfoオブジェクトが含まれています:
interface BundleInfo { id: string; // Unique bundle identifier version: string; // Bundle version downloaded: string; // Download timestamp checksum?: string; // Bundle checksum (if available) status: BundleStatus; // Bundle status}Where BundleStatus can be:
'success'- Bundle downloaded successfully'error'- Bundle download/installation failed'pending'- Bundle is pending to be set as next'downloading'- Bundle is currently downloading
例:完全な更新フロー
Section titled “例:完全な更新フロー”イベントを使用して完全な更新フローを処理する例を以下に示します:
import { CapacitorUpdater } from '@capgo/capacitor-updater';
export class UpdateManager { private listeners: any[] = [];
async setupListeners() { // Listen for available updates this.listeners.push( await CapacitorUpdater.addListener('updateAvailable', async (event) => { console.log('Update available:', event.bundle.version); // Auto-download the update await CapacitorUpdater.download({ url: event.bundle.url, version: event.bundle.version }); }) );
// Monitor download progress this.listeners.push( await CapacitorUpdater.addListener('download', (event) => { console.log(`Downloading: ${event.percent}%`); // Update UI progress bar this.updateProgressBar(event.percent); }) );
// Handle download completion this.listeners.push( await CapacitorUpdater.addListener('downloadComplete', async (event) => { console.log('Download complete:', event.bundle.version); // Set as next bundle await CapacitorUpdater.next({ id: event.bundle.id }); }) );
// Handle failures this.listeners.push( await CapacitorUpdater.addListener('downloadFailed', (event) => { console.error('Download failed:', event.version); this.showError('Update download failed. Please try again later.'); }) );
this.listeners.push( await CapacitorUpdater.addListener('updateFailed', (event) => { console.error('Update installation failed:', event.bundle.version); this.showError('Update installation failed. The app has been rolled back.'); }) );
// Handle app ready this.listeners.push( await CapacitorUpdater.addListener('appReady', async (event) => { console.log('App ready with bundle:', event.bundle.version); }) ); }
cleanup() { // Remove all listeners when no longer needed this.listeners.forEach(listener => listener.remove()); this.listeners = []; }
private updateProgressBar(percent: number) { // Update your UI progress bar }
private showError(message: string) { // Show error to user }}ベストプラクティス
Section titled “ベストプラクティス”-
常に
notifyAppReady()を呼び出す: 自動更新を使用する場合、ロールバックを防ぐために、アプリの初期化後に常にこのメソッドを呼び出してください。 -
失敗を適切に処理する: ダウンロードおよび更新の失敗に対する適切なエラー処理を実装してください。
-
ユーザーフィードバックを提供する: ダウンロード進行状況イベントを使用して、ユーザーに更新の進行状況を表示してください。
-
リスナーをクリーンアップする: メモリリークを防ぐために、不要になったイベントリスナーを削除してください。
-
更新シナリオをテストする: 失敗、ロールバック、メジャーアップデートを含むさまざまな更新シナリオをテストしてください。