rpc: recognize the new unused prefix address types

This commit is contained in:
Olaoluwa Osuntokun 2019-02-19 19:17:46 -08:00
parent 8c1181af3b
commit 65cdb1294e
No known key found for this signature in database
GPG Key ID: CE58F7F8E20FD9A2
2 changed files with 38 additions and 8 deletions

@ -226,6 +226,11 @@ func (m *mockWalletController) NewAddress(addrType lnwallet.AddressType,
m.rootKey.PubKey().SerializeCompressed(), &chaincfg.MainNetParams) m.rootKey.PubKey().SerializeCompressed(), &chaincfg.MainNetParams)
return addr, nil return addr, nil
} }
func (*mockWalletController) LastUnusedAddress(addrType lnwallet.AddressType) (
btcutil.Address, error) {
return nil, nil
}
func (*mockWalletController) IsOurAddress(a btcutil.Address) bool { func (*mockWalletController) IsOurAddress(a btcutil.Address) bool {
return false return false
} }

@ -932,19 +932,44 @@ func (r *rpcServer) NewAddress(ctx context.Context,
// Translate the gRPC proto address type to the wallet controller's // Translate the gRPC proto address type to the wallet controller's
// available address types. // available address types.
var addrType lnwallet.AddressType var (
addr btcutil.Address
err error
)
switch in.Type { switch in.Type {
case lnrpc.AddressType_WITNESS_PUBKEY_HASH: case lnrpc.AddressType_WITNESS_PUBKEY_HASH:
addrType = lnwallet.WitnessPubKey addr, err = r.server.cc.wallet.NewAddress(
case lnrpc.AddressType_NESTED_PUBKEY_HASH: lnwallet.WitnessPubKey, false,
addrType = lnwallet.NestedWitnessPubKey )
}
addr, err := r.server.cc.wallet.NewAddress(addrType, false)
if err != nil { if err != nil {
return nil, err return nil, err
} }
case lnrpc.AddressType_NESTED_PUBKEY_HASH:
addr, err = r.server.cc.wallet.NewAddress(
lnwallet.NestedWitnessPubKey, false,
)
if err != nil {
return nil, err
}
case lnrpc.AddressType_UNUSED_WITNESS_PUBKEY_HASH:
addr, err = r.server.cc.wallet.LastUnusedAddress(
lnwallet.WitnessPubKey,
)
if err != nil {
return nil, err
}
case lnrpc.AddressType_UNUSED_NESTED_PUBKEY_HASH:
addr, err = r.server.cc.wallet.LastUnusedAddress(
lnwallet.NestedWitnessPubKey,
)
if err != nil {
return nil, err
}
}
rpcsLog.Infof("[newaddress] addr=%v", addr.String()) rpcsLog.Infof("[newaddress] addr=%v", addr.String())
return &lnrpc.NewAddressResponse{Address: addr.String()}, nil return &lnrpc.NewAddressResponse{Address: addr.String()}, nil
} }