Getting Started with Electron Updater
설치 단계와 이 플러그인의 전체 마크다운 가이드를 포함한 설정 명령어를 복사하세요.
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.
이 가이드는 @capgo/electron-updater Electron 애플리케이션에서
사전 요구 사항
사전 요구 사항 섹션- Electron 20.0.0 이상
- Node.js 18 이상
- Capgo 계정 ( capgo.app)
설치
설치 섹션Capgo AI-Assisted Setup을 사용하여 플러그인을 설치할 수 있습니다. AI 도구에 Capgo 기능을 추가하려면 다음 명령어를 사용하세요:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-plugins그런 다음 다음 명령어를 사용하세요:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/electron-updater` plugin in my project.만약 Manual Setup을 선호한다면, 다음 명령어를 실행하고 아래의 플랫폼별 지침을 따르세요:
-
패키지를 설치하세요:
터미널 창 bun add @capgo/electron-updater -
Capgo 대시보드에서 앱 ID를 가져오세요. 아직 앱을 만들지 않았다면 다음 명령어를 실행하세요:
터미널 창 npx @capgo/cli@latest init
설정
설정Electron Updater는 세 가지 장소에서 설정이 필요합니다: 메인 프로세스, 로드 전 처리 스크립트, 렌더러 프로세스.
메인 프로세스
메인 프로세스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(); }});로드 전 처리 스크립트
로드 전 처리 스크립트import { exposeUpdaterAPI } from '@capgo/electron-updater/preload';
// Expose the updater API to the renderer processexposeUpdaterAPI();렌더러 프로세스
렌더러 프로세스// 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());Copy to clipboard
Youmust autoUpdate: truecall
// 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 });}이벤트를 듣기
이벤트를 듣는 섹션 제목이벤트를 통해 업데이트 진행 상황과 상태를 추적하세요.
// 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);});업데이트 배포
업데이트 배포 섹션 제목Capgo CLI를 사용하여 업데이트를 업로드하세요.
# Build your appnpm run build
# Upload to Capgonpx @capgo/cli@latest bundle upload --channel=production다음 체크 시 Electron 앱은 자동으로 새로운 번들을 다운로드하고 감지할 것입니다.
디버그 메뉴
디버그 메뉴 섹션 제목개발 중에 디버그 메뉴를 활성화하십시오:
const updater = new ElectronUpdater({ appId: 'YOUR_CAPGO_APP_ID', debugMenu: true, // Enable debug menu});Press Ctrl+Shift+D (또는 Cmd+Shift+D Mac에서 사용하는 경우) 디버그 메뉴를 열고:
- 현재 번들 정보를 확인하십시오
- 사용 가능한 번들을-switch
- builtin 버전으로 리셋
- 디바이스 및 채널 정보를 확인하십시오
설정 옵션
설정 옵션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)});다음 단계
다음 단계 섹션Getting Started with Electron Updater에서 계속
Getting Started with Electron Updater에서 계속하는 섹션__CAPGO_KEEP_0__ 참조 Getting Started with Electron Updater를 사용 중이라면 자연 플러그인 작업을 계획하기 위해 연결하세요. Using @capgo/electron-updater Using @capgo/electron-updater Capgo 플러그인 디렉토리 Capgo 플러그인 디렉토리 Capacitor 플러그인들에 의해 Capgo Capacitor 플러그인들에 의해 Capgo 플러그인 추가 또는 업데이트 플러그인 추가 또는 업데이트 아이오닉 엔터프라이즈 플러그인 대안 아이오닉 엔터프라이즈 플러그인 대안