Iniziare con Electron Updater
Copia un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
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.
Questa guida ti guida attraverso la configurazione di @capgo/electron-updater nel tuo'applicazione Electron per abilitare gli aggiornamenti in tempo reale di JavaScript/HTML/CSS.
Requisiti preliminari
Sezione intitolata “Requisiti preliminari”- Electron 20.0.0 o superiore
- Node.js 18 o superiore
- Un account Capgo (iscrivi ti al capgo.app)
Installazione
Sezione intitolata “Installazione”Puoi utilizzare la nostra configurazione assistita da AI per installare il plugin. Aggiungi le Capgo skills al tuo strumento AI utilizzando il seguente comando:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-pluginsPoi utilizza la seguente richiesta:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/electron-updater` plugin in my project.Se preferisci la configurazione manuale, installa il plugin eseguendo i seguenti comandi e segui le istruzioni specifiche del tuo platform di seguito:
-
Installa il pacchetto:
Finestra del terminale bun add @capgo/electron-updater -
Ottieni il tuo ID App da Capgo dashboard. Se non hai creato un'app ancora, esegui:
Finestra del terminale npx @capgo/cli@latest init
Configurazione
Sezione intitolata “Configurazione”L'aggiornatore di Electron richiede la configurazione in tre luoghi: processo principale, script di caricamento predefinito e processo di rendering.
Processo Principale
Sezione intitolata “Processo Principale”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(); }});Script di caricamento predefinito
Sezione intitolata “Preload Script”import { exposeUpdaterAPI } from '@capgo/electron-updater/preload';
// Expose the updater API to the renderer processexposeUpdaterAPI();Processo di rendering
Sezione intitolata “Processo di rendering”// 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());Controlla Aggiornamenti
Sezione intitolata “Controlla Aggiornamenti”Con autoUpdate: true, l'aggiornatore controlla automaticamente gli aggiornamenti. Puoi anche attivare controlli manuali:
// 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 });}Ascoltando Eventi
Sezione intitolata “Ascoltando Eventi”Segui il progresso e lo stato degli aggiornamenti con gli eventi:
// 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);});Distribuisci Aggiornamenti
Sezione intitolata “Distribuisci Aggiornamenti”Usa i Capgo CLI per caricare gli aggiornamenti:
# Build your appnpm run build
# Upload to Capgonpx @capgo/cli@latest bundle upload --channel=productionLa tua app Electron rileverà automaticamente e scaricherà il nuovo bundle alla prossima verifica.
Menu di debug
Sezione intitolata “Menu di debug”Abilita il menu di debug durante lo sviluppo:
const updater = new ElectronUpdater({ appId: 'YOUR_CAPGO_APP_ID', debugMenu: true, // Enable debug menu});Premi Ctrl+Shift+D (o Cmd+Shift+D su Mac) per aprire il menu di debug e:
- Visualizza informazioni sul bundle corrente
- Scegli tra le disponibilità dei bundle
- Ripristina alla versione predefinita
- Visualizza informazioni dispositivo e canale
Opzioni di configurazione
Sezione intitolata “Opzioni di configurazione”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)});Passaggi successivi
Sezione intitolata “Passaggi successivi”- API Riferimento - Esplora tutti i metodi disponibili
- Canali - Scopri i canali di distribuzione
- Ripristini - Comprende la protezione del ripristino
Continua da Getting Started with Electron Updater
Sezione intitolata “Continua da Getting Started with Electron Updater”Se stai utilizzando Getting Started with Electron Updater per pianificare il lavoro di plugin nativi, connettilo con Utilizzando @capgo/electron-updater per la capacità nativa in Utilizzando @capgo/electron-updater, Capgo Directory dei plugin per il flusso di lavoro del prodotto in Capgo Directory dei plugin, Capacitor Plugin da Capgo per i dettagli di implementazione in Capacitor Plugin da Capgo, Aggiungere o Aggiornare Plugin per i dettagli di implementazione in Aggiungere o Aggiornare Plugin, e Alternative Plugin per Enterprise Ionic per il workflow del prodotto in Alternative Plugin per Enterprise Ionic.