Files
lspd/main.go
2022-11-18 16:51:36 +01:00

93 lines
1.6 KiB
Go

package main
import (
"fmt"
"log"
"os"
"sync"
"github.com/btcsuite/btcd/btcec/v2"
)
func main() {
if len(os.Args) > 1 && os.Args[1] == "genkey" {
p, err := btcec.NewPrivateKey()
if err != nil {
log.Fatalf("btcec.NewPrivateKey() error: %v", err)
}
fmt.Printf("LSPD_PRIVATE_KEY=\"%x\"\n", p.Serialize())
return
}
err := pgConnect()
if err != nil {
log.Fatalf("pgConnect() error: %v", err)
}
runCln := os.Getenv("RUN_CLN") == "true"
runLnd := os.Getenv("RUN_LND") == "true"
if runCln && runLnd {
log.Fatalf("One of RUN_CLN or RUN_LND must be true, not both.")
}
if !runCln && !runLnd {
log.Fatalf("Either RUN_CLN or RUN_LND must be true.")
}
var interceptor HtlcInterceptor
if runCln {
c := NewClnClient("lightningrpc", ".")
client = c
interceptor = NewClnHtlcInterceptor(c)
}
if runLnd {
c := NewLndClient()
client = c
interceptor = NewLndHtlcInterceptor(c)
}
s := NewGrpcServer()
info, err := client.GetInfo()
if err != nil {
log.Fatalf("client.GetInfo() error: %v", err)
}
if nodeName == "" {
nodeName = info.Alias
}
if nodePubkey == "" {
nodePubkey = info.Pubkey
}
var wg sync.WaitGroup
wg.Add(2)
go func() {
err := interceptor.Start()
if err == nil {
log.Printf("Interceptor stopped.")
} else {
log.Printf("FATAL. Interceptor stopped with error: %v", err)
}
s.Stop()
wg.Done()
}()
go func() {
err := s.Start()
if err == nil {
log.Printf("GRPC server stopped.")
} else {
log.Printf("FATAL. GRPC server stopped with error: %v", err)
}
interceptor.Stop()
wg.Done()
}()
wg.Wait()
log.Printf("lspd exited")
}