-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsyslog_handler.go
55 lines (48 loc) · 1.23 KB
/
syslog_handler.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
// +build !windows,!nacl,!plan9
package ligno
import "log/syslog"
// syslogHandler sends all messages to local syslog server.
type syslogHandler struct {
Formatter Formatter
Tag string
Priority syslog.Priority
writer *syslog.Writer
}
// SyslogHandler creates new syslog handler with provided config variables.
func SyslogHandler(formatter Formatter, tag string, priority syslog.Priority) Handler {
writer, err := syslog.New(syslog.LOG_DEBUG, tag)
if err != nil {
panic(err)
}
return &syslogHandler{
Formatter: formatter,
Tag: tag,
Priority: priority,
writer: writer,
}
}
// Handle passes all messages to syslog server. Message priorities are
// translated to syslog compatible priorities.
func (sh *syslogHandler) Handle(record Record) error {
msg := string(sh.Formatter.Format(record))
switch record.Level {
case NOTSET:
return sh.writer.Info(msg)
case DEBUG:
return sh.writer.Debug(msg)
case INFO:
return sh.writer.Info(msg)
case WARNING:
return sh.writer.Warning(msg)
case ERROR:
return sh.writer.Err(msg)
case CRITICAL:
return sh.writer.Crit(msg)
default:
return sh.writer.Info(msg)
}
}
// Close closes connection with syslog server.
func (sh *syslogHandler) Close() {
sh.writer.Close()
}