2018-03-09 22:59:12 +02:00
|
|
|
const { dialog } = require('electron')
|
2018-05-14 12:08:33 +02:00
|
|
|
const { shim } = require('lib/shim');
|
2018-03-09 22:59:12 +02:00
|
|
|
const { Logger } = require('lib/logger.js');
|
|
|
|
const { _ } = require('lib/locale.js');
|
2018-03-14 19:23:19 +02:00
|
|
|
const fetch = require('node-fetch');
|
2018-05-14 12:08:33 +02:00
|
|
|
const { fileExtension } = require('lib/path-utils.js');
|
2018-03-14 19:23:19 +02:00
|
|
|
const packageInfo = require('./packageInfo.js');
|
|
|
|
const compareVersions = require('compare-versions');
|
2018-01-31 00:35:50 +02:00
|
|
|
|
|
|
|
let autoUpdateLogger_ = new Logger();
|
|
|
|
let checkInBackground_ = false;
|
2018-02-16 01:05:04 +02:00
|
|
|
let isCheckingForUpdate_ = false;
|
|
|
|
let parentWindow_ = null;
|
2018-01-31 00:35:50 +02:00
|
|
|
|
2018-02-16 01:05:04 +02:00
|
|
|
function showErrorMessageBox(message) {
|
|
|
|
return dialog.showMessageBox(parentWindow_, {
|
2018-03-09 22:59:12 +02:00
|
|
|
type: 'error',
|
2018-02-16 01:05:04 +02:00
|
|
|
message: message,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function onCheckStarted() {
|
2018-03-09 22:59:12 +02:00
|
|
|
autoUpdateLogger_.info('checkForUpdates: Starting...');
|
2018-02-16 01:05:04 +02:00
|
|
|
isCheckingForUpdate_ = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function onCheckEnded() {
|
2018-03-09 22:59:12 +02:00
|
|
|
autoUpdateLogger_.info('checkForUpdates: Done.');
|
2018-02-16 01:05:04 +02:00
|
|
|
isCheckingForUpdate_ = false;
|
|
|
|
}
|
|
|
|
|
2018-03-14 19:23:19 +02:00
|
|
|
async function fetchLatestRelease() {
|
|
|
|
const response = await fetch('https://api.github.com/repos/laurent22/joplin/releases/latest');
|
2018-02-16 20:08:02 +02:00
|
|
|
|
2018-03-14 19:23:19 +02:00
|
|
|
if (!response.ok) {
|
|
|
|
const responseText = await response.text();
|
|
|
|
throw new Error('Cannot get latest release info: ' + responseText.substr(0,500));
|
2018-02-16 20:08:02 +02:00
|
|
|
}
|
|
|
|
|
2018-03-14 19:23:19 +02:00
|
|
|
const json = await response.json();
|
|
|
|
|
|
|
|
const version = json.tag_name.substr(1);
|
|
|
|
let downloadUrl = null;
|
|
|
|
const platform = process.platform;
|
|
|
|
for (let i = 0; i < json.assets.length; i++) {
|
|
|
|
const asset = json.assets[i];
|
|
|
|
let found = false;
|
2018-05-14 12:08:33 +02:00
|
|
|
const ext = fileExtension(asset.name);
|
|
|
|
if (platform === 'win32' && ext === 'exe') {
|
|
|
|
if (shim.isPortable()) {
|
|
|
|
found = asset.name == 'JoplinPortable.exe';
|
|
|
|
} else {
|
|
|
|
found = !!asset.name.match(/^Joplin-Setup-[\d.]+\.exe$/);
|
|
|
|
}
|
|
|
|
} else if (platform === 'darwin' && ext === 'dmg') {
|
2018-03-14 19:23:19 +02:00
|
|
|
found = true;
|
2018-05-14 12:08:33 +02:00
|
|
|
} else if (platform === 'linux' && ext === '.AppImage') {
|
2018-03-14 19:23:19 +02:00
|
|
|
found = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (found) {
|
|
|
|
downloadUrl = asset.browser_download_url;
|
|
|
|
break;
|
|
|
|
}
|
2018-02-06 15:11:59 +02:00
|
|
|
}
|
|
|
|
|
2018-03-14 19:23:19 +02:00
|
|
|
return {
|
|
|
|
version: version,
|
|
|
|
downloadUrl: downloadUrl,
|
|
|
|
notes: json.body,
|
2018-05-14 13:18:00 +02:00
|
|
|
pageUrl: json.html_url,
|
2018-03-14 19:23:19 +02:00
|
|
|
};
|
|
|
|
}
|
2018-01-31 00:35:50 +02:00
|
|
|
|
2018-02-16 01:05:04 +02:00
|
|
|
function checkForUpdates(inBackground, window, logFilePath) {
|
|
|
|
if (isCheckingForUpdate_) {
|
2018-03-09 22:59:12 +02:00
|
|
|
autoUpdateLogger_.info('checkForUpdates: Skipping check because it is already running');
|
2018-02-16 01:05:04 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
parentWindow_ = window;
|
|
|
|
|
|
|
|
onCheckStarted();
|
|
|
|
|
2018-01-31 00:35:50 +02:00
|
|
|
if (logFilePath && !autoUpdateLogger_.targets().length) {
|
|
|
|
autoUpdateLogger_ = new Logger();
|
2018-03-09 22:59:12 +02:00
|
|
|
autoUpdateLogger_.addTarget('file', { path: logFilePath });
|
2018-01-31 00:35:50 +02:00
|
|
|
autoUpdateLogger_.setLevel(Logger.LEVEL_DEBUG);
|
2018-03-09 22:59:12 +02:00
|
|
|
autoUpdateLogger_.info('checkForUpdates: Initializing...');
|
2018-01-31 00:35:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
checkInBackground_ = inBackground;
|
|
|
|
|
2018-03-14 19:23:19 +02:00
|
|
|
fetchLatestRelease().then(release => {
|
2018-05-14 13:18:00 +02:00
|
|
|
autoUpdateLogger_.info('Current version: ' + packageInfo.version);
|
|
|
|
autoUpdateLogger_.info('Latest version: ' + release.version);
|
|
|
|
|
2018-03-14 19:23:19 +02:00
|
|
|
if (compareVersions(release.version, packageInfo.version) <= 0) {
|
|
|
|
if (!checkInBackground_) dialog.showMessageBox({ message: _('Current version is up-to-date.') })
|
|
|
|
} else {
|
|
|
|
const releaseNotes = release.notes.trim() ? "\n\n" + release.notes.trim() : '';
|
|
|
|
|
|
|
|
const buttonIndex = dialog.showMessageBox(parentWindow_, {
|
|
|
|
type: 'info',
|
|
|
|
message: _('An update is available, do you want to download it now?' + releaseNotes),
|
|
|
|
buttons: [_('Yes'), _('No')]
|
|
|
|
});
|
|
|
|
|
2018-05-14 13:18:00 +02:00
|
|
|
if (buttonIndex === 0) require('electron').shell.openExternal(release.downloadUrl ? release.downloadUrl : release.pageUrl);
|
2018-03-14 19:23:19 +02:00
|
|
|
}
|
|
|
|
}).catch(error => {
|
2018-01-31 21:10:45 +02:00
|
|
|
autoUpdateLogger_.error(error);
|
2018-02-16 01:05:04 +02:00
|
|
|
if (!checkInBackground_) showErrorMessageBox(error.message);
|
2018-03-14 19:23:19 +02:00
|
|
|
}).then(() => {
|
2018-02-16 01:05:04 +02:00
|
|
|
onCheckEnded();
|
2018-03-14 19:23:19 +02:00
|
|
|
});
|
2018-01-31 00:35:50 +02:00
|
|
|
}
|
|
|
|
|
2018-03-09 22:59:12 +02:00
|
|
|
module.exports.checkForUpdates = checkForUpdates
|