logger.go 905 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. package logger
  2. import (
  3. "fmt"
  4. "log/slog"
  5. "os"
  6. "path/filepath"
  7. "github.com/ayn2op/discordo/internal/consts"
  8. "github.com/lmittmann/tint"
  9. )
  10. const fileName = "logs.txt"
  11. func DefaultPath() string {
  12. path, err := os.UserCacheDir()
  13. if err != nil {
  14. slog.Info(
  15. "user cache directory path cannot be determined; falling back to the current directory path",
  16. )
  17. path = "."
  18. }
  19. return filepath.Join(path, consts.Name, fileName)
  20. }
  21. // Load opens the log file and configures default logger.
  22. func Load(path string, level slog.Level) error {
  23. if err := os.MkdirAll(filepath.Dir(path), os.ModePerm); err != nil {
  24. return err
  25. }
  26. file, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, os.ModePerm)
  27. if err != nil {
  28. return fmt.Errorf("failed to open log file: %w", err)
  29. }
  30. opts := &tint.Options{Level: level}
  31. handler := tint.NewHandler(file, opts)
  32. slog.SetDefault(slog.New(handler))
  33. return nil
  34. }