Refactor configuration out into reusable files

pull/749/head
David Balatero 8 years ago committed by Scott Nonnenberg
parent ed831dacd0
commit 5e5ca80a6e
No known key found for this signature in database
GPG Key ID: A4931C09644C654B

@ -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;
} }

@ -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;

@ -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;

@ -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…
Cancel
Save