/
logger.go
119 lines (93 loc) · 2.21 KB
/
logger.go
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*
* Copyright (c) 2023 Juice Technologies, Inc. All Rights Reserved.
*/
package logger
import (
"flag"
"fmt"
"strings"
"go.uber.org/zap"
)
var (
quiet = flag.Bool("quiet", false, "Disables all logging output")
logLevelArg = flag.String("log-level", "info", "Sets the maximum level of output [Fatal, Error, Warning, Info (Default), Debug]")
logFile = flag.String("log-file", "", "")
logFormat = flag.String("log-format", "juice", "Set the format of the logging [juice, console, json]")
logLevel zap.AtomicLevel
logger *zap.Logger = nil
sugardLogger *zap.SugaredLogger = nil
options []zap.Option
)
func LogLevelAsString() (string, error) {
return logLevel.String(), nil
}
func AddOption(option zap.Option) {
options = append(options, option)
}
func Configure() error {
var err error
logLevel, err = zap.ParseAtomicLevel(strings.ToLower(strings.TrimSpace(*logLevelArg)))
if err != nil {
return err
}
zap.RegisterEncoder("juice", NewJuiceEncoder)
config := zap.NewDevelopmentConfig()
config.Encoding = *logFormat
config.Level = logLevel
if *logFile != "" {
config.OutputPaths = []string{
*logFile,
}
}
// Skip our logger api
AddOption(zap.AddCallerSkip(1))
if *quiet {
logger = zap.NewNop()
} else {
logger, err = config.Build(options...)
if err != nil {
return fmt.Errorf("failed to initialize logger, %w", err)
}
}
sugardLogger = logger.Sugar()
return nil
}
func Close() {
logger.Sync()
}
func Fatal(v ...any) {
sugardLogger.Panic(v...)
}
func Fatalf(format string, v ...any) {
sugardLogger.Panicf(format, v...)
}
func Panic(v ...any) {
sugardLogger.Panic(v...)
}
func Panicf(format string, v ...any) {
sugardLogger.Panicf(format, v...)
}
func Error(v ...any) {
sugardLogger.Error(v...)
}
func Errorf(format string, v ...any) {
sugardLogger.Errorf(format, v...)
}
func Warning(v ...any) {
sugardLogger.Warn(v...)
}
func Warningf(format string, v ...any) {
sugardLogger.Warnf(format, v...)
}
func Info(v ...any) {
sugardLogger.Info(v...)
}
func Infof(format string, v ...any) {
sugardLogger.Infof(format, v...)
}
func Debug(v ...any) {
sugardLogger.Debug(v...)
}
func Debugf(format string, v ...any) {
sugardLogger.Debugf(format, v...)
}