164 lines
3.2 KiB
Go
164 lines
3.2 KiB
Go
// +build autopilotrpc
|
|
|
|
package main
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/lightningnetwork/lnd/lnrpc/autopilotrpc"
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
func getAutopilotClient(ctx *cli.Context) (autopilotrpc.AutopilotClient, func()) {
|
|
conn := getClientConn(ctx, false)
|
|
|
|
cleanUp := func() {
|
|
conn.Close()
|
|
}
|
|
|
|
return autopilotrpc.NewAutopilotClient(conn), cleanUp
|
|
}
|
|
|
|
var getStatusCommand = cli.Command{
|
|
Name: "status",
|
|
Usage: "Get the active status of autopilot.",
|
|
Description: "",
|
|
Action: actionDecorator(getStatus),
|
|
}
|
|
|
|
func getStatus(ctx *cli.Context) error {
|
|
ctxb := context.Background()
|
|
client, cleanUp := getAutopilotClient(ctx)
|
|
defer cleanUp()
|
|
|
|
req := &autopilotrpc.StatusRequest{}
|
|
|
|
resp, err := client.Status(ctxb, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
printRespJSON(resp)
|
|
return nil
|
|
}
|
|
|
|
var enableCommand = cli.Command{
|
|
Name: "enable",
|
|
Usage: "Enable the autopilot.",
|
|
Description: "",
|
|
Action: actionDecorator(enable),
|
|
}
|
|
|
|
var disableCommand = cli.Command{
|
|
Name: "disable",
|
|
Usage: "Disable the active autopilot.",
|
|
Description: "",
|
|
Action: actionDecorator(disable),
|
|
}
|
|
|
|
func enable(ctx *cli.Context) error {
|
|
ctxb := context.Background()
|
|
client, cleanUp := getAutopilotClient(ctx)
|
|
defer cleanUp()
|
|
|
|
// We will enable the autopilot.
|
|
req := &autopilotrpc.ModifyStatusRequest{
|
|
Enable: true,
|
|
}
|
|
|
|
resp, err := client.ModifyStatus(ctxb, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
printRespJSON(resp)
|
|
return nil
|
|
}
|
|
|
|
func disable(ctx *cli.Context) error {
|
|
ctxb := context.Background()
|
|
client, cleanUp := getAutopilotClient(ctx)
|
|
defer cleanUp()
|
|
|
|
// We will disable the autopilot.
|
|
req := &autopilotrpc.ModifyStatusRequest{
|
|
Enable: false,
|
|
}
|
|
|
|
resp, err := client.ModifyStatus(ctxb, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
printRespJSON(resp)
|
|
return nil
|
|
}
|
|
|
|
var queryScoresCommand = cli.Command{
|
|
Name: "query",
|
|
Usage: "Query the autopilot heuristics for nodes' scores.",
|
|
ArgsUsage: "[flags] <pubkey> <pubkey> <pubkey> ...",
|
|
Description: "",
|
|
Action: actionDecorator(queryScores),
|
|
Flags: []cli.Flag{
|
|
cli.BoolFlag{
|
|
Name: "ignorelocalstate, i",
|
|
Usage: "Ignore local channel state when calculating " +
|
|
"scores.",
|
|
},
|
|
},
|
|
}
|
|
|
|
func queryScores(ctx *cli.Context) error {
|
|
ctxb := context.Background()
|
|
client, cleanUp := getAutopilotClient(ctx)
|
|
defer cleanUp()
|
|
|
|
args := ctx.Args()
|
|
var pubs []string
|
|
|
|
// Keep reading pubkeys as long as there are arguments.
|
|
loop:
|
|
for {
|
|
switch {
|
|
case args.Present():
|
|
pubs = append(pubs, args.First())
|
|
args = args.Tail()
|
|
default:
|
|
break loop
|
|
}
|
|
}
|
|
|
|
req := &autopilotrpc.QueryScoresRequest{
|
|
Pubkeys: pubs,
|
|
IgnoreLocalState: ctx.Bool("ignorelocalstate"),
|
|
}
|
|
|
|
resp, err := client.QueryScores(ctxb, req)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
printRespJSON(resp)
|
|
return nil
|
|
}
|
|
|
|
// autopilotCommands will return the set of commands to enable for autopilotrpc
|
|
// builds.
|
|
func autopilotCommands() []cli.Command {
|
|
return []cli.Command{
|
|
{
|
|
Name: "autopilot",
|
|
Category: "Autopilot",
|
|
Usage: "Interact with a running autopilot.",
|
|
Description: "",
|
|
Subcommands: []cli.Command{
|
|
getStatusCommand,
|
|
enableCommand,
|
|
disableCommand,
|
|
queryScoresCommand,
|
|
},
|
|
},
|
|
}
|
|
}
|