mirror of https://github.com/lightninglabs/loop
loop: static address creation client command
parent
56bca2f632
commit
0b504f70af
@ -0,0 +1,76 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
|
||||
"github.com/lightninglabs/loop/looprpc"
|
||||
"github.com/urfave/cli"
|
||||
)
|
||||
|
||||
var staticAddressCommands = cli.Command{
|
||||
Name: "static",
|
||||
ShortName: "s",
|
||||
Usage: "manage static loop-in addresses",
|
||||
Category: "StaticAddress",
|
||||
Subcommands: []cli.Command{
|
||||
newStaticAddressCommand,
|
||||
},
|
||||
}
|
||||
|
||||
var newStaticAddressCommand = cli.Command{
|
||||
Name: "new",
|
||||
ShortName: "n",
|
||||
Usage: "Create a new static loop in address.",
|
||||
Description: `
|
||||
Requests a new static loop in address from the server. Funds that are
|
||||
sent to this address will be locked by a 2:2 multisig between us and the
|
||||
loop server, or a timeout path that we can sweep once it opens up. The
|
||||
funds can either be cooperatively spent with a signature from the server
|
||||
or looped in.
|
||||
`,
|
||||
Action: newStaticAddress,
|
||||
}
|
||||
|
||||
func newStaticAddress(ctx *cli.Context) error {
|
||||
ctxb := context.Background()
|
||||
if ctx.NArg() > 0 {
|
||||
return cli.ShowCommandHelp(ctx, "new")
|
||||
}
|
||||
|
||||
client, cleanup, err := getAddressClient(ctx)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer cleanup()
|
||||
|
||||
resp, err := client.NewAddress(
|
||||
ctxb, &looprpc.NewAddressRequest{},
|
||||
)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
fmt.Printf("Received a new static loop-in address from the server: "+
|
||||
"%s\n", resp.Address)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func getAddressClient(ctx *cli.Context) (looprpc.StaticAddressClientClient,
|
||||
func(), error) {
|
||||
|
||||
rpcServer := ctx.GlobalString("rpcserver")
|
||||
tlsCertPath, macaroonPath, err := extractPathArgs(ctx)
|
||||
if err != nil {
|
||||
return nil, nil, err
|
||||
}
|
||||
conn, err := getClientConn(rpcServer, tlsCertPath, macaroonPath)
|
||||
if err != nil {
|
||||
return nil, nil, err
|
||||
}
|
||||
cleanup := func() { conn.Close() }
|
||||
|
||||
addressClient := looprpc.NewStaticAddressClientClient(conn)
|
||||
return addressClient, cleanup, nil
|
||||
}
|
Loading…
Reference in New Issue