mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 20:24:21 +01:00
* [btc-embedded] add chainfee.Estimator and extraAPI interfaces * dynamic fee amount * dynamic dust amount * [client] fix linter errors * [domain] fix unit tests * [server] return dust amount in GetInfo RPC * [sdk] fix lnd dependencie * go work sync * fix witness stack size forfeit tx size estimator * remove hardcoded fee values in covenant txbuilder * lower liquid feerate * fix after reviews * go work sync
118 lines
3.1 KiB
Go
Executable File
118 lines
3.1 KiB
Go
Executable File
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"os/signal"
|
|
"path/filepath"
|
|
"syscall"
|
|
|
|
"github.com/ark-network/ark/common"
|
|
appconfig "github.com/ark-network/ark/server/internal/app-config"
|
|
"github.com/ark-network/ark/server/internal/config"
|
|
grpcservice "github.com/ark-network/ark/server/internal/interface/grpc"
|
|
log "github.com/sirupsen/logrus"
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
// Version will be set during build time
|
|
var Version string
|
|
|
|
// flags
|
|
var (
|
|
urlFlag = &cli.StringFlag{
|
|
Name: "url",
|
|
Usage: "the url where to reach ark server",
|
|
Value: fmt.Sprintf("http://localhost:%d", config.DefaultPort),
|
|
}
|
|
noMacaroonFlag = &cli.BoolFlag{
|
|
Name: "no-macaroon",
|
|
Usage: "don't use macaroon auth",
|
|
Value: false,
|
|
}
|
|
macaroonFlag = &cli.StringFlag{
|
|
Name: "macaroon-path",
|
|
Usage: "the path where to find the admin macaroon file",
|
|
Value: filepath.Join(common.AppDataDir("arkd", false), "macaroons", "admin.macaroon"),
|
|
}
|
|
tlsCertFlag = &cli.StringFlag{
|
|
Name: "tls-cert-path",
|
|
Usage: "the path where to find the TLS certificate",
|
|
Value: filepath.Join(common.AppDataDir("arkd", false), "tls", "cert.pem"),
|
|
}
|
|
)
|
|
|
|
func mainAction(_ *cli.Context) error {
|
|
cfg, err := config.LoadConfig()
|
|
if err != nil {
|
|
return fmt.Errorf("invalid config: %s", err)
|
|
}
|
|
|
|
log.SetLevel(log.Level(cfg.LogLevel))
|
|
|
|
svcConfig := grpcservice.Config{
|
|
Datadir: cfg.Datadir,
|
|
Port: cfg.Port,
|
|
NoTLS: cfg.NoTLS,
|
|
NoMacaroons: cfg.NoMacaroons,
|
|
TLSExtraIPs: cfg.TLSExtraIPs,
|
|
TLSExtraDomains: cfg.TLSExtraDomains,
|
|
}
|
|
|
|
appConfig := &appconfig.Config{
|
|
EventDbType: cfg.EventDbType,
|
|
DbType: cfg.DbType,
|
|
DbDir: cfg.DbDir,
|
|
DbMigrationPath: cfg.DbMigrationPath,
|
|
EventDbDir: cfg.DbDir,
|
|
RoundInterval: cfg.RoundInterval,
|
|
Network: cfg.Network,
|
|
SchedulerType: cfg.SchedulerType,
|
|
TxBuilderType: cfg.TxBuilderType,
|
|
BlockchainScannerType: cfg.BlockchainScannerType,
|
|
WalletAddr: cfg.WalletAddr,
|
|
RoundLifetime: cfg.RoundLifetime,
|
|
UnilateralExitDelay: cfg.UnilateralExitDelay,
|
|
EsploraURL: cfg.EsploraURL,
|
|
NeutrinoPeer: cfg.NeutrinoPeer,
|
|
BitcoindRpcUser: cfg.BitcoindRpcUser,
|
|
BitcoindRpcPass: cfg.BitcoindRpcPass,
|
|
BitcoindRpcHost: cfg.BitcoindRpcHost,
|
|
BoardingExitDelay: cfg.BoardingExitDelay,
|
|
}
|
|
svc, err := grpcservice.NewService(svcConfig, appConfig)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
log.RegisterExitHandler(svc.Stop)
|
|
|
|
log.Info("starting service...")
|
|
if err := svc.Start(); err != nil {
|
|
return err
|
|
}
|
|
|
|
sigChan := make(chan os.Signal, 1)
|
|
signal.Notify(sigChan, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT, os.Interrupt)
|
|
<-sigChan
|
|
|
|
log.Info("shutting down service...")
|
|
log.Exit(0)
|
|
|
|
return nil
|
|
}
|
|
|
|
func main() {
|
|
app := cli.NewApp()
|
|
app.Version = Version
|
|
app.Name = "Arkd CLI"
|
|
app.Usage = "arkd command line interface"
|
|
app.Commands = append(app.Commands, walletCmd)
|
|
app.Action = mainAction
|
|
app.Flags = append(app.Flags, urlFlag, noMacaroonFlag, macaroonFlag, tlsCertFlag)
|
|
|
|
if err := app.Run(os.Args); err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
}
|