]> git.r.bdr.sh - rbdr/mobius/blame - cmd/mobius-hotline-client/main.go
Minor cleanup
[rbdr/mobius] / cmd / mobius-hotline-client / main.go
CommitLineData
6988a057
JH
1package main
2
3import (
4 "context"
5 "flag"
6 "fmt"
22c599ab 7 "github.com/jhalter/mobius/hotline"
6988a057 8 "github.com/rivo/tview"
ea2027a3 9 "log/slog"
6988a057
JH
10 "os"
11 "os/signal"
95753255 12 "runtime"
6988a057 13 "syscall"
6988a057
JH
14)
15
ea2027a3
JH
16var logLevels = map[string]slog.Level{
17 "debug": slog.LevelDebug,
18 "info": slog.LevelInfo,
19 "warn": slog.LevelWarn,
20 "error": slog.LevelError,
21}
22
6988a057
JH
23func main() {
24 _, cancelRoot := context.WithCancel(context.Background())
25
26 sigChan := make(chan os.Signal, 1)
27 signal.Notify(sigChan, syscall.SIGTERM, syscall.SIGINT, os.Interrupt)
28
e130e0a2 29 configDir := flag.String("config", defaultConfigPath(), "Path to config root")
6988a057
JH
30 version := flag.Bool("version", false, "print version and exit")
31 logLevel := flag.String("log-level", "info", "Log level")
12ace83f
JH
32 logFile := flag.String("log-file", "", "output logs to file")
33
6988a057
JH
34 flag.Parse()
35
36 if *version {
37 fmt.Printf("v%s\n", hotline.VERSION)
38 os.Exit(0)
39 }
40
6988a057
JH
41 // init DebugBuffer
42 db := &hotline.DebugBuffer{
43 TextView: tview.NewTextView(),
44 }
45
12ace83f
JH
46 // Add file logger if optional log-file flag was passed
47 if *logFile != "" {
48 f, err := os.OpenFile(*logFile,
49 os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
ea2027a3 50 defer func() { _ = f.Close() }()
12ace83f
JH
51 if err != nil {
52 panic(err)
53 }
6988a057 54 }
12ace83f 55
ea2027a3
JH
56 logger := slog.New(slog.NewTextHandler(db, &slog.HandlerOptions{Level: logLevels[*logLevel]}))
57 logger.Info("Started Mobius client", "Version", hotline.VERSION)
6988a057
JH
58
59 go func() {
60 sig := <-sigChan
ea2027a3 61 logger.Info("Stopping client", "signal", sig.String())
6988a057
JH
62 cancelRoot()
63 }()
64
d005ef04 65 client := hotline.NewUIClient(*configDir, logger)
6988a057
JH
66 client.DebugBuf = db
67 client.UI.Start()
6988a057
JH
68}
69
95753255 70func defaultConfigPath() (cfgPath string) {
f4a69647 71 switch runtime.GOOS {
95753255
JH
72 case "windows":
73 cfgPath = "mobius-client-config.yaml"
74 case "darwin":
f4a69647
JH
75 if _, err := os.Stat("/usr/local/etc/mobius-client-config.yaml"); err == nil {
76 cfgPath = "/usr/local/etc/mobius-client-config.yaml"
77 } else if _, err := os.Stat("/opt/homebrew/etc/mobius-client-config.yaml"); err == nil {
78 cfgPath = "/opt/homebrew/etc/mobius-client-config.yaml"
79 }
95753255
JH
80 case "linux":
81 cfgPath = "/usr/local/etc/mobius-client-config.yaml"
82 default:
83 fmt.Printf("unsupported OS")
84 }
85
86 return cfgPath
87}