From 3c5337ea2579837a83d90cfa5154c71fd64e4a69 Mon Sep 17 00:00:00 2001 From: Tom Kirkpatrick Date: Wed, 5 Sep 2018 13:38:03 +0200 Subject: [PATCH] feat(grpc): ability to unlock remote wallet If when connecting to a remote wallet we detect that it is locked initialise the wallet unlocker to allow users to unlock their remote wallets. Fix #543 --- app/components/Onboarding/Onboarding.js | 18 +++++++++--------- app/lib/zap/controller.js | 10 +++------- app/reducers/onboarding.js | 1 + 3 files changed, 13 insertions(+), 16 deletions(-) diff --git a/app/components/Onboarding/Onboarding.js b/app/components/Onboarding/Onboarding.js index 37147c75..79083024 100644 --- a/app/components/Onboarding/Onboarding.js +++ b/app/components/Onboarding/Onboarding.js @@ -159,16 +159,16 @@ const Onboarding = ({ ) case 3: + // eslint-disable-next-line no-case-declarations + let message = 'It looks like you already have a wallet' + if (initWalletProps.loginProps.existingWalletDir && connectionType === 'local') { + message += ` (we found one at ${initWalletProps.loginProps.existingWalletDir})` + } else { + message += ` at ${connectionHost.split(':')[0]}` + } + message += '. Please enter your wallet password to unlock it.' return ( - + ) diff --git a/app/lib/zap/controller.js b/app/lib/zap/controller.js index b3592119..3eaab660 100644 --- a/app/lib/zap/controller.js +++ b/app/lib/zap/controller.js @@ -199,8 +199,7 @@ class ZapController { // which indicates that the requested operation is not implemented or not supported/enabled in the service. // See https://github.com/grpc/grpc-node/blob/master/packages/grpc-native-core/src/constants.js#L129 if (e.code === 12) { - errors.host = - 'Unable to connect to host. Please ensure wallet is unlocked before connecting.' + return this.startWalletUnlocker() } // Other error codes such as UNAVAILABLE most likely indicate that there is a problem with the host. @@ -336,11 +335,6 @@ class ZapController { this.startWalletUnlocker() }) - this.neutrino.on('lightning-grpc-active', () => { - mainLog.info('Lightning gRPC active') - this.startLightningWallet() - }) - this.neutrino.on('chain-sync-waiting', () => { mainLog.info('Neutrino sync waiting') this.sendMessage('lndSyncStatus', 'waiting') @@ -467,6 +461,7 @@ class ZapController { */ _registerIpcListeners() { ipcMain.on('startLnd', (event, options: onboardingOptions) => this.finishOnboarding(options)) + ipcMain.on('startLightningWallet', () => this.startLightningWallet()) } /** @@ -474,6 +469,7 @@ class ZapController { */ _removeIpcListeners() { ipcMain.removeAllListeners('startLnd') + ipcMain.removeAllListeners('startLightningWallet') ipcMain.removeAllListeners('walletUnlocker') ipcMain.removeAllListeners('lnd') } diff --git a/app/reducers/onboarding.js b/app/reducers/onboarding.js index e19d2e2e..e9fd1a1e 100644 --- a/app/reducers/onboarding.js +++ b/app/reducers/onboarding.js @@ -320,6 +320,7 @@ export const unlockWallet = wallet_password => dispatch => { export const walletUnlocked = () => dispatch => { dispatch({ type: WALLET_UNLOCKED }) dispatch({ type: ONBOARDING_FINISHED }) + ipcRenderer.send('startLightningWallet') } export const unlockWalletError = () => dispatch => {