Documentation ¶
Index ¶
- Constants
- Variables
- func Run(rpcCfg RPCConfig) error
- func SetupLoggers(root *build.RotatingLogWriter, intercept signal.Interceptor)
- func Validate(cfg *Config) error
- type Config
- type Daemon
- func (s *Daemon) GetLiquidityParams(_ context.Context, _ *clientrpc.GetLiquidityParamsRequest) (*clientrpc.LiquidityParameters, error)
- func (s *Daemon) GetLoopInQuote(ctx context.Context, req *clientrpc.QuoteRequest) (*clientrpc.InQuoteResponse, error)
- func (s *Daemon) GetLoopInTerms(ctx context.Context, req *clientrpc.TermsRequest) (*clientrpc.InTermsResponse, error)
- func (s *Daemon) GetLsatTokens(ctx context.Context, _ *clientrpc.TokensRequest) (*clientrpc.TokensResponse, error)
- func (s *Daemon) ListSwaps(_ context.Context, _ *clientrpc.ListSwapsRequest) (*clientrpc.ListSwapsResponse, error)
- func (s *Daemon) LoopIn(ctx context.Context, in *clientrpc.LoopInRequest) (*clientrpc.SwapResponse, error)
- func (s *Daemon) LoopOut(ctx context.Context, in *clientrpc.LoopOutRequest) (*clientrpc.SwapResponse, error)
- func (s *Daemon) LoopOutQuote(ctx context.Context, req *clientrpc.QuoteRequest) (*clientrpc.OutQuoteResponse, error)
- func (s *Daemon) LoopOutTerms(ctx context.Context, req *clientrpc.TermsRequest) (*clientrpc.OutTermsResponse, error)
- func (s *Daemon) Monitor(in *clientrpc.MonitorRequest, server clientrpc.SwapClient_MonitorServer) error
- func (s *Daemon) Probe(ctx context.Context, req *clientrpc.ProbeRequest) (*clientrpc.ProbeResponse, error)
- func (s *Daemon) SetLiquidityParams(ctx context.Context, in *clientrpc.SetLiquidityParamsRequest) (*clientrpc.SetLiquidityParamsResponse, error)
- func (d *Daemon) Start() error
- func (d *Daemon) StartAsSubserver(lndGrpc *lndclient.GrpcLndServices, withMacaroonService bool) error
- func (d *Daemon) Stop()
- func (s *Daemon) SuggestSwaps(ctx context.Context, _ *clientrpc.SuggestSwapsRequest) (*clientrpc.SuggestSwapsResponse, error)
- func (s *Daemon) SwapInfo(_ context.Context, req *clientrpc.SwapInfoRequest) (*clientrpc.SwapStatus, error)
- func (d *Daemon) ValidateMacaroon(ctx context.Context, requiredPermissions []bakery.Op, fullMethod string) error
- type ListenerCfg
- type RPCConfig
Constants ¶
const Subsystem = "LOOPD"
Variables ¶
var ( // LoopDirBase is the default main directory where loop stores its data. LoopDirBase = btcutil.AppDataDir("loop", false) // DefaultNetwork is the default bitcoin network loop runs on. DefaultNetwork = "mainnet" // DefaultTLSCertFilename is the default file name for the autogenerated // TLS certificate. DefaultTLSCertFilename = "tls.cert" // DefaultTLSKeyFilename is the default file name for the autogenerated // TLS key. DefaultTLSKeyFilename = "tls.key" // DefaultLndMacaroonPath is the default mainnet admin macaroon path of // LND. DefaultLndMacaroonPath = filepath.Join( btcutil.AppDataDir("lnd", false), "data", "chain", "bitcoin", DefaultNetwork, defaultLndMacaroon, ) // DefaultTLSCertPath is the default full path of the autogenerated TLS // certificate. DefaultTLSCertPath = filepath.Join( LoopDirBase, DefaultNetwork, DefaultTLSCertFilename, ) // DefaultTLSKeyPath is the default full path of the autogenerated TLS // key. DefaultTLSKeyPath = filepath.Join( LoopDirBase, DefaultNetwork, DefaultTLSKeyFilename, ) // DefaultMacaroonFilename is the default file name for the // autogenerated loop macaroon. DefaultMacaroonFilename = "loop.macaroon" // DefaultMacaroonPath is the default full path of the base loop // macaroon. DefaultMacaroonPath = filepath.Join( LoopDirBase, DefaultNetwork, DefaultMacaroonFilename, ) // DefaultAutogenValidity is the default validity of a self-signed // certificate. The value corresponds to 14 months // (14 months * 30 days * 24 hours). DefaultAutogenValidity = 14 * 30 * 24 * time.Hour )
var ( // LoopMinRequiredLndVersion is the minimum required version of lnd that // is compatible with the current version of the loop client. Also all // listed build tags/subservers need to be enabled. LoopMinRequiredLndVersion = &verrpc.Version{ AppMajor: 0, AppMinor: 11, AppPatch: 1, BuildTags: []string{ "signrpc", "walletrpc", "chainrpc", "invoicesrpc", }, } )
var ( // RequiredPermissions is a map of all loop RPC methods and their // required macaroon permissions to access loopd. RequiredPermissions = map[string][]bakery.Op{ "/looprpc.SwapClient/LoopOut": {{ Entity: "swap", Action: "execute", }, { Entity: "loop", Action: "out", }}, "/looprpc.SwapClient/LoopIn": {{ Entity: "swap", Action: "execute", }, { Entity: "loop", Action: "in", }}, "/looprpc.SwapClient/Monitor": {{ Entity: "swap", Action: "read", }}, "/looprpc.SwapClient/ListSwaps": {{ Entity: "swap", Action: "read", }}, "/looprpc.SwapClient/SwapInfo": {{ Entity: "swap", Action: "read", }}, "/looprpc.SwapClient/LoopOutTerms": {{ Entity: "terms", Action: "read", }, { Entity: "loop", Action: "out", }}, "/looprpc.SwapClient/LoopOutQuote": {{ Entity: "swap", Action: "read", }, { Entity: "loop", Action: "out", }}, "/looprpc.SwapClient/GetLoopInTerms": {{ Entity: "terms", Action: "read", }, { Entity: "loop", Action: "in", }}, "/looprpc.SwapClient/GetLoopInQuote": {{ Entity: "swap", Action: "read", }, { Entity: "loop", Action: "in", }}, "/looprpc.SwapClient/GetLsatTokens": {{ Entity: "auth", Action: "read", }}, "/looprpc.SwapClient/SuggestSwaps": {{ Entity: "suggestions", Action: "read", }}, "/looprpc.SwapClient/GetLiquidityParams": {{ Entity: "suggestions", Action: "read", }}, "/looprpc.SwapClient/SetLiquidityParams": {{ Entity: "suggestions", Action: "write", }}, "/looprpc.SwapClient/Probe": {{ Entity: "swap", Action: "execute", }, { Entity: "loop", Action: "in", }}, } )
Functions ¶
func SetupLoggers ¶
func SetupLoggers(root *build.RotatingLogWriter, intercept signal.Interceptor)
SetupLoggers initializes all package-global logger variables.
Types ¶
type Config ¶
type Config struct { ShowVersion bool `long:"version" description:"Display version information and exit"` Network string `long:"network" description:"network to run on" choice:"regtest" choice:"testnet" choice:"mainnet" choice:"simnet"` RPCListen string `long:"rpclisten" description:"Address to listen on for gRPC clients"` RESTListen string `long:"restlisten" description:"Address to listen on for REST clients"` CORSOrigin string `long:"corsorigin" description:"The value to send in the Access-Control-Allow-Origin header. Header will be omitted if empty."` LoopDir string `` /* 166-byte string literal not displayed */ ConfigFile string `long:"configfile" description:"Path to configuration file."` DataDir string `long:"datadir" description:"Directory for loopdb."` TLSCertPath string `long:"tlscertpath" description:"Path to write the TLS certificate for loop's RPC and REST services."` TLSKeyPath string `long:"tlskeypath" description:"Path to write the TLS private key for loop's RPC and REST services."` TLSExtraIPs []string `long:"tlsextraip" description:"Adds an extra IP to the generated certificate."` TLSExtraDomains []string `long:"tlsextradomain" description:"Adds an extra domain to the generated certificate."` TLSAutoRefresh bool `long:"tlsautorefresh" description:"Re-generate TLS certificate and key if the IPs or domains are changed."` TLSDisableAutofill bool `` /* 174-byte string literal not displayed */ MacaroonPath string `long:"macaroonpath" description:"Path to write the macaroon for loop's RPC and REST services if it doesn't exist."` LogDir string `long:"logdir" description:"Directory to log output."` MaxLogFiles int `long:"maxlogfiles" description:"Maximum logfiles to keep (0 for no rotation)."` MaxLogFileSize int `long:"maxlogfilesize" description:"Maximum logfile size in MB."` DebugLevel string `` /* 265-byte string literal not displayed */ MaxLSATCost uint32 `` /* 148-byte string literal not displayed */ MaxLSATFee uint32 `long:"maxlsatfee" description:"Maximum routing fee in satoshis that we are willing to pay while paying for an LSAT token."` LoopOutMaxParts uint32 `long:"loopoutmaxparts" description:"The maximum number of payment parts that may be used for a loop out swap."` Lnd *lndConfig `group:"lnd" namespace:"lnd"` Server *loopServerConfig `group:"server" namespace:"server"` View viewParameters `` /* 131-byte string literal not displayed */ }
func DefaultConfig ¶
func DefaultConfig() Config
DefaultConfig returns all default values for the Config struct.
type Daemon ¶
type Daemon struct { // ErrChan is an error channel that users of the Daemon struct must use // to detect runtime errors and also whether a shutdown is fully // completed. ErrChan chan error // contains filtered or unexported fields }
Daemon is the struct that holds one instance of the loop client daemon.
func New ¶
func New(config *Config, lisCfg *ListenerCfg) *Daemon
New creates a new instance of the loop client daemon.
func (*Daemon) GetLiquidityParams ¶
func (s *Daemon) GetLiquidityParams(_ context.Context, _ *clientrpc.GetLiquidityParamsRequest) (*clientrpc.LiquidityParameters, error)
GetLiquidityParams gets our current liquidity manager's parameters.
func (*Daemon) GetLoopInQuote ¶
func (s *Daemon) GetLoopInQuote(ctx context.Context, req *clientrpc.QuoteRequest) (*clientrpc.InQuoteResponse, error)
GetQuote returns a quote for a swap with the provided parameters.
func (*Daemon) GetLoopInTerms ¶
func (s *Daemon) GetLoopInTerms(ctx context.Context, req *clientrpc.TermsRequest) (*clientrpc.InTermsResponse, error)
GetTerms returns the terms that the server enforces for swaps.
func (*Daemon) GetLsatTokens ¶
func (s *Daemon) GetLsatTokens(ctx context.Context, _ *clientrpc.TokensRequest) (*clientrpc.TokensResponse, error)
GetLsatTokens returns all tokens that are contained in the LSAT token store.
func (*Daemon) ListSwaps ¶
func (s *Daemon) ListSwaps(_ context.Context, _ *clientrpc.ListSwapsRequest) (*clientrpc.ListSwapsResponse, error)
ListSwaps returns a list of all currently known swaps and their current status.
func (*Daemon) LoopIn ¶
func (s *Daemon) LoopIn(ctx context.Context, in *clientrpc.LoopInRequest) ( *clientrpc.SwapResponse, error)
func (*Daemon) LoopOut ¶
func (s *Daemon) LoopOut(ctx context.Context, in *clientrpc.LoopOutRequest) ( *clientrpc.SwapResponse, error)
LoopOut initiates an loop out swap with the given parameters. The call returns after the swap has been set up with the swap server. From that point onwards, progress can be tracked via the LoopOutStatus stream that is returned from Monitor().
func (*Daemon) LoopOutQuote ¶
func (s *Daemon) LoopOutQuote(ctx context.Context, req *clientrpc.QuoteRequest) (*clientrpc.OutQuoteResponse, error)
LoopOutQuote returns a quote for a loop out swap with the provided parameters.
func (*Daemon) LoopOutTerms ¶
func (s *Daemon) LoopOutTerms(ctx context.Context, req *clientrpc.TermsRequest) (*clientrpc.OutTermsResponse, error)
LoopOutTerms returns the terms that the server enforces for loop out swaps.
func (*Daemon) Monitor ¶
func (s *Daemon) Monitor(in *clientrpc.MonitorRequest, server clientrpc.SwapClient_MonitorServer) error
Monitor will return a stream of swap updates for currently active swaps.
func (*Daemon) Probe ¶
func (s *Daemon) Probe(ctx context.Context, req *clientrpc.ProbeRequest) (*clientrpc.ProbeResponse, error)
Probe requests the server to probe the client's node to test inbound liquidity.
func (*Daemon) SetLiquidityParams ¶
func (s *Daemon) SetLiquidityParams(ctx context.Context, in *clientrpc.SetLiquidityParamsRequest) (*clientrpc.SetLiquidityParamsResponse, error)
SetLiquidityParams attempts to set our current liquidity manager's parameters.
func (*Daemon) Start ¶
Start starts loopd in daemon mode. It will listen for grpc connections, execute commands and pass back swap status information.
func (*Daemon) StartAsSubserver ¶
func (d *Daemon) StartAsSubserver(lndGrpc *lndclient.GrpcLndServices, withMacaroonService bool) error
StartAsSubserver is an alternative to Start where the RPC server does not create its own gRPC server but registers to an existing one. The same goes for REST (if enabled), instead of creating an own mux and HTTP server, we register to an existing one.
func (*Daemon) Stop ¶
func (d *Daemon) Stop()
Stop tries to gracefully shut down the daemon. A caller needs to wait for a message on the main error channel indicating that the shutdown is completed.
func (*Daemon) SuggestSwaps ¶
func (s *Daemon) SuggestSwaps(ctx context.Context, _ *clientrpc.SuggestSwapsRequest) (*clientrpc.SuggestSwapsResponse, error)
SuggestSwaps provides a list of suggested swaps based on lnd's current channel balances and rules set by the liquidity manager.
func (*Daemon) SwapInfo ¶
func (s *Daemon) SwapInfo(_ context.Context, req *clientrpc.SwapInfoRequest) (*clientrpc.SwapStatus, error)
SwapInfo returns all known details about a single swap.
func (*Daemon) ValidateMacaroon ¶
func (d *Daemon) ValidateMacaroon(ctx context.Context, requiredPermissions []bakery.Op, fullMethod string) error
ValidateMacaroon extracts the macaroon from the context's gRPC metadata, checks its signature, makes sure all specified permissions for the called method are contained within and finally ensures all caveat conditions are met. A non-nil error is returned if any of the checks fail. This method is needed to enable loopd running as an external subserver in the same process as lnd but still validate its own macaroons.
type ListenerCfg ¶
type ListenerCfg struct {
// contains filtered or unexported fields
}
ListenerCfg holds closures used to retrieve listeners for the gRPC services.
func NewListenerConfig ¶
func NewListenerConfig(config *Config, rpcCfg RPCConfig) *ListenerCfg
NewListenerConfig creates and returns a new listenerCfg from the passed config and RPCConfig.
type RPCConfig ¶
type RPCConfig struct { // RPCListener is an optional listener that if set will override the // daemon's gRPC settings, and make the gRPC server listen on this // listener. // Note that setting this will also disable REST. RPCListener net.Listener // LndConn is an optional connection to an lnd instance. If set it will // override the TCP connection created from daemon's config. LndConn net.Conn }
RPCConfig holds optional options that can be used to make the loop daemon communicate on custom connections.