smartctl_exporter/logging.go

56 lines
1.1 KiB
Go
Raw Normal View History

2019-08-14 22:34:49 +02:00
package main
import (
"fmt"
)
// Logger is logger
type Logger struct {
verbose bool
debug bool
}
func newLogger(verbose bool, debug bool) Logger {
logger := Logger{verbose: verbose, debug: debug}
return logger
}
// Msg formatted message
func (i Logger) print(prefix string, format string, values ...interface{}) {
fmt.Printf(fmt.Sprintf("[%s] %s\n", prefix, format), values...)
}
// Info log message
func (i Logger) Info(format string, values ...interface{}) {
i.print("Info", format, values...)
}
// Warning log message
func (i Logger) Warning(format string, values ...interface{}) {
i.print("Warning", format, values...)
}
// Error log message
func (i Logger) Error(format string, values ...interface{}) {
i.print("Error", format, values...)
}
// Panic log message
func (i Logger) Panic(format string, values ...interface{}) {
i.print("Panic", format, values...)
}
// Verbose log message
func (i Logger) Verbose(format string, values ...interface{}) {
if i.verbose {
i.print("Verbose", format, values...)
}
}
// Debug log message
func (i Logger) Debug(format string, values ...interface{}) {
if i.debug {
i.print("Debug", format, values...)
}
}