|
|
|
/**
|
|
|
|
* This module executes inside of electron's main process. You can start
|
|
|
|
* electron renderer process from here and communicate with the other processes
|
|
|
|
* through IPC.
|
|
|
|
*
|
|
|
|
* When running `npm run build` or `npm run build-main`, this file is compiled to
|
|
|
|
* `./app/main.prod.js` using webpack. This gives us some performance wins.
|
|
|
|
*/
|
|
|
|
import { app, BrowserWindow, session } from 'electron'
|
|
|
|
import { mainLog } from './utils/log'
|
|
|
|
import MenuBuilder from './menu'
|
|
|
|
import ZapController from './zap'
|
|
|
|
import lnd from './lnd'
|
|
|
|
|
|
|
|
// Set up a couple of timers to track the app startup progress.
|
|
|
|
mainLog.time('Time until app is ready')
|
|
|
|
mainLog.time('Time until lnd process lookup finished')
|
|
|
|
|
|
|
|
// Determine wether we should start our own lnd process or connect to one that is already running.
|
|
|
|
const zapMode = lnd
|
|
|
|
.isLndRunning()
|
|
|
|
.then(res => {
|
|
|
|
mainLog.debug('lnd already running: %s', res)
|
|
|
|
mainLog.timeEnd('Time until lnd process lookup finished')
|
|
|
|
return res ? 'external' : 'internal'
|
|
|
|
})
|
|
|
|
.catch(mainLog.error)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize Zap as soon as electron is ready.
|
|
|
|
*/
|
|
|
|
app.on('ready', () => {
|
|
|
|
mainLog.timeEnd('Time until app is ready')
|
|
|
|
|
|
|
|
// Start a couple more timers to track the app loading time.
|
|
|
|
mainLog.time('Time until app is visible')
|
|
|
|
mainLog.time('Time until onboarding has started')
|
|
|
|
|
|
|
|
// Create the electron browser window.
|
|
|
|
const mainWindow = new BrowserWindow({
|
|
|
|
show: false,
|
|
|
|
titleBarStyle: 'hidden',
|
|
|
|
width: 950,
|
|
|
|
height: 600,
|
|
|
|
minWidth: 950,
|
|
|
|
minHeight: 425,
|
|
|
|
backgroundColor: '#1c1e26'
|
|
|
|
})
|
|
|
|
|
|
|
|
// Initialise the application.
|
|
|
|
const zap = new ZapController(mainWindow, zapMode)
|
|
|
|
zap.init()
|
|
|
|
|
|
|
|
// Initialise the application menus.
|
|
|
|
const menuBuilder = new MenuBuilder(mainWindow)
|
|
|
|
menuBuilder.buildMenu()
|
|
|
|
|
|
|
|
/**
|
|
|
|
* In production mode, enable source map support.
|
|
|
|
*/
|
|
|
|
if (process.env.NODE_ENV === 'production') {
|
|
|
|
const sourceMapSupport = require('source-map-support') // eslint-disable-line global-require
|
|
|
|
sourceMapSupport.install()
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* In development mode or when DEBUG_PROD is set, enable debugging tools.
|
|
|
|
*/
|
|
|
|
if (process.env.NODE_ENV === 'development' || process.env.DEBUG_PROD === 'true') {
|
|
|
|
// eslint-disable global-require
|
|
|
|
require('electron-debug')()
|
|
|
|
const installer = require('electron-devtools-installer')
|
|
|
|
const forceDownload = !!process.env.UPGRADE_EXTENSIONS
|
|
|
|
const extensions = ['REACT_DEVELOPER_TOOLS', 'REDUX_DEVTOOLS']
|
|
|
|
|
|
|
|
Promise.all(extensions.map(name => installer.default(installer[name], forceDownload))).catch(
|
|
|
|
mainLog.error
|
|
|
|
)
|
|
|
|
|
|
|
|
mainWindow.webContents.once('dom-ready', () => {
|
|
|
|
mainWindow.openDevTools()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add application event listener:
|
|
|
|
* - Kill lnd process is killed when the app quits.
|
|
|
|
*/
|
|
|
|
app.on('quit', () => {
|
|
|
|
mainLog.debug('app.quit')
|
|
|
|
if (zap.neutrino) {
|
|
|
|
zap.neutrino.stop()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add application event listener:
|
|
|
|
* - Open zap payment form when lightning url is opened
|
|
|
|
*/
|
|
|
|
app.setAsDefaultProtocolClient('lightning')
|
|
|
|
app.on('open-url', (event, url) => {
|
|
|
|
mainLog.debug('open-url')
|
|
|
|
event.preventDefault()
|
|
|
|
const payreq = url.split(':')[1]
|
|
|
|
zap.sendMessage('lightningPaymentUri', { payreq })
|
|
|
|
mainWindow.show()
|
|
|
|
})
|
|
|
|
|
|
|
|
// HACK: patch webrequest to fix devtools incompatibility with electron 2.x.
|
|
|
|
// See https://github.com/electron/electron/issues/13008#issuecomment-400261941
|
|
|
|
session.defaultSession.webRequest.onBeforeRequest({}, (details, callback) => {
|
|
|
|
if (details.url.indexOf('7accc8730b0f99b5e7c0702ea89d1fa7c17bfe33') !== -1) {
|
|
|
|
callback({
|
|
|
|
redirectURL: details.url.replace(
|
|
|
|
'7accc8730b0f99b5e7c0702ea89d1fa7c17bfe33',
|
|
|
|
'57c9d07b416b5a2ea23d28247300e4af36329bdc'
|
|
|
|
)
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
callback({ cancel: false })
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add application event listener:
|
|
|
|
* - quit app when window is closed
|
|
|
|
*/
|
|
|
|
app.on('window-all-closed', () => {
|
|
|
|
mainLog.debug('app.window-all-closed')
|
|
|
|
// Respect the OSX convention of having the application in memory even after all windows have been closed
|
|
|
|
if (process.platform !== 'darwin') {
|
|
|
|
app.quit()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|