1 Star 0 Fork 0

yangtxiang/mg-fw

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
glogger.go 1.66 KB
一键复制 编辑 原始数据 按行查看 历史
yangtxiang 提交于 2022-08-21 16:42 +08:00 . 增加日志库
package glogger
import (
"sync"
"time"
)
type LogLevel string
const (
LogLevelAll LogLevel = "all"
LogLevelInfo LogLevel = "info"
LogLevelDebug LogLevel = "debug"
LogLevelWarn LogLevel = "warn"
LogLevelError LogLevel = "error"
)
type GLog struct {
Level LogLevel
Tag string
Date time.Time
Log any
}
type GLogWriter interface {
Write(log *GLog)
}
type GLogWriterGetter func() GLogWriter
type GLogger interface {
Log(level LogLevel, tag string, data any)
Info(tag string, data any)
Debug(tag string, data any)
Warn(tag string, data any)
Error(tag string, data any)
}
type GLogOptions struct {
Prefix string `json:"prefix"`
Level LogLevel `json:"level"`
}
type baseLogger struct {
options *GLogOptions
lock sync.RWMutex
writerGetter GLogWriterGetter
}
func NewBaseLogger(writer GLogWriterGetter, options *GLogOptions) *baseLogger {
return &baseLogger{
lock: sync.RWMutex{},
options: options,
writerGetter: writer,
}
}
func (l *baseLogger) Log(level LogLevel, tag string, data any) {
l.lock.Lock()
defer l.lock.Unlock()
if !((l.options.Level == "" || l.options.Level == LogLevelAll) || (l.options.Level == level)) {
return
}
writer := l.writerGetter()
if writer == nil {
return
}
writer.Write(&GLog{
Level: level,
Tag: tag,
Date: time.Now(),
Log: data,
})
}
func (l *baseLogger) Info(tag string, data any) {
l.Log(LogLevelInfo, tag, data)
}
func (l *baseLogger) Debug(tag string, data any) {
l.Log(LogLevelDebug, tag, data)
}
func (l *baseLogger) Warn(tag string, data any) {
l.Log(LogLevelWarn, tag, data)
}
func (l *baseLogger) Error(tag string, data any) {
l.Log(LogLevelError, tag, data)
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/maglsoft/mg-fw.git
git@gitee.com:maglsoft/mg-fw.git
maglsoft
mg-fw
mg-fw
v0.0.5

搜索帮助