logger.go 683 B

123456789101112131415161718192021222324252627282930313233
  1. package logger
  2. import (
  3. "log/slog"
  4. "os"
  5. "path/filepath"
  6. "github.com/ayn2op/discordo/internal/consts"
  7. )
  8. // Load opens the log file and configures default logger.
  9. func Load(level slog.Level) error {
  10. path, err := os.UserCacheDir()
  11. if err != nil {
  12. return err
  13. }
  14. path = filepath.Join(path, consts.Name)
  15. if err := os.MkdirAll(path, os.ModePerm); err != nil {
  16. return err
  17. }
  18. path = filepath.Join(path, "logs.txt")
  19. file, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, os.ModePerm)
  20. if err != nil {
  21. return err
  22. }
  23. opts := &slog.HandlerOptions{AddSource: true, Level: level}
  24. handler := slog.NewTextHandler(file, opts)
  25. slog.SetDefault(slog.New(handler))
  26. return nil
  27. }