forked from UBAutograding/leviathan
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathlogger.go
More file actions
71 lines (60 loc) · 1.74 KB
/
logger.go
File metadata and controls
71 lines (60 loc) · 1.74 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
package common
import (
"context"
"fmt"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
"gopkg.in/natefinch/lumberjack.v2"
"os"
)
const (
JobLogKey = "jobID"
)
func getConsoleWriter() zerolog.ConsoleWriter {
return zerolog.ConsoleWriter{
Out: os.Stderr,
TimeFormat: "2006-01-02 15:04:05",
}
}
func getBaseLogger() zerolog.Logger {
env, ok := os.LookupEnv("LEVIATHAN_LOG_SHOW_CALLER_FILE")
if !ok || env == "false" {
return log.With().Logger().Output(getConsoleWriter())
}
return log.With().Caller().Logger().Output(getConsoleWriter())
}
func CreateJobSubLoggerCtx(ctx context.Context, jobID string) context.Context {
return log.Logger.With().Str(JobLogKey, jobID).Logger().WithContext(ctx)
}
func FileConsoleLogger() zerolog.Logger {
level, err := zerolog.ParseLevel(LogLevel.GetStr())
if err != nil {
log.Fatal().Err(err).Msg("unable to parse log level")
}
log.Info().Msgf("log level is now set to %s, this can be changed by using the LEVIATHAN_LOG_LEVEL env", level)
return getBaseLogger().Output(
zerolog.MultiLevelWriter(
GetFileLogger(LogDir.GetStr()),
getConsoleWriter(),
),
).Level(level)
}
// ErrLog logs the original error while returning a sanitized user-facing error.
//
// This hides implementation details from users while ensuring full error information is available for debugging.
func ErrLog(message string, err error, eventLevel *zerolog.Event) error {
eventLevel.Err(err).Msg(message)
return fmt.Errorf("%s", message)
}
func ConsoleLogger() zerolog.Logger {
return getBaseLogger()
}
func GetFileLogger(logFile string) *lumberjack.Logger {
return &lumberjack.Logger{
Filename: logFile,
MaxSize: 10, // MB
MaxBackups: 5, // number of backups
MaxAge: 30, // days
Compress: true,
}
}