photoprism/pkg/dummy/logger.go

248 lines
5.6 KiB
Go

package dummy
import (
"context"
"io"
"os"
"sync/atomic"
"time"
"github.com/sirupsen/logrus"
)
// Logger represents a dummy logger.
type Logger struct {
Out io.Writer
Hooks logrus.LevelHooks
Formatter logrus.Formatter
ReportCaller bool
Level logrus.Level
ExitFunc exitFunc
BufferPool logrus.BufferPool
}
// Logger represents am exit callback function.
type exitFunc func(int)
// NewLogger creates a new dummy logger instance.
func NewLogger() *Logger {
return &Logger{
Out: os.Stderr,
Formatter: &logrus.TextFormatter{
DisableColors: true,
FullTimestamp: true,
},
Hooks: make(logrus.LevelHooks),
Level: logrus.PanicLevel,
ExitFunc: os.Exit,
}
}
// WithField allocates a new entry and adds a field to it.
func (logger *Logger) WithField(key string, value interface{}) *logrus.Entry {
return &logrus.Entry{Data: logrus.Fields{key: value}}
}
// WithFields adds a struct of fields to the log entry. All it does is call `WithField` for
// each `Field`.
func (logger *Logger) WithFields(fields logrus.Fields) *logrus.Entry {
return &logrus.Entry{Data: fields}
}
// WithError adds an error as single field to the log entry. All it does is call
// `WithError` for the given `error`.
func (logger *Logger) WithError(err error) *logrus.Entry {
if err == nil {
return &logrus.Entry{}
}
return &logrus.Entry{Message: err.Error()}
}
// WithContext adds a context to the log entry.
func (logger *Logger) WithContext(ctx context.Context) *logrus.Entry {
return &logrus.Entry{Context: ctx}
}
// WithTime overrides the time of the log entry.
func (logger *Logger) WithTime(t time.Time) *logrus.Entry {
return &logrus.Entry{Time: t}
}
func (logger *Logger) Logf(level logrus.Level, format string, args ...interface{}) {
}
func (logger *Logger) Tracef(format string, args ...interface{}) {
}
func (logger *Logger) Debugf(format string, args ...interface{}) {
}
func (logger *Logger) Infof(format string, args ...interface{}) {
}
func (logger *Logger) Printf(format string, args ...interface{}) {
}
func (logger *Logger) Warnf(format string, args ...interface{}) {
}
func (logger *Logger) Warningf(format string, args ...interface{}) {
}
func (logger *Logger) Errorf(format string, args ...interface{}) {
}
func (logger *Logger) Fatalf(format string, args ...interface{}) {
}
func (logger *Logger) Panicf(format string, args ...interface{}) {
}
// Log will log a message at the level given as parameter.
func (logger *Logger) Log(level logrus.Level, args ...interface{}) {
}
func (logger *Logger) LogFn(level logrus.Level, fn logrus.LogFunction) {
}
func (logger *Logger) Trace(args ...interface{}) {
}
func (logger *Logger) Debug(args ...interface{}) {
}
func (logger *Logger) Info(args ...interface{}) {
}
func (logger *Logger) Print(args ...interface{}) {
}
func (logger *Logger) Warn(args ...interface{}) {
}
func (logger *Logger) Warning(args ...interface{}) {
}
func (logger *Logger) Error(args ...interface{}) {
}
func (logger *Logger) Fatal(args ...interface{}) {
}
func (logger *Logger) Panic(args ...interface{}) {
}
func (logger *Logger) TraceFn(fn logrus.LogFunction) {
}
func (logger *Logger) DebugFn(fn logrus.LogFunction) {
}
func (logger *Logger) InfoFn(fn logrus.LogFunction) {
}
func (logger *Logger) PrintFn(fn logrus.LogFunction) {
}
func (logger *Logger) WarnFn(fn logrus.LogFunction) {
}
func (logger *Logger) WarningFn(fn logrus.LogFunction) {
}
func (logger *Logger) ErrorFn(fn logrus.LogFunction) {
}
func (logger *Logger) FatalFn(fn logrus.LogFunction) {
}
func (logger *Logger) PanicFn(fn logrus.LogFunction) {
}
func (logger *Logger) Logln(level logrus.Level, args ...interface{}) {
}
func (logger *Logger) Traceln(args ...interface{}) {
}
func (logger *Logger) Debugln(args ...interface{}) {
}
func (logger *Logger) Infoln(args ...interface{}) {
logger.Logln(logrus.InfoLevel, args...)
}
func (logger *Logger) Println(args ...interface{}) {
}
func (logger *Logger) Warnln(args ...interface{}) {
logger.Logln(logrus.WarnLevel, args...)
}
func (logger *Logger) Warningln(args ...interface{}) {
logger.Warnln(args...)
}
func (logger *Logger) Errorln(args ...interface{}) {
logger.Logln(logrus.ErrorLevel, args...)
}
func (logger *Logger) Fatalln(args ...interface{}) {
logger.Logln(logrus.FatalLevel, args...)
}
func (logger *Logger) Panicln(args ...interface{}) {
logger.Logln(logrus.PanicLevel, args...)
}
func (logger *Logger) Exit(code int) {
}
func (logger *Logger) SetNoLock() {
}
// SetLevel sets the logger level.
func (logger *Logger) SetLevel(level logrus.Level) {
atomic.StoreUint32((*uint32)(&logger.Level), uint32(level))
}
// GetLevel returns the logger level.
func (logger *Logger) GetLevel() logrus.Level {
return logger.Level
}
// AddHook adds a hook to the logger hooks.
func (logger *Logger) AddHook(hook logrus.Hook) {
logger.Hooks.Add(hook)
}
// IsLevelEnabled checks if the log level of the logger is greater than the level param
func (logger *Logger) IsLevelEnabled(level logrus.Level) bool {
return logger.Level >= level
}
// SetFormatter sets the logger formatter.
func (logger *Logger) SetFormatter(formatter logrus.Formatter) {
logger.Formatter = formatter
}
// SetOutput sets the logger output.
func (logger *Logger) SetOutput(output io.Writer) {
logger.Out = output
}
func (logger *Logger) SetReportCaller(reportCaller bool) {
logger.ReportCaller = reportCaller
}
// ReplaceHooks replaces the logger hooks and returns the old ones
func (logger *Logger) ReplaceHooks(hooks logrus.LevelHooks) logrus.LevelHooks {
logger.Hooks = hooks
return logger.Hooks
}
// SetBufferPool sets the logger buffer pool.
func (logger *Logger) SetBufferPool(pool logrus.BufferPool) {
logger.BufferPool = pool
}