| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- package cmd
- import (
- "flag"
- "log/slog"
- "github.com/ayn2op/discordo/internal/config"
- "github.com/ayn2op/discordo/internal/consts"
- "github.com/ayn2op/discordo/internal/logger"
- "github.com/ayn2op/tview"
- "github.com/diamondburned/arikawa/v3/utils/ws"
- "github.com/gdamore/tcell/v2"
- "github.com/zalando/go-keyring"
- )
- var (
- discordState *state
- app *application
- )
- func Run() error {
- logLevel := flag.String("log-level", "info", "log level")
- logFormat := flag.String("log-format", "text", "log format")
- token := flag.String("token", "", "authentication token")
- configPath := flag.String("config", config.DefaultPath(), "path to the configuration file")
- flag.Parse()
- var level slog.Level
- switch *logLevel {
- case "debug":
- ws.EnableRawEvents = true
- level = slog.LevelDebug
- case "info":
- level = slog.LevelInfo
- case "warn":
- level = slog.LevelWarn
- case "error":
- level = slog.LevelError
- }
- var format logger.Format
- switch *logFormat {
- case "text":
- format = logger.FormatText
- case "json":
- format = logger.FormatJson
- }
- if err := logger.Load(format, level); err != nil {
- return err
- }
- tok := *token
- if tok == "" {
- var err error
- tok, err = keyring.Get(consts.Name, "token")
- if err != nil {
- slog.Info("failed to retrieve token from keyring", "err", err)
- }
- }
- cfg, err := config.Load(*configPath)
- if err != nil {
- return err
- }
- tview.Styles.PrimitiveBackgroundColor = tcell.GetColor(cfg.Theme.BackgroundColor)
- app = newApplication(cfg)
- return app.run(tok)
- }
|