mirror of
https://github.com/grafana/grafana.git
synced 2024-11-30 04:34:23 -06:00
115 lines
2.3 KiB
Go
115 lines
2.3 KiB
Go
package sqlstore
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
glog "github.com/grafana/grafana/pkg/log"
|
|
|
|
"github.com/go-xorm/core"
|
|
)
|
|
|
|
type XormLogger struct {
|
|
grafanaLog glog.Logger
|
|
level glog.Lvl
|
|
showSQL bool
|
|
}
|
|
|
|
func NewXormLogger(level glog.Lvl, grafanaLog glog.Logger) *XormLogger {
|
|
return &XormLogger{
|
|
grafanaLog: grafanaLog,
|
|
level: level,
|
|
showSQL: true,
|
|
}
|
|
}
|
|
|
|
// Error implement core.ILogger
|
|
func (s *XormLogger) Error(v ...interface{}) {
|
|
if s.level <= glog.LvlError {
|
|
s.grafanaLog.Error(fmt.Sprint(v...))
|
|
}
|
|
}
|
|
|
|
// Errorf implement core.ILogger
|
|
func (s *XormLogger) Errorf(format string, v ...interface{}) {
|
|
if s.level <= glog.LvlError {
|
|
s.grafanaLog.Error(fmt.Sprintf(format, v...))
|
|
}
|
|
}
|
|
|
|
// Debug implement core.ILogger
|
|
func (s *XormLogger) Debug(v ...interface{}) {
|
|
if s.level <= glog.LvlDebug {
|
|
s.grafanaLog.Debug(fmt.Sprint(v...))
|
|
}
|
|
}
|
|
|
|
// Debugf implement core.ILogger
|
|
func (s *XormLogger) Debugf(format string, v ...interface{}) {
|
|
if s.level <= glog.LvlDebug {
|
|
s.grafanaLog.Debug(fmt.Sprintf(format, v...))
|
|
}
|
|
}
|
|
|
|
// Info implement core.ILogger
|
|
func (s *XormLogger) Info(v ...interface{}) {
|
|
if s.level <= glog.LvlInfo {
|
|
s.grafanaLog.Info(fmt.Sprint(v...))
|
|
}
|
|
}
|
|
|
|
// Infof implement core.ILogger
|
|
func (s *XormLogger) Infof(format string, v ...interface{}) {
|
|
if s.level <= glog.LvlInfo {
|
|
s.grafanaLog.Info(fmt.Sprintf(format, v...))
|
|
}
|
|
}
|
|
|
|
// Warn implement core.ILogger
|
|
func (s *XormLogger) Warn(v ...interface{}) {
|
|
if s.level <= glog.LvlWarn {
|
|
s.grafanaLog.Warn(fmt.Sprint(v...))
|
|
}
|
|
}
|
|
|
|
// Warnf implement core.ILogger
|
|
func (s *XormLogger) Warnf(format string, v ...interface{}) {
|
|
if s.level <= glog.LvlWarn {
|
|
s.grafanaLog.Warn(fmt.Sprintf(format, v...))
|
|
}
|
|
}
|
|
|
|
// Level implement core.ILogger
|
|
func (s *XormLogger) Level() core.LogLevel {
|
|
switch s.level {
|
|
case glog.LvlError:
|
|
return core.LOG_ERR
|
|
case glog.LvlWarn:
|
|
return core.LOG_WARNING
|
|
case glog.LvlInfo:
|
|
return core.LOG_INFO
|
|
case glog.LvlDebug:
|
|
return core.LOG_DEBUG
|
|
default:
|
|
return core.LOG_ERR
|
|
}
|
|
}
|
|
|
|
// SetLevel implement core.ILogger
|
|
func (s *XormLogger) SetLevel(l core.LogLevel) {
|
|
}
|
|
|
|
// ShowSQL implement core.ILogger
|
|
func (s *XormLogger) ShowSQL(show ...bool) {
|
|
s.grafanaLog.Error("ShowSQL", "show", "show")
|
|
if len(show) == 0 {
|
|
s.showSQL = true
|
|
return
|
|
}
|
|
s.showSQL = show[0]
|
|
}
|
|
|
|
// IsShowSQL implement core.ILogger
|
|
func (s *XormLogger) IsShowSQL() bool {
|
|
return s.showSQL
|
|
}
|