-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathlogger.go
More file actions
96 lines (79 loc) · 1.7 KB
/
logger.go
File metadata and controls
96 lines (79 loc) · 1.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
// Package logger is a logger package :)
package logger
import (
"fmt"
"log/slog"
"os"
"path/filepath"
"time"
)
var (
enabled bool = false
logger *slog.Logger
)
func Init(
isEnabled bool,
logFilePath string,
) {
enabled = isEnabled
if !enabled {
return
}
file, err := createLogFile(logFilePath)
if err != nil {
panic(err)
}
opts := &slog.HandlerOptions{
Level: slog.LevelDebug,
}
logger = slog.New(slog.NewTextHandler(file, opts))
logger.Info("Logger initialized")
}
func createLogFile(logFilePath string) (*os.File, error) {
homeDir, err := os.UserHomeDir()
if err != nil {
panic(fmt.Errorf("failed to get user home dir: %w", err))
}
logDir := filepath.Join(homeDir, logFilePath)
// Ensure directory exists
if err := os.MkdirAll(logDir, 0o755); err != nil {
panic(fmt.Errorf("failed to create log dir: %w", err))
}
// Create log file with today's date
today := time.Now().Format("2006-01-02")
logFile := filepath.Join(logDir, today+".log")
file, err := os.OpenFile(logFile, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0o644)
if err != nil {
return nil, fmt.Errorf("failed to open log file: %w", err)
}
return file, nil
}
func Debug(msg string, args ...any) {
if enabled {
logger.Debug(msg, args...)
}
}
func Info(msg string, args ...any) {
if enabled {
logger.Info(msg, args...)
}
}
func Warn(msg string, args ...any) {
if enabled {
logger.Warn(msg, args...)
}
}
func Error(msg string, args ...any) {
if enabled {
logger.Error(msg, args...)
}
}
func BoolAttr(key string, v bool) slog.Attr {
return slog.Bool(key, v)
}
func StringAttr(key string, v string) slog.Attr {
return slog.String(key, v)
}
func IntAttr(key string, v int) slog.Attr {
return slog.Int(key, v)
}