-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathwriter_logger.go
More file actions
135 lines (111 loc) · 2.6 KB
/
writer_logger.go
File metadata and controls
135 lines (111 loc) · 2.6 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
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
130
131
132
133
134
135
package gomolwriter
import (
"bufio"
"errors"
"io"
"sync"
"time"
"github.com/aphistic/gomol"
)
type WriterLoggerConfig struct {
/*
The number of messages to be buffered before flushing them to
the file.
*/
BufferSize int
}
func NewWriterLoggerConfig() *WriterLoggerConfig {
return &WriterLoggerConfig{
BufferSize: 1000,
}
}
type WriterLogger struct {
base *gomol.Base
config *WriterLoggerConfig
writeLock sync.Mutex
buffer []*gomol.TemplateMsg
bufWriter *bufio.Writer
tpl *gomol.Template
isInitialized bool
}
func NewWriterLogger(w io.Writer, cfg *WriterLoggerConfig) (*WriterLogger, error) {
if w == nil {
return nil, errors.New("An io.Writer must be provided")
}
if cfg == nil {
cfg = NewWriterLoggerConfig()
}
l := &WriterLogger{
config: cfg,
buffer: make([]*gomol.TemplateMsg, 0),
bufWriter: bufio.NewWriter(w),
}
tpl, err := gomol.NewTemplate("[{{ucase .LevelName}}] {{.Message}}")
if err != nil {
return nil, err
}
l.SetTemplate(tpl)
return l, nil
}
func (l *WriterLogger) SetBase(base *gomol.Base) {
l.base = base
}
func (l *WriterLogger) SetTemplate(tpl *gomol.Template) error {
if tpl == nil {
return errors.New("A template must be provided")
}
l.tpl = tpl
return nil
}
func (l *WriterLogger) InitLogger() error {
l.isInitialized = true
return nil
}
func (l *WriterLogger) IsInitialized() bool {
return l.isInitialized
}
func (l *WriterLogger) ShutdownLogger() error {
err := l.flushMessages()
if err != nil {
return err
}
l.isInitialized = false
return nil
}
func (l *WriterLogger) flushMessages() error {
if len(l.buffer) == 0 {
return nil
}
sendMsgs := func() []*gomol.TemplateMsg {
l.writeLock.Lock()
defer l.writeLock.Unlock()
retBuf := l.buffer
l.buffer = make([]*gomol.TemplateMsg, 0)
return retBuf
}()
for _, sendMsg := range sendMsgs {
// Use colors for this because if they use colors in their
// non-default template there's probably a reason. This won't
// affect any templates that don't include colors
out, err := l.tpl.Execute(sendMsg, true)
if err != nil {
// Need to make a channel or something to send logging
// errors back to
}
l.bufWriter.WriteString(out + "\n")
}
l.bufWriter.Flush()
return nil
}
func (l *WriterLogger) Logm(timestamp time.Time, level gomol.LogLevel, m map[string]interface{}, msg string) error {
newMsg := gomol.NewTemplateMsg(timestamp, level, m, msg)
func() {
l.writeLock.Lock()
defer l.writeLock.Unlock()
l.buffer = append(l.buffer, newMsg)
}()
if len(l.buffer) >= l.config.BufferSize {
l.flushMessages()
}
return nil
}