magicwallet/main.go

96 lines
2.3 KiB
Go
Raw Normal View History

2024-10-24 12:11:06 +00:00
package main
import (
"encoding/hex"
2024-10-24 12:11:06 +00:00
"fmt"
"log"
"net/http"
2024-12-11 07:18:43 +00:00
"github.com/ekzyis/magicwallet/db"
"github.com/ekzyis/magicwallet/env"
"github.com/ekzyis/magicwallet/lightning"
"github.com/ekzyis/magicwallet/server"
"github.com/lightninglabs/lndclient"
"github.com/namsral/flag"
2024-10-24 12:11:06 +00:00
)
func banner() {
2024-12-11 07:18:43 +00:00
s := ""+
` .__
_____ _____ ____ |__| ____
/ \\__ \ / ___\| |/ ___\
| Y Y \/ __ \_/ /_/ > \ \___
|__|_| (____ /\___ /|__|\___ >
\/ \//_____/..wallet..\/ `
fmt.Printf("%s\n\n", s)
}
2024-10-24 12:11:06 +00:00
func main() {
var (
dbUrl string
lndAddress string
lndCert string
lndMacaroon string
lndNetwork string
)
banner()
2024-10-24 12:11:06 +00:00
// env
if err := env.Load(); err != nil {
log.Fatal(err)
}
flag.StringVar(&dbUrl, "DATABASE_URL", "", "Database connection")
flag.StringVar(&lndAddress, "LND_ADDRESS", "localhost:10001", "LND gRPC server address")
flag.StringVar(&lndCert, "LND_CERT", "", "LND TLS certificate in hex")
flag.StringVar(&lndMacaroon, "LND_MACAROON", "", "LND macaroon in hex")
flag.StringVar(&lndNetwork, "LND_NETWORK", "regtest", "LND network")
env.Parse()
fmt.Printf("Commit: %s\n", env.CommitShortSha)
fmt.Printf("Environment: %s\n", env.Env)
// database
db_, err := db.New(dbUrl)
if err != nil {
// database is required for every route
log.Fatalf("❌ failed to connect to db: %v\n", err)
} else {
// TODO: don't print db password
fmt.Printf("✅ connected to %s\n", dbUrl)
}
// lightning
tlsData, err := hex.DecodeString(lndCert)
if err != nil {
log.Printf("❌ failed to decode LND TLS certificate: %v\n", err)
}
lnd_, err := lightning.New(&lightning.LNDConfig{
LndAddress: lndAddress,
CustomMacaroonHex: lndMacaroon,
TLSData: string(tlsData),
Network: lndclient.Network(lndNetwork),
Insecure: false,
})
if err != nil {
log.Printf("❌ failed to connect to LND: %v\n", err)
// lnd is not required for every route
lnd_ = nil
} else {
fmt.Printf("✅ connected to %s LND v%s\n", lndAddress, lnd_.Version.Version)
}
// server
ctx := server.Context{
Environment: env.Env,
CommitShortSha: env.CommitShortSha,
Db: db_,
Lnd: lnd_,
}
s := server.New(ctx)
2024-10-24 12:11:06 +00:00
// TODO: read port from env
if err = s.Start(fmt.Sprintf("127.0.0.1:%d", env.Port)); err != http.ErrServerClosed {
2024-10-24 12:11:06 +00:00
log.Fatal(err)
}
}