Files
kapow/internal/logger/logger.go
Héctor Hurtado 248f7d1fcc Added stderr output management to jaillover.
Added Spawn support for stderr redirection.
Added --debug option to server cmd.
Added debug information to documentation.
Finnished script logger.
2020-04-20 10:18:16 +02:00

70 lines
1.0 KiB
Go

package logger
import (
"io"
"log"
"os"
)
const (
SCRIPTS = "ScriptsOutput"
)
type LogMsg struct {
Prefix string
Messages []string
}
type internalLogger struct {
loggerChannel chan LogMsg
execLog *log.Logger
}
var loggers = make(map[string]internalLogger)
func RegisterLogger(name string, writer io.Writer) {
il := internalLogger{}
flags := log.Ldate | log.Ltime | log.LUTC | log.Lmicroseconds
if writer == nil {
writer = os.Stdout
}
il.loggerChannel = make(chan LogMsg)
il.execLog = log.New(writer, "", flags)
loggers[name] = il
}
func Close(name string) {
il := loggers[name]
close(il.loggerChannel)
il.loggerChannel = nil
}
func SendMsg(name string, log LogMsg) bool {
if il, ok := loggers[name]; ok {
il.loggerChannel <- log
return true
}
return false
}
func ProcessMsg(name string) bool {
var cont bool
if il, ok := loggers[name]; ok {
var msg LogMsg
msg, cont = <-il.loggerChannel
for _, msgLine := range msg.Messages {
il.execLog.Printf("%s %s", msg.Prefix, msgLine)
}
}
return cont
}