Electron Updater API 참조
이 플러그인의 설치 단계와 전체 마크다운 가이드를 포함한 설정 프롬프트를 복사하세요.
이 페이지는 Electron Updater의 모든 사용 가능한 메서드, 이벤트 및 구성 옵션을 문서화합니다.
기본 메서드
기본 메서드모든 앱 런치 시 호출해야 합니다.
성공적으로 패키지가 로드되었는지 확인하고 자동 롤백을 방지합니다.클립보드에 복사 주의: 사용에 주의가 필요합니다.
await updater.notifyAppReady();__CAPGO_KEEP_0__(options)
제목 "__CAPGO_KEEP_0__(options)"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});매개 변수:
| 옵션 | 타입 | 필수 | 설명 |
|---|---|---|---|
url | __CAPGO_KEEP_0__ | __CAPGO_KEEP_1__ | __CAPGO_KEEP_2__ |
version | __CAPGO_KEEP_0__ | __CAPGO_KEEP_1__ | __CAPGO_KEEP_3__ |
checksum | __CAPGO_KEEP_4__ | __CAPGO_KEEP_5__ | __CAPGO_KEEP_6__ |
sessionKey | __CAPGO_KEEP_7__ | __CAPGO_KEEP_8__ | __CAPGO_KEEP_9__ |
반환: BundleInfo 객체에 id, version, status
next(options)
next(options) 제목앱이 다시 시작될 때 다음으로 로드될 배포를 큐에 추가합니다.
await updater.next({ id: 'bundle-id' });매개 변수:
| 옵션 | 타입 | 필수 | 설명 |
|---|---|---|---|
id | 문자열 | 네 | Bundle ID를 큐에 추가 |
__CAPGO_KEEP_0__
set(options) 섹션즉시 앱을 재로드하고 Bundle로 Switch합니다.
await updater.set({ id: 'bundle-id' });매개 변수:
| 옵션 | 타입 | 필수 | 설명 |
|---|---|---|---|
id | 문자열 | Yes | Bundle ID to activate |
reload()
Section titled “reload()”Manually reload the app with the current bundle.
await updater.reload();Section titled “”
Section titled “delete(options)”Copy to clipboard
await updater.delete({ id: 'bundle-id' });Parameters:
| Option | 타입 | 필수 | 설명 |
|---|---|---|---|
id | string | Yes | 삭제할 번들 ID |
reset(options)
섹션 제목 “reset(options)”기본 버전 또는 마지막 성공 번들을 복원합니다.
// Reset to builtinawait updater.reset({ toLastSuccessful: false });
// Reset to last successful bundleawait updater.reset({ toLastSuccessful: true });매개 변수:
| 옵션 | 타입 | 필수 | 설명 |
|---|---|---|---|
toLastSuccessful | boolean | 아니요 | true가면 마지막 성공한 번들로 리셋합니다. |
번들 정보
번들 정보 섹션현재()
현재() 섹션현재 번들 및 네이티브 버전 정보를 가져옵니다.
const info = await updater.current();// { bundle: { id, version, status }, native: '1.0.0' }__CAPGO_KEEP_0__
__CAPGO_KEEP_1____CAPGO_KEEP_2__
const bundles = await updater.list();// [{ id, version, status, downloaded, checksum }, ...]__CAPGO_KEEP_4__
__CAPGO_KEEP_5____CAPGO_KEEP_6__
const next = await updater.getNextBundle();// { id, version, status } or null__CAPGO_KEEP_8__
__CAPGO_KEEP_9____CAPGO_KEEP_10__
const failed = await updater.getFailedUpdate();// { id, version, reason } or nullgetBuiltinVersion()
getBuiltinVersion() 섹션앱 바이너리와 함께 제공되는 버전을 가져옵니다.
const version = await updater.getBuiltinVersion();// '1.0.0'업데이트 확인
업데이트 확인 섹션getLatest(options)
getLatest(options) 섹션서버에서 가장 최신 버전을 확인합니다.
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 | 문자열 | 다운로드 URL (업데이트가 없으면 빈 문자열) |
version | 문자열 | 사용 가능한 버전 |
checksum | SHA256 체크섬 | 암호화 세션 키 |
sessionKey | 체크 실패 시 오류 메시지 | __CAPGO_KEEP_0__ |
error | __CAPGO_KEEP_1__ | __CAPGO_KEEP_2__ |
message | string | 서버 메시지 |
채널 관리
채널 관리채널을 특정 채널에 할당합니다.
복사채널 할당을 취소하고 기본값을 사용합니다.
await updater.setChannel({ channel: 'beta' });__CAPGO_KEEP_0__
__CAPGO_KEEP_0____CAPGO_KEEP_0__
await updater.unsetChannel();getChannel()
getChannel() 섹션현재 채널 assignments을 가져옵니다.
const channel = await updater.getChannel();// { channel: 'production', status: 'set' }listChannels()
listChannels() 섹션이 앱에 사용 가능한 모든 채널을 목록화합니다.
const channels = await updater.listChannels();// ['production', 'beta', 'staging']다운로드 된 업데이트를 적용하는 시기를 제어합니다.
setMultiDelay(options)멀티 딜레이 옵션을 설정합니다.
Copy to clipboard
setMultiDelay(options)업데이트가 적용되기 전에 충족해야 하는 조건을 설정합니다.
// Wait for app to be backgroundedawait updater.setMultiDelay({ delayConditions: [{ kind: 'background' }]});
// Wait until specific dateawait updater.setMultiDelay({ delayConditions: [{ kind: 'date', value: '2024-12-25T00:00:00Z' }]});
// Wait for app to be killed and restartedawait 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 | - | 앱이 종료되고 다시 시작되기를 기다립니다. |
date | ISO 날짜 문자열 | 특정 날짜/시간까지 기다립니다. |
nativeVersion | 버전 문자열 | 네이티브 앱 업데이트 기다리기 |
cancelDelay()
cancelDelay() 섹션즉시 업데이트 적용을 위해 다음 체크 시 모든 지연 조건을 취소합니다.
await updater.cancelDelay();기기 식별
기기 식별 섹션getDeviceId()
getDeviceId() 섹션기기 고유 식별자를 가져옵니다.
const deviceId = await updater.getDeviceId();// 'uuid-xxxx-xxxx-xxxx'__CAPGO_KEEP_0__
__CAPGO_KEEP_1____CAPGO_KEEP_2__
await updater.setCustomId({ customId: 'user-123' });__CAPGO_KEEP_4__
__CAPGO_KEEP_5____CAPGO_KEEP_6__
__CAPGO_KEEP_7____CAPGO_KEEP_8__
await updater.setUpdateUrl({ url: 'https://my-server.com/updates' });setStatsUrl(options)
'setStatsUrl(options)' 제목통계 보고 URL을 변경합니다.
await updater.setStatsUrl({ url: 'https://my-server.com/stats' });setChannelUrl(options)
'setChannelUrl(options)' 제목채널 관리 URL을 변경합니다.
await updater.setChannelUrl({ url: 'https://my-server.com/channel' });setAppId(options)
'setAppId(options)' 제목runtime에서 App ID를 변경하세요.
await updater.setAppId({ appId: 'com.example.newapp' });getAppId()
getAppId()라는 제목의 섹션현재 App ID를 가져옵니다.
const appId = await updater.getAppId();debug
Debug라는 제목의 섹션setDebugMenu(options)
setDebug 메뉴 설정하기Debug 메뉴를 사용하거나 비활성화합니다.
await updater.setDebugMenu({ enabled: true });isDebugMenuEnabled()
Debug 메뉴가 활성화되어 있는지 확인합니다.클립보드에 복사
const enabled = await updater.isDebugMenuEnabled();Debug 메뉴 업데이트 이벤트를 듣기 위해
클립보드에 복사이벤트 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 | {} | 앱이 다시 로드되었습니다 |
appReady | {} | notifyAppReady() __CAPGO_KEEP_0__가 호출되었습니다 |
예시: 전체 이벤트 처리
예시: 전체 이벤트 처리// Progress trackingupdater.addListener('download', (event) => { updateProgressBar(event.percent);});
// Update available notificationupdater.addListener('updateAvailable', (event) => { showNotification(`Update ${event.bundle.version} available!`);});
// Handle completionupdater.addListener('downloadComplete', async (event) => { // Queue for next restart await updater.next({ id: event.bundle.id }); showNotification('Update will apply on next restart');});
// Handle failuresupdater.addListener('updateFailed', (event) => { console.error('Update failed:', event.reason); reportError(event);});생성자 옵션
생성자 옵션전체 구성 옵션 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)});API Electron Updater에서 계속하기
Section titled “Keep going from Electron Updater API Reference”Capgo를 사용 중이라면 Electron Updater API 참고문서 API 대시보드와 운영을 계획하고 연결하세요. @capgo/electron-updater를 사용하여 @capgo/electron-updater를 사용하여 Native 기능을 구현하는 경우, API 개요 API 개요에서 구현 세부 정보를 참조하세요. 소개 소개에서 구현 세부 정보를 참조하세요. API 키 API 키에서 구현 세부 정보를 참조하세요. 그리고 기기 기기에서 구현 세부 정보를 참조하세요.