package main import ( "encoding/hex" "fmt" "log" "net/http" "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" ) func banner() { s := ""+ ` .__ _____ _____ ____ |__| ____ / \\__ \ / ___\| |/ ___\ | Y Y \/ __ \_/ /_/ > \ \___ |__|_| (____ /\___ /|__|\___ > \/ \//_____/..wallet..\/ ` fmt.Printf("%s\n\n", s) } func main() { var ( dbUrl string lndAddress string lndCert string lndMacaroon string lndNetwork string ) banner() // 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) // TODO: read port from env if err = s.Start(fmt.Sprintf("127.0.0.1:%d", env.Port)); err != http.ErrServerClosed { log.Fatal(err) } }