2024-10-24 12:11:06 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2024-10-26 01:56:41 +00:00
|
|
|
"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"
|
2024-10-26 01:56:41 +00:00
|
|
|
"github.com/lightninglabs/lndclient"
|
2024-10-27 22:42:44 +00:00
|
|
|
"github.com/namsral/flag"
|
2024-10-24 12:11:06 +00:00
|
|
|
)
|
|
|
|
|
2024-10-25 02:32:25 +00:00
|
|
|
func banner() {
|
2024-12-11 07:18:43 +00:00
|
|
|
s := ""+
|
|
|
|
` .__
|
|
|
|
_____ _____ ____ |__| ____
|
|
|
|
/ \\__ \ / ___\| |/ ___\
|
|
|
|
| Y Y \/ __ \_/ /_/ > \ \___
|
|
|
|
|__|_| (____ /\___ /|__|\___ >
|
|
|
|
\/ \//_____/..wallet..\/ `
|
|
|
|
fmt.Printf("%s\n\n", s)
|
2024-10-25 02:32:25 +00:00
|
|
|
}
|
|
|
|
|
2024-10-24 12:11:06 +00:00
|
|
|
func main() {
|
2024-10-26 01:56:41 +00:00
|
|
|
var (
|
|
|
|
dbUrl string
|
|
|
|
lndAddress string
|
|
|
|
lndCert string
|
|
|
|
lndMacaroon string
|
|
|
|
lndNetwork string
|
|
|
|
)
|
2024-10-25 02:32:25 +00:00
|
|
|
banner()
|
2024-10-24 12:11:06 +00:00
|
|
|
|
2024-10-26 01:56:41 +00:00
|
|
|
// env
|
|
|
|
if err := env.Load(); err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
2024-10-27 22:42:44 +00:00
|
|
|
flag.StringVar(&dbUrl, "DATABASE_URL", "", "Database connection")
|
2024-10-26 01:56:41 +00:00
|
|
|
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()
|
|
|
|
|
2024-10-27 22:42:44 +00:00
|
|
|
fmt.Printf("Commit: %s\n", env.CommitShortSha)
|
|
|
|
fmt.Printf("Environment: %s\n", env.Env)
|
2024-10-26 01:56:41 +00:00
|
|
|
|
|
|
|
// database
|
|
|
|
db_, err := db.New(dbUrl)
|
|
|
|
if err != nil {
|
2024-10-27 22:42:44 +00:00
|
|
|
// 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)
|
2024-10-26 01:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 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)
|
2024-10-27 22:42:44 +00:00
|
|
|
// lnd is not required for every route
|
2024-10-26 01:56:41 +00:00
|
|
|
lnd_ = nil
|
|
|
|
} else {
|
2024-10-27 22:42:44 +00:00
|
|
|
fmt.Printf("✅ connected to %s LND v%s\n", lndAddress, lnd_.Version.Version)
|
2024-10-26 01:56:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 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
|
2024-10-26 01:56:41 +00:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|