summaryrefslogtreecommitdiffhomepage
path: root/packages/desktop-electron/src
diff options
context:
space:
mode:
Diffstat (limited to 'packages/desktop-electron/src')
-rw-r--r--packages/desktop-electron/src/main/index.ts21
-rw-r--r--packages/desktop-electron/src/renderer/index.tsx2
2 files changed, 18 insertions, 5 deletions
diff --git a/packages/desktop-electron/src/main/index.ts b/packages/desktop-electron/src/main/index.ts
index ae9f58118..c9f16606a 100644
--- a/packages/desktop-electron/src/main/index.ts
+++ b/packages/desktop-electron/src/main/index.ts
@@ -337,11 +337,16 @@ function setupAutoUpdater() {
})
}
-let updateReady = false
+let downloadedUpdateVersion: string | undefined
async function checkUpdate() {
if (!UPDATER_ENABLED) return { updateAvailable: false }
- updateReady = false
+ if (downloadedUpdateVersion) {
+ logger.log("returning cached downloaded update", {
+ version: downloadedUpdateVersion,
+ })
+ return { updateAvailable: true, version: downloadedUpdateVersion }
+ }
logger.log("checking for updates", {
currentVersion: app.getVersion(),
channel: autoUpdater.channel,
@@ -367,7 +372,7 @@ async function checkUpdate() {
logger.log("update available", { version })
await autoUpdater.downloadUpdate()
logger.log("update download completed", { version })
- updateReady = true
+ downloadedUpdateVersion = version
return { updateAvailable: true, version }
} catch (error) {
logger.error("update check failed", error)
@@ -376,7 +381,15 @@ async function checkUpdate() {
}
async function installUpdate() {
- if (!updateReady) return
+ if (!downloadedUpdateVersion) {
+ logger.log("install update skipped", {
+ reason: "no downloaded update ready",
+ })
+ return
+ }
+ logger.log("installing downloaded update", {
+ version: downloadedUpdateVersion,
+ })
killSidecar()
autoUpdater.quitAndInstall()
}
diff --git a/packages/desktop-electron/src/renderer/index.tsx b/packages/desktop-electron/src/renderer/index.tsx
index 56fe9fa51..91ea1ae07 100644
--- a/packages/desktop-electron/src/renderer/index.tsx
+++ b/packages/desktop-electron/src/renderer/index.tsx
@@ -170,7 +170,7 @@ const createPlatform = (): Platform => {
return window.api.checkUpdate()
},
- update: async () => {
+ updateAndRestart: async () => {
const config = await window.api.getWindowConfig().catch(() => ({ updaterEnabled: false }))
if (!config.updaterEnabled) return
await window.api.installUpdate()