7 "github.com/jhalter/mobius/hotline"
8 "github.com/rivo/tview"
16 var logLevels = map[string]slog.Level{
17 "debug": slog.LevelDebug,
18 "info": slog.LevelInfo,
19 "warn": slog.LevelWarn,
20 "error": slog.LevelError,
24 _, cancelRoot := context.WithCancel(context.Background())
26 sigChan := make(chan os.Signal, 1)
27 signal.Notify(sigChan, syscall.SIGTERM, syscall.SIGINT, os.Interrupt)
29 configDir := flag.String("config", defaultConfigPath(), "Path to config root")
30 version := flag.Bool("version", false, "print version and exit")
31 logLevel := flag.String("log-level", "info", "Log level")
32 logFile := flag.String("log-file", "", "output logs to file")
37 fmt.Printf("v%s\n", hotline.VERSION)
42 db := &hotline.DebugBuffer{
43 TextView: tview.NewTextView(),
46 // Add file logger if optional log-file flag was passed
48 f, err := os.OpenFile(*logFile,
49 os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
50 defer func() { _ = f.Close() }()
56 logger := slog.New(slog.NewTextHandler(db, &slog.HandlerOptions{Level: logLevels[*logLevel]}))
57 logger.Info("Started Mobius client", "Version", hotline.VERSION)
61 logger.Info("Stopping client", "signal", sig.String())
65 client := hotline.NewUIClient(*configDir, logger)
70 func defaultConfigPath() (cfgPath string) {
73 cfgPath = "mobius-client-config.yaml"
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"
81 cfgPath = "/usr/local/etc/mobius-client-config.yaml"
83 fmt.Printf("unsupported OS")