keeweb/app/scripts/app.js

165 lines
5.7 KiB
JavaScript
Raw Normal View History

const Backbone = require('backbone');
2017-01-31 07:50:28 +01:00
const AppModel = require('./models/app-model');
const AppView = require('./views/app-view');
const AppSettingsModel = require('./models/app-settings-model');
const UpdateModel = require('./models/update-model');
const RuntimeDataModel = require('./models/runtime-data-model');
const FileInfoCollection = require('./collections/file-info-collection');
2017-01-31 07:50:28 +01:00
const KeyHandler = require('./comp/key-handler');
const IdleTracker = require('./comp/idle-tracker');
const PopupNotifier = require('./comp/popup-notifier');
const SingleInstanceChecker = require('./comp/single-instance-checker');
const AppRightsChecker = require('./comp/app-rights-checker');
2017-01-31 07:50:28 +01:00
const Alerts = require('./comp/alerts');
const Updater = require('./comp/updater');
const AuthReceiver = require('./comp/auth-receiver');
const ExportApi = require('./comp/export-api');
const SettingsManager = require('./comp/settings-manager');
2017-02-19 18:51:52 +01:00
const PluginManager = require('./plugins/plugin-manager');
2017-02-05 11:08:26 +01:00
const Launcher = require('./comp/launcher');
2018-08-30 22:16:31 +02:00
const FeatureTester = require('./comp/feature-tester');
2017-05-20 12:46:21 +02:00
const Timeouts = require('./const/timeouts');
const FeatureDetector = require('./util/feature-detector');
2017-01-31 07:50:28 +01:00
const KdbxwebInit = require('./util/kdbxweb-init');
const Locale = require('./util/locale');
2015-10-17 23:49:24 +02:00
2017-02-05 11:08:26 +01:00
const ready = Launcher && Launcher.ready || $;
ready(() => {
2017-08-31 18:56:11 +02:00
if (FeatureDetector.isPopup && AuthReceiver.receive() || FeatureDetector.isFrame) {
return;
2015-10-25 17:27:34 +01:00
}
2016-06-16 19:00:24 +02:00
loadMixins();
2015-10-17 23:49:24 +02:00
2017-02-05 11:08:26 +01:00
const appModel = new AppModel();
Promise.resolve()
.then(loadConfigs)
.then(initModules)
.then(loadRemoteConfig)
2017-05-16 22:56:52 +02:00
.then(ensureCanRun)
2017-05-16 21:26:25 +02:00
.then(showApp)
.then(postInit)
2017-05-16 21:26:25 +02:00
.catch(e => {
appModel.appLogger.error('Error starting app', e);
});
2017-02-05 11:08:26 +01:00
2016-06-16 19:00:24 +02:00
function loadMixins() {
require('./mixins/view');
require('./helpers');
}
2017-05-16 22:56:52 +02:00
function ensureCanRun() {
2018-08-30 22:21:57 +02:00
return FeatureTester.test()
2017-05-16 22:56:52 +02:00
.catch(e => {
Alerts.error({
header: Locale.appSettingsError,
2018-08-30 22:21:57 +02:00
body: Locale.appNotSupportedError + '<br/><br/>' + e,
2017-05-16 22:56:52 +02:00
buttons: [],
esc: false, enter: false, click: false
});
2018-08-30 22:21:57 +02:00
throw 'Feature testing failed: ' + e;
2017-05-16 22:56:52 +02:00
});
}
function loadConfigs() {
return Promise.all([
AppSettingsModel.instance.load(),
UpdateModel.instance.load(),
RuntimeDataModel.instance.load(),
FileInfoCollection.instance.load()
]);
}
2016-06-16 19:00:24 +02:00
function initModules() {
KeyHandler.init();
IdleTracker.init();
PopupNotifier.init();
2017-01-30 21:26:31 +01:00
KdbxwebInit.init();
2016-06-16 19:00:24 +02:00
window.kw = ExportApi;
return PluginManager.init();
2016-06-16 19:00:24 +02:00
}
function showSettingsLoadError() {
Alerts.error({
header: Locale.appSettingsError,
body: Locale.appSettingsErrorBody,
buttons: [],
esc: false, enter: false, click: false
});
}
function loadRemoteConfig() {
2017-05-16 21:26:25 +02:00
return Promise.resolve().then(() => {
SettingsManager.setBySettings(appModel.settings);
const configParam = getConfigParam();
if (configParam) {
2017-05-16 21:26:25 +02:00
return appModel.loadConfig(configParam).then(() => {
SettingsManager.setBySettings(appModel.settings);
2017-05-16 21:26:25 +02:00
}).catch(e => {
if (!appModel.settings.get('cacheConfigSettings')) {
showSettingsLoadError();
2017-05-16 21:26:25 +02:00
throw e;
}
});
}
});
}
2015-10-17 23:49:24 +02:00
function showApp() {
2018-08-30 22:21:57 +02:00
return Promise.resolve()
2018-08-30 22:16:31 +02:00
.then(() => {
const skipHttpsWarning = localStorage.skipHttpsWarning || appModel.settings.get('skipHttpsWarning');
const protocolIsInsecure = ['https:', 'file:', 'app:'].indexOf(location.protocol) < 0;
const hostIsInsecure = location.hostname !== 'localhost';
if (protocolIsInsecure && hostIsInsecure && !skipHttpsWarning) {
return new Promise(resolve => {
Alerts.error({
header: Locale.appSecWarn, icon: 'user-secret', esc: false, enter: false, click: false,
body: Locale.appSecWarnBody1 + '<br/><br/>' + Locale.appSecWarnBody2,
buttons: [
{result: '', title: Locale.appSecWarnBtn, error: true}
],
complete: () => {
showView();
resolve();
}
});
});
} else {
showView();
}
});
2016-06-16 19:00:24 +02:00
}
function postInit() {
Updater.init();
SingleInstanceChecker.init();
AppRightsChecker.init();
2017-05-20 12:46:21 +02:00
setTimeout(() => PluginManager.runAutoUpdate(), Timeouts.AutoUpdatePluginsAfterStart);
}
2016-06-16 19:00:24 +02:00
function showView() {
appModel.prepare();
2015-12-06 21:32:41 +01:00
new AppView({ model: appModel }).render();
Backbone.trigger('app-ready');
logStartupTime();
}
function logStartupTime() {
2017-02-19 20:19:03 +01:00
const time = Math.round(performance.now());
appModel.appLogger.info(`Started in ${time}ms ¯\\_(ツ)_/¯`);
2015-10-17 23:49:24 +02:00
}
2016-06-16 19:00:24 +02:00
function getConfigParam() {
2017-01-31 07:50:28 +01:00
const metaConfig = document.head.querySelector('meta[name=kw-config]');
if (metaConfig && metaConfig.content && metaConfig.content[0] !== '(') {
return metaConfig.content;
}
2017-01-31 07:50:28 +01:00
const match = location.search.match(/[?&]config=([^&]+)/i);
2016-06-16 19:00:24 +02:00
if (match && match[1]) {
return match[1];
}
}
2015-10-17 23:49:24 +02:00
});