__CAPGO_KEEP_0__
Salin prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/electron-updater`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/electron-updater/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
Panduan ini akan membantu Anda mengatur @capgo/electron-updater dalam aplikasi Electron Anda untuk memungkinkan pembaruan JavaScript/HTML/CSS secara langsung.
Persyaratan
Bagian berjudul “Persyaratan”- Electron 20.0.0 atau lebih tinggi
- Node.js 18 atau lebih tinggi
- Akun Capgo (daftar di capgo.app)
Pemasangan
Bagian berjudul “Pemasangan”-
Pasang paket:
Jendela terminal bun add @capgo/electron-updater -
Ambil ID Aplikasi Anda dari dashboard Capgo. Jika Anda belum membuat aplikasi, jalankan:
Jendela Terminal npx @capgo/cli@latest init
Pengaturan
Bagian berjudul “Pengaturan”Pembarui Electron memerlukan pengaturan di tiga tempat: proses utama, skrip pra-muat, dan proses renderer.
Proses Utama
Bagian berjudul “Proses Utama”import { app, BrowserWindow } from 'electron';import * as path from 'path';import { ElectronUpdater, setupIPCHandlers, setupEventForwarding,} from '@capgo/electron-updater';
// Create updater instance with your Capgo App IDconst updater = new ElectronUpdater({ appId: 'YOUR_CAPGO_APP_ID', // e.g., 'com.example.myapp' autoUpdate: true,});
app.whenReady().then(async () => { const mainWindow = new BrowserWindow({ width: 1200, height: 800, webPreferences: { preload: path.join(__dirname, 'preload.js'), contextIsolation: true, }, });
// Initialize updater with window and builtin path const builtinPath = path.join(__dirname, 'www/index.html'); await updater.initialize(mainWindow, builtinPath);
// Setup IPC communication between main and renderer setupIPCHandlers(updater); setupEventForwarding(updater, mainWindow);
// Load the current bundle (either builtin or downloaded update) await mainWindow.loadFile(updater.getCurrentBundlePath());});
app.on('window-all-closed', () => { if (process.platform !== 'darwin') { app.quit(); }});Skrip Pra-Muat
Bagian berjudul “Skrip Pra-Muat”import { exposeUpdaterAPI } from '@capgo/electron-updater/preload';
// Expose the updater API to the renderer processexposeUpdaterAPI();Proses Pemroses Renderer
Judul Bagian “Proses Pemroses Renderer”// renderer.ts (or in your app's entry point)import { requireUpdater } from '@capgo/electron-updater/renderer';
const updater = requireUpdater();
// CRITICAL: Call this on every app launch!// This confirms the bundle loaded successfully and prevents rollbackawait updater.notifyAppReady();
console.log('App ready, current bundle:', await updater.current());Mengecek Pembaruan
Mengecekkan PerbaruanDengan, updater secara otomatis memeriksa perbaruan. Anda juga dapat memicu pengecekan manual: autoUpdate: trueSalin ke clipboard
// Check for updates manuallyconst latest = await updater.getLatest();
if (latest.url && !latest.error) { console.log('Update available:', latest.version);
// Download the update const bundle = await updater.download({ url: latest.url, version: latest.version, checksum: latest.checksum, });
console.log('Downloaded bundle:', bundle.id);
// Option 1: Queue for next restart await updater.next({ id: bundle.id });
// Option 2: Apply immediately and reload // await updater.set({ id: bundle.id });}Bab yang berjudul “Mengikuti Acara”
Ikuti kemajuan dan status perbaruan dengan acara:Salin ke clipboard
// Download progressupdater.addListener('download', (event) => { console.log(`Download progress: ${event.percent}%`);});
// Update availableupdater.addListener('updateAvailable', (event) => { console.log('New version available:', event.bundle.version);});
// Download completedupdater.addListener('downloadComplete', (event) => { console.log('Download finished:', event.bundle.id);});
// Update failedupdater.addListener('updateFailed', (event) => { console.error('Update failed:', event.bundle.version);});Bab yang berjudul “Mengunggah Perbaruan”
Gunakan __CAPGO_KEEP_0__ __CAPGO_KEEP_1__ untuk mengunggah perbaruan:Use the Capgo CLI to upload updates:
# Build your appnpm run build
# Upload to Capgonpx @capgo/cli@latest bundle upload --channel=productionAplikasi Electron Anda akan secara otomatis mendeteksi dan mengunduh bundle baru pada saat cek berikutnya.
Menu Debug
Judul bagian “Menu Debug”Aktifkan menu debug selama pengembangan:
const updater = new ElectronUpdater({ appId: 'YOUR_CAPGO_APP_ID', debugMenu: true, // Enable debug menu});Tekan Ctrl+Shift+D (atau Cmd+Shift+D pada Mac) untuk membuka menu debug dan:
- Lihat informasi bundle saat ini
- Pindah antara bundle yang tersedia
- Kembali ke versi bawaan
- Lihat informasi perangkat dan saluran
Opsi Konfigurasi
Bagian berjudul “Opsi Konfigurasi”const updater = new ElectronUpdater({ // Required appId: 'com.example.app',
// Server URLs (defaults to Capgo Cloud) updateUrl: 'https://plugin.capgo.app/updates', channelUrl: 'https://plugin.capgo.app/channel_self', statsUrl: 'https://plugin.capgo.app/stats',
// Behavior autoUpdate: true, // Enable auto-updates appReadyTimeout: 10000, // MS before rollback (default: 10s) autoDeleteFailed: true, // Delete failed bundles autoDeletePrevious: true, // Delete old bundles after successful update
// Channels defaultChannel: 'production',
// Security publicKey: '...', // For end-to-end encryption
// Debug debugMenu: false, // Enable debug menu disableJSLogging: false, // Disable console logs
// Periodic Updates periodCheckDelay: 0, // Seconds between checks (0 = disabled, min 600)});Langkah-Langkah Selanjutnya
Bagian berjudul “Langkah-Langkah Selanjutnya”- API Referensi - Eksplor semua metode yang tersedia
- Saluran - Pelajari tentang saluran pengembangan
- Rollback - Pahami perlindungan rollback
Lanjutkan dari Getting Started dengan Electron Updater
Judul Bagian “Lanjutkan dari Getting Started dengan Electron Updater”Jika Anda menggunakan Getting Started dengan Electron Updater untuk merencanakan pekerjaan plugin native, hubungkannya dengan Menggunakan @capgo/electron-updater untuk kemampuan native di Menggunakan @capgo/electron-updater, Capgo Direktori Plugin untuk alur kerja produk di Capgo Direktori Plugin, Capacitor Plugin oleh Capgo untuk detail implementasi di Capacitor Plugin oleh Capgo, Menambahkan atau Mengupdate Plugin untuk detail implementasi dalam Menambahkan atau Mengupdate Plugin, dan Alternatif Plugin Enterprise Ionic untuk alur produk dalam Alternatif Plugin Enterprise Ionic.