From 63775756e053d69b715ef4e6d7bae298013e8ede Mon Sep 17 00:00:00 2001 From: carla Date: Tue, 19 Jan 2021 10:57:16 +0200 Subject: [PATCH] lncli: add mission control getter and setter --- cmd/lncli/cmd_mc_cfg_get.go | 36 +++++++++++++ cmd/lncli/cmd_mc_cfg_set.go | 102 ++++++++++++++++++++++++++++++++++++ cmd/lncli/routerrpc.go | 2 + 3 files changed, 140 insertions(+) create mode 100644 cmd/lncli/cmd_mc_cfg_get.go create mode 100644 cmd/lncli/cmd_mc_cfg_set.go diff --git a/cmd/lncli/cmd_mc_cfg_get.go b/cmd/lncli/cmd_mc_cfg_get.go new file mode 100644 index 000000000..017449f8b --- /dev/null +++ b/cmd/lncli/cmd_mc_cfg_get.go @@ -0,0 +1,36 @@ +package main + +import ( + "context" + + "github.com/lightningnetwork/lnd/lnrpc/routerrpc" + "github.com/urfave/cli" +) + +var getCfgCommand = cli.Command{ + Name: "getmccfg", + Usage: "Display mission control's config.", + Description: ` + Returns the config currently being used by mission control. + `, + Action: actionDecorator(getCfg), +} + +func getCfg(ctx *cli.Context) error { + conn := getClientConn(ctx, false) + defer conn.Close() + + client := routerrpc.NewRouterClient(conn) + + ctxb := context.Background() + resp, err := client.GetMissionControlConfig( + ctxb, &routerrpc.GetMissionControlConfigRequest{}, + ) + if err != nil { + return err + } + + printRespJSON(resp) + + return nil +} diff --git a/cmd/lncli/cmd_mc_cfg_set.go b/cmd/lncli/cmd_mc_cfg_set.go new file mode 100644 index 000000000..874ff2db9 --- /dev/null +++ b/cmd/lncli/cmd_mc_cfg_set.go @@ -0,0 +1,102 @@ +package main + +import ( + "context" + + "github.com/lightningnetwork/lnd/lnrpc/routerrpc" + "github.com/urfave/cli" +) + +var setCfgCommand = cli.Command{ + Name: "setmccfg", + Usage: "Set mission control's config.", + Description: ` + Update the config values being used by mission control to calculate + the probability that payment routes will succeed. + `, + Flags: []cli.Flag{ + cli.DurationFlag{ + Name: "halflife", + Usage: "the amount of time taken to restore a node " + + "or channel to 50% probability of success.", + }, + cli.Float64Flag{ + Name: "hopprob", + Usage: "the probability of success assigned " + + "to hops that we have no information about", + }, + cli.Float64Flag{ + Name: "weight", + Usage: "the degree to which mission control should " + + "rely on historical results, expressed as " + + "value in [0;1]", + }, cli.UintFlag{ + Name: "pmtnr", + Usage: "the number of payments mission control " + + "should store", + }, + cli.DurationFlag{ + Name: "failrelax", + Usage: "the amount of time to wait after a failure " + + "before raising failure amount", + }, + }, + Action: actionDecorator(setCfg), +} + +func setCfg(ctx *cli.Context) error { + conn := getClientConn(ctx, false) + defer conn.Close() + + client := routerrpc.NewRouterClient(conn) + + ctxb := context.Background() + resp, err := client.GetMissionControlConfig( + ctxb, &routerrpc.GetMissionControlConfigRequest{}, + ) + if err != nil { + return err + } + + var haveValue bool + + if ctx.IsSet("halflife") { + haveValue = true + resp.Config.HalfLifeSeconds = uint64(ctx.Duration( + "halflife", + ).Seconds()) + } + + if ctx.IsSet("hopprob") { + haveValue = true + resp.Config.HopProbability = float32(ctx.Float64("hopprob")) + } + + if ctx.IsSet("weight") { + haveValue = true + resp.Config.Weight = float32(ctx.Float64("weight")) + } + + if ctx.IsSet("pmtnr") { + haveValue = true + resp.Config.MaximumPaymentResults = uint32(ctx.Int("pmtnr")) + } + + if ctx.IsSet("failrelax") { + haveValue = true + resp.Config.MinimumFailureRelaxInterval = uint64(ctx.Duration( + "failrelax", + ).Seconds()) + } + + if !haveValue { + return cli.ShowCommandHelp(ctx, "setmccfg") + } + + _, err = client.SetMissionControlConfig( + ctxb, &routerrpc.SetMissionControlConfigRequest{ + Config: resp.Config, + }, + ) + return err +} diff --git a/cmd/lncli/routerrpc.go b/cmd/lncli/routerrpc.go index 819f66d22..04c9676ec 100644 --- a/cmd/lncli/routerrpc.go +++ b/cmd/lncli/routerrpc.go @@ -9,5 +9,7 @@ func routerCommands() []cli.Command { queryProbCommand, resetMissionControlCommand, buildRouteCommand, + getCfgCommand, + setCfgCommand, } }