This repository was archived by the owner on Mar 13, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathmain.js
122 lines (98 loc) · 4.02 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
const { app, BrowserWindow, autoUpdater, ipcMain, dialog } = require("electron")
const { accountId, productId, getLicenses, resetValidatedLicenses } = require("./keygen")
const path = require("path")
const url = require("url")
const { platform, env } = process
// Keep a global reference of the window object, if you don't, the window will
// be closed automatically when the JavaScript object is garbage collected.
let win
// Keep a timestamp of when the last update occured
let lastUpdateAttemptAt
function createWindow() {
// Create the browser window.
win = new BrowserWindow({ width: 800, height: 600 })
if (env.NODE_ENV === 'development') {
win.webContents.openDevTools()
}
// Load the login page by default.
win.loadURL(`file://${__dirname}/login.html`)
// Load the login page when user is unauthenticated.
ipcMain.on("unauthenticated", (event) => {
resetValidatedLicenses()
win.loadURL(`file://${__dirname}/login.html`)
})
// Load our app when user is authenticated.
ipcMain.on("authenticated", async event => {
win.loadURL(`file://${__dirname}/index.html`)
if (env.NODE_ENV === 'development') {
return // Skip updates on development env
}
// Attempt to update the app after the user is authenticated
const { licenses } = await getLicenses()
if (!Object.values(licenses).some(l => Object.keys(l).length)) {
return
}
// Use first available license key that's valid for updates
const [license] = Object.values(licenses).filter(l => l.meta && l.meta.valid)
if (!license) {
return
}
if (lastUpdateAttemptAt != null && ((+new Date) - lastUpdateAttemptAt) < 43200000 /* every 12 hours */) {
return
} else {
lastUpdateAttemptAt = +new Date
}
const { key } = license.data.attributes
autoUpdater.setFeedURL(`https://dist.keygen.sh/v1/${accountId}/${productId}/update/${platform}/zip/${app.getVersion()}?key=${key}`)
autoUpdater.on('error', err => win.webContents.send('error', err))
autoUpdater.on('checking-for-update', () => win.webContents.send('log', 'checking-for-update', autoUpdater.getFeedURL()))
autoUpdater.on('update-available', () => win.webContents.send('log', 'update-available', autoUpdater.getFeedURL()))
autoUpdater.on('update-not-available', () => win.webContents.send('log', 'update-not-available', autoUpdater.getFeedURL()))
autoUpdater.on('update-downloaded', (...args) => {
win.webContents.send('log', 'update-downloaded', autoUpdater.getFeedURL(), args)
const choice = dialog.showMessageBox(win, {
message: 'An update has been downloaded. Do you want to restart now to finish installing it?',
title: 'Update is ready',
type: 'question',
buttons: [
'Yes',
'No'
]
})
if (choice === 0) {
autoUpdater.quitAndInstall()
}
})
autoUpdater.checkForUpdates()
})
// Open the DevTools.
// win.webContents.openDevTools()
// Emitted when the window is closed.
win.on("closed", () => {
// Dereference the window object, usually you would store windows
// in an array if your app supports multi windows, this is the time
// when you should delete the corresponding element.
win = null
})
}
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.on("ready", createWindow)
// Quit when all windows are closed.
app.on("window-all-closed", () => {
// On OS X it is common for applications and their menu bar
// to stay active until the user quits explicitly with Cmd + Q
if (process.platform !== "darwin") {
app.quit()
}
})
app.on("activate", () => {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (win === null) {
createWindow()
}
})
// In this file you can include the rest of your app's specific main process
// code. You can also put them in separate files and require them here.