Refactor configuration out into reusable files
This commit is contained in:
parent
ed831dacd0
commit
5e5ca80a6e
4 changed files with 84 additions and 55 deletions
|
@ -1,5 +1,6 @@
|
||||||
const autoUpdater = require('electron-updater').autoUpdater
|
const autoUpdater = require('electron-updater').autoUpdater
|
||||||
const { dialog } = require('electron');
|
const { dialog } = require('electron');
|
||||||
|
const config = require('./config');
|
||||||
|
|
||||||
const windowState = require('./window_state');
|
const windowState = require('./window_state');
|
||||||
|
|
||||||
|
@ -9,7 +10,7 @@ const autoUpdaterInterval = hour * 1000;
|
||||||
const RESTART_BUTTON = 0;
|
const RESTART_BUTTON = 0;
|
||||||
const LATER_BUTTON = 1;
|
const LATER_BUTTON = 1;
|
||||||
|
|
||||||
function autoUpdateDisabled(config) {
|
function autoUpdateDisabled() {
|
||||||
return process.mas || config.get('disableAutoUpdate');
|
return process.mas || config.get('disableAutoUpdate');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,8 +46,8 @@ function onError(error) {
|
||||||
console.log("Got an error while updating: ", error.stack);
|
console.log("Got an error while updating: ", error.stack);
|
||||||
}
|
}
|
||||||
|
|
||||||
function initializeAutoUpdater(config, localeMessages) {
|
function initializeAutoUpdater(localeMessages) {
|
||||||
if (autoUpdateDisabled(config)) {
|
if (autoUpdateDisabled()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
41
app/config.js
Normal file
41
app/config.js
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
const fs = require('fs');
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
console.log('reading package.json');
|
||||||
|
const jsonFile = fs.readFileSync(path.join(__dirname, '..', 'package.json'));
|
||||||
|
const package_json = JSON.parse(jsonFile, 'utf-8');
|
||||||
|
const environment = package_json.environment || process.env.NODE_ENV || 'development';
|
||||||
|
|
||||||
|
console.log('configuring');
|
||||||
|
|
||||||
|
// Set environment vars to configure node-config before requiring it
|
||||||
|
process.env.NODE_ENV = environment;
|
||||||
|
process.env.NODE_CONFIG_DIR = path.join(__dirname, '..', 'config');
|
||||||
|
|
||||||
|
if (environment === 'production') {
|
||||||
|
// harden production config against the local env
|
||||||
|
process.env.NODE_CONFIG = '';
|
||||||
|
process.env.NODE_CONFIG_STRICT_MODE = true;
|
||||||
|
process.env.HOSTNAME = '';
|
||||||
|
process.env.NODE_APP_INSTANCE = '';
|
||||||
|
process.env.ALLOW_CONFIG_MUTATIONS = '';
|
||||||
|
process.env.SUPPRESS_NO_CONFIG_WARNING = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
const config = require('config');
|
||||||
|
config.environment = environment;
|
||||||
|
|
||||||
|
// Log resulting env vars in use by config
|
||||||
|
[
|
||||||
|
'NODE_ENV',
|
||||||
|
'NODE_CONFIG_DIR',
|
||||||
|
'NODE_CONFIG',
|
||||||
|
'ALLOW_CONFIG_MUTATIONS',
|
||||||
|
'HOSTNAME',
|
||||||
|
'NODE_APP_INSTANCE',
|
||||||
|
'SUPPRESS_NO_CONFIG_WARNING'
|
||||||
|
].forEach(function(s) {
|
||||||
|
console.log(s + ' ' + config.util.getEnv(s));
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = config;
|
22
app/user_config.js
Normal file
22
app/user_config.js
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
const app = require('electron').app;
|
||||||
|
const path = require('path');
|
||||||
|
const ElectronConfig = require('electron-config');
|
||||||
|
|
||||||
|
const config = require('./config');
|
||||||
|
|
||||||
|
// use a separate data directory for development
|
||||||
|
if (config.has('storageProfile')) {
|
||||||
|
const userData = path.join(
|
||||||
|
app.getPath('appData'),
|
||||||
|
'Signal-' + config.get('storageProfile')
|
||||||
|
);
|
||||||
|
|
||||||
|
app.setPath('userData', userData);
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('userData ' + app.getPath('userData'));
|
||||||
|
|
||||||
|
// this needs to be below our update to the appData path
|
||||||
|
const userConfig = new ElectronConfig();
|
||||||
|
|
||||||
|
module.exports = userConfig;
|
69
main.js
69
main.js
|
@ -3,11 +3,9 @@ const app = electron.app
|
||||||
const BrowserWindow = electron.BrowserWindow
|
const BrowserWindow = electron.BrowserWindow
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
const url = require('url')
|
const url = require('url')
|
||||||
const fs = require('fs')
|
|
||||||
const ipc = electron.ipcMain;
|
const ipc = electron.ipcMain;
|
||||||
const Menu = electron.Menu;
|
const Menu = electron.Menu;
|
||||||
const shell = electron.shell;
|
const shell = electron.shell;
|
||||||
const ElectronConfig = require('electron-config');
|
|
||||||
|
|
||||||
const autoupdate = require('./app/autoupdate');
|
const autoupdate = require('./app/autoupdate');
|
||||||
const locale = require('./app/locale');
|
const locale = require('./app/locale');
|
||||||
|
@ -16,11 +14,13 @@ const windowState = require('./app/window_state');
|
||||||
console.log('setting AUMID');
|
console.log('setting AUMID');
|
||||||
app.setAppUserModelId('org.whispersystems.signal-desktop')
|
app.setAppUserModelId('org.whispersystems.signal-desktop')
|
||||||
|
|
||||||
console.log('reading package.json');
|
// Keep a global reference of the window object, if you don't, the window will
|
||||||
const package_json = JSON.parse(fs.readFileSync(path.join(__dirname, 'package.json'), 'utf-8'))
|
// be closed automatically when the JavaScript object is garbage collected.
|
||||||
const environment = package_json.environment || process.env.NODE_ENV || 'development';
|
let mainWindow
|
||||||
|
|
||||||
if (environment === 'production' && !process.mas) {
|
const config = require("./app/config");
|
||||||
|
|
||||||
|
if (config.environment === 'production' && !process.mas) {
|
||||||
console.log('making app single instance');
|
console.log('making app single instance');
|
||||||
var shouldQuit = app.makeSingleInstance(function(commandLine, workingDirectory) {
|
var shouldQuit = app.makeSingleInstance(function(commandLine, workingDirectory) {
|
||||||
// Someone tried to run a second instance, we should focus our window
|
// Someone tried to run a second instance, we should focus our window
|
||||||
|
@ -38,49 +38,10 @@ if (environment === 'production' && !process.mas) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('configuring');
|
const userConfig = require('./app/user_config');
|
||||||
// Set environment vars to configure node-config before requiring it
|
|
||||||
process.env.NODE_ENV = environment;
|
|
||||||
process.env.NODE_CONFIG_DIR = path.join(__dirname, 'config');
|
|
||||||
if (environment === 'production') {
|
|
||||||
// harden production config against the local env
|
|
||||||
process.env.NODE_CONFIG = '';
|
|
||||||
process.env.NODE_CONFIG_STRICT_MODE = true;
|
|
||||||
process.env.HOSTNAME = '';
|
|
||||||
process.env.NODE_APP_INSTANCE = '';
|
|
||||||
process.env.ALLOW_CONFIG_MUTATIONS = '';
|
|
||||||
process.env.SUPPRESS_NO_CONFIG_WARNING = '';
|
|
||||||
}
|
|
||||||
const config = require('config');
|
|
||||||
// Log resulting env vars in use by config
|
|
||||||
[
|
|
||||||
'NODE_ENV',
|
|
||||||
'NODE_CONFIG_DIR',
|
|
||||||
'NODE_CONFIG',
|
|
||||||
'ALLOW_CONFIG_MUTATIONS',
|
|
||||||
'HOSTNAME',
|
|
||||||
'NODE_APP_INSTANCE',
|
|
||||||
'SUPPRESS_NO_CONFIG_WARNING'
|
|
||||||
].forEach(function(s) {
|
|
||||||
console.log(s + ' ' + config.util.getEnv(s));
|
|
||||||
});
|
|
||||||
|
|
||||||
// use a separate data directory for development
|
|
||||||
if (config.has('storageProfile')) {
|
|
||||||
var userData = path.join(app.getPath('appData'), 'Signal-' + config.get('storageProfile'));
|
|
||||||
app.setPath('userData', userData);
|
|
||||||
}
|
|
||||||
console.log('userData ' + app.getPath('userData'));
|
|
||||||
|
|
||||||
// this needs to be below our update to the appData path
|
|
||||||
const userConfig = new ElectronConfig();
|
|
||||||
|
|
||||||
// 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 mainWindow
|
|
||||||
let windowConfig = userConfig.get('window');
|
let windowConfig = userConfig.get('window');
|
||||||
|
|
||||||
|
|
||||||
// Load locale - if we can't load messages for the current locale, we
|
// Load locale - if we can't load messages for the current locale, we
|
||||||
// default to 'en'
|
// default to 'en'
|
||||||
//
|
//
|
||||||
|
@ -154,13 +115,13 @@ function createWindow () {
|
||||||
version: app.getVersion(),
|
version: app.getVersion(),
|
||||||
buildExpiration: config.get('buildExpiration'),
|
buildExpiration: config.get('buildExpiration'),
|
||||||
serverUrl: config.get('serverUrl'),
|
serverUrl: config.get('serverUrl'),
|
||||||
environment: environment,
|
environment: config.environment,
|
||||||
node_version: process.versions.node
|
node_version: process.versions.node
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
if (environment === 'test') {
|
if (config.environment === 'test') {
|
||||||
mainWindow.loadURL(prepareURL([__dirname, 'test', 'index.html']));
|
mainWindow.loadURL(prepareURL([__dirname, 'test', 'index.html']));
|
||||||
} else {
|
} else {
|
||||||
mainWindow.loadURL(prepareURL([__dirname, 'background.html']));
|
mainWindow.loadURL(prepareURL([__dirname, 'background.html']));
|
||||||
|
@ -178,6 +139,7 @@ function createWindow () {
|
||||||
shell.openExternal(url)
|
shell.openExternal(url)
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
mainWindow.webContents.on('will-navigate', function(e) {
|
mainWindow.webContents.on('will-navigate', function(e) {
|
||||||
console.log('will-navigate');
|
console.log('will-navigate');
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
@ -185,11 +147,12 @@ function createWindow () {
|
||||||
|
|
||||||
// Emitted when the window is about to be closed.
|
// Emitted when the window is about to be closed.
|
||||||
mainWindow.on('close', function (e) {
|
mainWindow.on('close', function (e) {
|
||||||
if (process.platform === 'darwin' && !windowState.shouldQuit() && environment !== 'test') {
|
if (process.platform === 'darwin' && !windowState.shouldQuit() && config.environment !== 'test') {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
mainWindow.hide();
|
mainWindow.hide();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Emitted when the window is closed.
|
// Emitted when the window is closed.
|
||||||
mainWindow.on('closed', function () {
|
mainWindow.on('closed', function () {
|
||||||
// Dereference the window object, usually you would store windows
|
// Dereference the window object, usually you would store windows
|
||||||
|
@ -209,7 +172,7 @@ function createWindow () {
|
||||||
app.on('ready', function() {
|
app.on('ready', function() {
|
||||||
console.log('app ready');
|
console.log('app ready');
|
||||||
|
|
||||||
autoupdate.initializeAutoUpdater(config, messages);
|
autoupdate.initializeAutoUpdater(messages);
|
||||||
|
|
||||||
createWindow();
|
createWindow();
|
||||||
|
|
||||||
|
@ -219,9 +182,9 @@ app.on('ready', function() {
|
||||||
mainWindow.show();
|
mainWindow.show();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
const menu = Menu.buildFromTemplate(template);
|
const menu = Menu.buildFromTemplate(template);
|
||||||
Menu.setApplicationMenu(menu);
|
Menu.setApplicationMenu(menu);
|
||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
app.on('before-quit', function() {
|
app.on('before-quit', function() {
|
||||||
|
@ -232,7 +195,7 @@ app.on('before-quit', function() {
|
||||||
app.on('window-all-closed', function () {
|
app.on('window-all-closed', function () {
|
||||||
// On OS X it is common for applications and their menu bar
|
// On OS X it is common for applications and their menu bar
|
||||||
// to stay active until the user quits explicitly with Cmd + Q
|
// to stay active until the user quits explicitly with Cmd + Q
|
||||||
if (process.platform !== 'darwin' || environment === 'test') {
|
if (process.platform !== 'darwin' || config.environment === 'test') {
|
||||||
app.quit()
|
app.quit()
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -253,6 +216,7 @@ app.on('activate', function () {
|
||||||
ipc.on('set-badge-count', function(event, count) {
|
ipc.on('set-badge-count', function(event, count) {
|
||||||
app.setBadgeCount(count);
|
app.setBadgeCount(count);
|
||||||
});
|
});
|
||||||
|
|
||||||
ipc.on('draw-attention', function(event, count) {
|
ipc.on('draw-attention', function(event, count) {
|
||||||
if (process.platform === 'darwin') {
|
if (process.platform === 'darwin') {
|
||||||
app.dock.bounce();
|
app.dock.bounce();
|
||||||
|
@ -263,6 +227,7 @@ ipc.on('draw-attention', function(event, count) {
|
||||||
}, 1000);
|
}, 1000);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ipc.on('restart', function(event) {
|
ipc.on('restart', function(event) {
|
||||||
app.relaunch();
|
app.relaunch();
|
||||||
app.quit();
|
app.quit();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue