logger.go 904 B

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