mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-10-11 11:03:18 +02:00
cmd: fix error parsed from status
The `codes.Unimplemented` is only returned when the RPCs are not built. When the wallet is in an unexpected state, `codes.Unknown` is returned instead, so we need to catch it properly to make sure we return the right error msg.
This commit is contained in:
@@ -251,41 +251,47 @@ func printModifiedProtoJSON(resp proto.Message) {
|
||||
// to command actions.
|
||||
func actionDecorator(f func(*cli.Context) error) func(*cli.Context) error {
|
||||
return func(c *cli.Context) error {
|
||||
if err := f(c); err != nil {
|
||||
s, ok := status.FromError(err)
|
||||
err := f(c)
|
||||
|
||||
// If it's a command for the UnlockerService (like
|
||||
// 'create' or 'unlock') but the wallet is already
|
||||
// unlocked, then these methods aren't recognized any
|
||||
// more because this service is shut down after
|
||||
// successful unlock. That's why the code
|
||||
// 'Unimplemented' means something different for these
|
||||
// two commands.
|
||||
if s.Code() == codes.Unimplemented &&
|
||||
(c.Command.Name == "create" ||
|
||||
c.Command.Name == "unlock" ||
|
||||
c.Command.Name == "changepassword" ||
|
||||
c.Command.Name == "createwatchonly") {
|
||||
// Exit early if there's no error.
|
||||
if err == nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
return fmt.Errorf("Wallet is already unlocked")
|
||||
}
|
||||
// Try to parse the Status representatio from this error.
|
||||
s, ok := status.FromError(err)
|
||||
|
||||
// lnd might be active, but not possible to contact
|
||||
// using RPC if the wallet is encrypted. If we get
|
||||
// error code Unimplemented, it means that lnd is
|
||||
// running, but the RPC server is not active yet (only
|
||||
// WalletUnlocker server active) and most likely this
|
||||
// is because of an encrypted wallet.
|
||||
if ok && s.Code() == codes.Unimplemented {
|
||||
return fmt.Errorf("Wallet is encrypted. " +
|
||||
"Please unlock using 'lncli unlock', " +
|
||||
"or set password using 'lncli create'" +
|
||||
" if this is the first time starting " +
|
||||
"lnd.")
|
||||
}
|
||||
// If this cannot be represented by a Status, exit early.
|
||||
if !ok {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
||||
// If it's a command for the UnlockerService (like 'create' or
|
||||
// 'unlock') but the wallet is already unlocked, then these
|
||||
// methods aren't recognized any more because this service is
|
||||
// shut down after successful unlock.
|
||||
if s.Code() == codes.Unknown &&
|
||||
(c.Command.Name == "create" ||
|
||||
c.Command.Name == "unlock" ||
|
||||
c.Command.Name == "changepassword" ||
|
||||
c.Command.Name == "createwatchonly") {
|
||||
|
||||
return errors.New("wallet is already unlocked")
|
||||
}
|
||||
|
||||
// lnd might be active, but not possible to contact using RPC if
|
||||
// the wallet is encrypted. If we get error code Unknown, it
|
||||
// means that lnd is running, but the RPC server is not active
|
||||
// yet (only WalletUnlocker server active) and most likely this
|
||||
// is because of an encrypted wallet.
|
||||
if s.Code() == codes.Unknown {
|
||||
return errors.New("wallet is encrypted - please " +
|
||||
"unlock using 'lncli unlock', or set " +
|
||||
"password using 'lncli create' if this is " +
|
||||
"the first time starting lnd")
|
||||
}
|
||||
|
||||
return s.Err()
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user