mirror of
https://github.com/lightninglabs/loop
synced 2024-11-09 19:10:47 +00:00
Merge pull request #59 from valentinewallace/basic-client-mac-path
lndclient/basic_client: pass full macaroon path, not just directory.
This commit is contained in:
commit
9de7b949dd
@ -13,11 +13,48 @@ import (
|
|||||||
macaroon "gopkg.in/macaroon.v2"
|
macaroon "gopkg.in/macaroon.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// BasicClientOption is a functional option argument that allows adding arbitrary
|
||||||
|
// lnd basic client configuration overrides, without forcing existing users of
|
||||||
|
// NewBasicClient to update their invocation. These are always processed in
|
||||||
|
// order, with later options overriding earlier ones.
|
||||||
|
type BasicClientOption func(*basicClientOptions)
|
||||||
|
|
||||||
|
// basicClientOptions is a set of options that can configure the lnd client
|
||||||
|
// returned by NewBasicClient.
|
||||||
|
type basicClientOptions struct {
|
||||||
|
macFilename string
|
||||||
|
}
|
||||||
|
|
||||||
|
// defaultBasicClientOptions returns a basicClientOptions set to lnd basic client
|
||||||
|
// defaults.
|
||||||
|
func defaultBasicClientOptions() *basicClientOptions {
|
||||||
|
return &basicClientOptions{
|
||||||
|
macFilename: defaultAdminMacaroonFilename,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// MacFilename is a basic client option that sets the name of the macaroon file
|
||||||
|
// to use.
|
||||||
|
func MacFilename(macFilename string) BasicClientOption {
|
||||||
|
return func(bc *basicClientOptions) {
|
||||||
|
bc.macFilename = macFilename
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// applyBasicClientOptions updates a basicClientOptions set with functional
|
||||||
|
// options.
|
||||||
|
func (bc *basicClientOptions) applyBasicClientOptions(options ...BasicClientOption) {
|
||||||
|
for _, option := range options {
|
||||||
|
option(bc)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// NewBasicClient creates a new basic gRPC client to lnd. We call this client
|
// NewBasicClient creates a new basic gRPC client to lnd. We call this client
|
||||||
// "basic" as it uses a global macaroon (by default the admin macaroon) for the
|
// "basic" as it falls back to expected defaults if the arguments aren't
|
||||||
// entire connection, and falls back to expected defaults if the arguments
|
// provided.
|
||||||
// aren't provided.
|
func NewBasicClient(lndHost, tlsPath, macDir, network string, basicOptions ...BasicClientOption) (
|
||||||
func NewBasicClient(lndHost, tlsPath, macDir, network string) (lnrpc.LightningClient, error) {
|
lnrpc.LightningClient, error) {
|
||||||
|
|
||||||
if tlsPath == "" {
|
if tlsPath == "" {
|
||||||
tlsPath = defaultTLSCertPath
|
tlsPath = defaultTLSCertPath
|
||||||
}
|
}
|
||||||
@ -40,7 +77,12 @@ func NewBasicClient(lndHost, tlsPath, macDir, network string) (lnrpc.LightningCl
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
macPath := filepath.Join(macDir, defaultAdminMacaroonFilename)
|
// Starting with the set of default options, we'll apply any specified
|
||||||
|
// functional options to the basic client.
|
||||||
|
bco := defaultBasicClientOptions()
|
||||||
|
bco.applyBasicClientOptions(basicOptions...)
|
||||||
|
|
||||||
|
macPath := filepath.Join(macDir, bco.macFilename)
|
||||||
|
|
||||||
// Load the specified macaroon file.
|
// Load the specified macaroon file.
|
||||||
macBytes, err := ioutil.ReadFile(macPath)
|
macBytes, err := ioutil.ReadFile(macPath)
|
||||||
|
Loading…
Reference in New Issue
Block a user