logger.go 718 B

123456789101112131415161718192021222324252627282930313233
  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. return filepath.Join(consts.CacheDir(), fileName)
  12. }
  13. // Load opens the log file and configures default logger.
  14. func Load(path string, level slog.Level) error {
  15. if err := os.MkdirAll(filepath.Dir(path), os.ModePerm); err != nil {
  16. return err
  17. }
  18. file, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY|os.O_TRUNC, os.ModePerm)
  19. if err != nil {
  20. return fmt.Errorf("failed to open log file: %w", err)
  21. }
  22. opts := &slog.HandlerOptions{Level: level}
  23. handler := slog.NewTextHandler(file, opts)
  24. slog.SetDefault(slog.New(handler))
  25. return nil
  26. }