Browse Source

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
renovate/lint-staged-8.x
Tom Kirkpatrick 6 years ago
parent
commit
3c5337ea25
No known key found for this signature in database GPG Key ID: 72203A8EC5967EA8
  1. 18
      app/components/Onboarding/Onboarding.js
  2. 10
      app/lib/zap/controller.js
  3. 1
      app/reducers/onboarding.js

18
app/components/Onboarding/Onboarding.js

@ -159,16 +159,16 @@ const Onboarding = ({
</FormContainer> </FormContainer>
) )
case 3: 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 ( return (
<FormContainer <FormContainer title="Welcome back!" description={`${message}`} back={null} next={null}>
title="Welcome back!"
description={`It looks like you already have a wallet
${Boolean(initWalletProps.loginProps.existingWalletDir) &&
`(we found one at \`${initWalletProps.loginProps.existingWalletDir}\`)`}.
Please enter your wallet password to unlock it.`}
back={null}
next={null}
>
<Login {...initWalletProps.loginProps} /> <Login {...initWalletProps.loginProps} />
</FormContainer> </FormContainer>
) )

10
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. // 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 // See https://github.com/grpc/grpc-node/blob/master/packages/grpc-native-core/src/constants.js#L129
if (e.code === 12) { if (e.code === 12) {
errors.host = return this.startWalletUnlocker()
'Unable to connect to host. Please ensure wallet is unlocked before connecting.'
} }
// Other error codes such as UNAVAILABLE most likely indicate that there is a problem with the host. // 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.startWalletUnlocker()
}) })
this.neutrino.on('lightning-grpc-active', () => {
mainLog.info('Lightning gRPC active')
this.startLightningWallet()
})
this.neutrino.on('chain-sync-waiting', () => { this.neutrino.on('chain-sync-waiting', () => {
mainLog.info('Neutrino sync waiting') mainLog.info('Neutrino sync waiting')
this.sendMessage('lndSyncStatus', 'waiting') this.sendMessage('lndSyncStatus', 'waiting')
@ -467,6 +461,7 @@ class ZapController {
*/ */
_registerIpcListeners() { _registerIpcListeners() {
ipcMain.on('startLnd', (event, options: onboardingOptions) => this.finishOnboarding(options)) ipcMain.on('startLnd', (event, options: onboardingOptions) => this.finishOnboarding(options))
ipcMain.on('startLightningWallet', () => this.startLightningWallet())
} }
/** /**
@ -474,6 +469,7 @@ class ZapController {
*/ */
_removeIpcListeners() { _removeIpcListeners() {
ipcMain.removeAllListeners('startLnd') ipcMain.removeAllListeners('startLnd')
ipcMain.removeAllListeners('startLightningWallet')
ipcMain.removeAllListeners('walletUnlocker') ipcMain.removeAllListeners('walletUnlocker')
ipcMain.removeAllListeners('lnd') ipcMain.removeAllListeners('lnd')
} }

1
app/reducers/onboarding.js

@ -320,6 +320,7 @@ export const unlockWallet = wallet_password => dispatch => {
export const walletUnlocked = () => dispatch => { export const walletUnlocked = () => dispatch => {
dispatch({ type: WALLET_UNLOCKED }) dispatch({ type: WALLET_UNLOCKED })
dispatch({ type: ONBOARDING_FINISHED }) dispatch({ type: ONBOARDING_FINISHED })
ipcRenderer.send('startLightningWallet')
} }
export const unlockWalletError = () => dispatch => { export const unlockWalletError = () => dispatch => {

Loading…
Cancel
Save