package main import ( "context" "fmt" "github.com/btcsuite/btcutil" "github.com/lightninglabs/loop/looprpc" "github.com/urfave/cli" ) var loopInCommand = cli.Command{ Name: "in", Usage: "perform an on-chain to off-chain swap (loop in)", ArgsUsage: "amt", Description: ` Send the amount in satoshis specified by the amt argument off-chain.`, Flags: []cli.Flag{ cli.Uint64Flag{ Name: "channel", Usage: "the 8-byte compact channel ID of the channel to loop in", }, cli.Uint64Flag{ Name: "amt", Usage: "the amount in satoshis to loop out", }, }, Action: loopIn, } func loopIn(ctx *cli.Context) error { args := ctx.Args() var amtStr string switch { case ctx.IsSet("amt"): amtStr = ctx.String("amt") case ctx.NArg() > 0: amtStr = args[0] args = args.Tail() default: // Show command help if no arguments and flags were provided. cli.ShowCommandHelp(ctx, "in") return nil } amt, err := parseAmt(amtStr) if err != nil { return err } client, cleanup, err := getClient(ctx) if err != nil { return err } defer cleanup() quote, err := client.GetLoopInQuote( context.Background(), &looprpc.QuoteRequest{ Amt: int64(amt), }, ) if err != nil { return err } limits := getInLimits(amt, quote) if err := displayLimits(amt, limits); err != nil { return err } var loopInChannel uint64 if ctx.IsSet("channel") { loopInChannel = ctx.Uint64("channel") } resp, err := client.LoopIn(context.Background(), &looprpc.LoopInRequest{ Amt: int64(amt), MaxMinerFee: int64(limits.maxMinerFee), MaxSwapFee: int64(limits.maxSwapFee), LoopInChannel: loopInChannel, }) if err != nil { return err } fmt.Printf("Swap initiated with id: %v\n", resp.Id[:8]) fmt.Printf("Run swapcli without a command to monitor progress.\n") return nil } func getInLimits(amt btcutil.Amount, quote *looprpc.QuoteResponse) *limits { return &limits{ // Apply a multiplier to the estimated miner fee, to not get // the swap canceled because fees increased in the mean time. maxMinerFee: btcutil.Amount(quote.MinerFee) * 3, maxSwapFee: btcutil.Amount(quote.SwapFee), } }