-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathlog.go
129 lines (106 loc) · 3.15 KB
/
log.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
120
121
122
123
124
125
126
127
128
129
// IRIS Endpoint-Server (EPS)
// Copyright (C) 2021-2021 The IRIS Endpoint-Server Authors (see AUTHORS.md)
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
package eps
import (
"fmt"
log "github.com/sirupsen/logrus"
"os"
"strings"
"time"
)
type Logger struct {
}
type Level log.Level
const (
PanicLogLevel = Level(log.PanicLevel)
FatalLogLevel = Level(log.FatalLevel)
ErrorLogLevel = Level(log.ErrorLevel)
WarnLogLevel = Level(log.WarnLevel)
InfoLogLevel = Level(log.InfoLevel)
DebugLogLevel = Level(log.DebugLevel)
TraceLogLevel = Level(log.TraceLevel)
)
func ParseLevel(level string) (Level, error) {
lvl, err := log.ParseLevel(level)
if err != nil {
return PanicLogLevel, fmt.Errorf("error parsing level: %w", err)
}
return Level(lvl), err
}
type IRISFormatter struct {
service string
}
func SetLogFormat(format string, service string) error {
switch format {
case "iris":
log.SetFormatter(&IRISFormatter{service: service})
default:
return fmt.Errorf("unknown log format: %s", format)
}
return nil
}
func (c *IRISFormatter) Format(entry *log.Entry) ([]byte, error) {
timestamp := time.Now().Format(time.RFC3339Nano)
loglevel := strings.ToUpper(entry.Level.String())
pid := os.Getpid()
thread := "[nan]" // thread ID is not applicable to Golang
function := "[nan]"
if entry.Caller != nil {
function = entry.Caller.Function
}
message := entry.Message
return []byte(fmt.Sprintf("%s %s %d %s %s %s : %s\n", timestamp, loglevel, pid, c.service, thread, function, message)), nil
}
func (l *Logger) Fatal(args ...interface{}) {
log.Fatal(args...)
}
func (l *Logger) Info(args ...interface{}) {
log.Info(args...)
}
func (l *Logger) Warning(args ...interface{}) {
log.Warning(args...)
}
func (l *Logger) SetLevel(level Level) {
log.SetLevel(log.Level(level))
}
func (l *Logger) Errorf(format string, args ...interface{}) {
log.Errorf(format, args...)
}
func (l *Logger) Fatalf(format string, args ...interface{}) {
log.Fatalf(format, args...)
}
func (l *Logger) Warningf(format string, args ...interface{}) {
log.Warningf(format, args...)
}
func (l *Logger) Error(args ...interface{}) {
log.Error(args...)
}
func (l *Logger) Debugf(format string, args ...interface{}) {
log.Debugf(format, args...)
}
func (l *Logger) Debug(args ...interface{}) {
log.Debug(args...)
}
func (l *Logger) Tracef(format string, args ...interface{}) {
log.Tracef(format, args...)
}
func (l *Logger) Trace(args ...interface{}) {
log.Trace(args...)
}
func (l *Logger) Infof(format string, args ...interface{}) {
log.Infof(format, args...)
}
var Log = Logger{}