2016-05-30 16:08:09 +02:00
|
|
|
package logger
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
|
2016-06-06 20:04:38 +02:00
|
|
|
"github.com/fatih/color"
|
2016-05-30 16:08:09 +02:00
|
|
|
"github.com/kataras/iris/config"
|
2016-06-06 20:04:38 +02:00
|
|
|
"github.com/mattn/go-colorable"
|
2016-05-30 16:08:09 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// Prefix is the prefix for the logger, default is [IRIS]
|
|
|
|
Prefix = "[IRIS] "
|
2016-06-06 20:04:38 +02:00
|
|
|
// bannersRan keeps track of the logger's print banner count
|
|
|
|
bannersRan = 0
|
2016-05-30 16:08:09 +02:00
|
|
|
)
|
|
|
|
|
2016-06-06 20:04:38 +02:00
|
|
|
// Logger the logger
|
2016-05-30 16:08:09 +02:00
|
|
|
type Logger struct {
|
2016-06-14 07:45:40 +02:00
|
|
|
config *config.Logger
|
2016-06-06 20:04:38 +02:00
|
|
|
underline *color.Color
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
|
2016-06-06 20:04:38 +02:00
|
|
|
// attr takes a color integer and converts it to color.Attribute
|
|
|
|
func attr(sgr int) color.Attribute {
|
|
|
|
return color.Attribute(sgr)
|
|
|
|
}
|
|
|
|
|
2016-06-24 00:34:49 +02:00
|
|
|
// check if background color > 0 and if so then set it
|
|
|
|
func (l *Logger) setBg(sgr int) {
|
|
|
|
if sgr > 0 {
|
|
|
|
l.underline.Add(attr(sgr))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-06 20:04:38 +02:00
|
|
|
// New creates a new Logger from config.Logger configuration
|
|
|
|
func New(c config.Logger) *Logger {
|
|
|
|
color.Output = colorable.NewColorable(c.Out)
|
|
|
|
|
2016-06-24 00:34:49 +02:00
|
|
|
l := &Logger{&c, color.New(attr(c.ColorFgDefault))}
|
|
|
|
l.setBg(c.ColorBgDefault)
|
2016-06-22 15:01:31 +02:00
|
|
|
|
2016-06-06 20:04:38 +02:00
|
|
|
return l
|
|
|
|
}
|
|
|
|
|
2016-06-06 20:46:28 +02:00
|
|
|
// SetEnable true enables, false disables the Logger
|
|
|
|
func (l *Logger) SetEnable(enable bool) {
|
|
|
|
l.config.Disabled = !enable
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsEnabled returns true if Logger is enabled, otherwise false
|
|
|
|
func (l *Logger) IsEnabled() bool {
|
|
|
|
return !l.config.Disabled
|
|
|
|
}
|
|
|
|
|
|
|
|
// ResetColors sets the colors to the default
|
|
|
|
// this func is called every time a success, info, warning, or danger message is printed
|
|
|
|
func (l *Logger) ResetColors() {
|
2016-06-24 00:34:49 +02:00
|
|
|
l.underline.Add(attr(l.config.ColorFgDefault))
|
|
|
|
l.setBg(l.config.ColorBgDefault)
|
2016-06-06 20:46:28 +02:00
|
|
|
}
|
|
|
|
|
2016-06-06 20:04:38 +02:00
|
|
|
// PrintBanner prints a text (banner) with BannerFgColor, BannerBgColor and a success message at the end
|
|
|
|
// It doesn't cares if the logger is disabled or not, it will print this
|
2016-06-18 00:11:03 +02:00
|
|
|
func (l *Logger) PrintBanner(banner string, successMessage string) {
|
2016-06-24 00:34:49 +02:00
|
|
|
c := color.New(attr(l.config.ColorFgBanner))
|
|
|
|
if l.config.ColorBgDefault > 0 {
|
|
|
|
c.Add(attr(l.config.ColorBgDefault))
|
|
|
|
}
|
2016-06-06 20:04:38 +02:00
|
|
|
c.Println(banner)
|
|
|
|
bannersRan++
|
|
|
|
|
2016-06-18 00:11:03 +02:00
|
|
|
if successMessage != "" {
|
2016-06-24 00:34:49 +02:00
|
|
|
c.Add(attr(l.config.ColorFgSuccess))
|
|
|
|
if l.config.ColorBgSuccess > 0 {
|
|
|
|
c.Add(attr(l.config.ColorBgSuccess))
|
|
|
|
}
|
2016-06-06 20:04:38 +02:00
|
|
|
if bannersRan > 1 {
|
|
|
|
c.Printf("Server[%#v]\n", bannersRan)
|
|
|
|
|
|
|
|
}
|
2016-06-18 00:11:03 +02:00
|
|
|
c.Println(successMessage)
|
2016-06-06 20:04:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
c.DisableColor()
|
|
|
|
c = nil
|
|
|
|
}
|
|
|
|
|
2016-05-30 16:08:09 +02:00
|
|
|
// Printf calls l.Output to print to the logger.
|
|
|
|
// Arguments are handled in the manner of fmt.Printf.
|
|
|
|
func (l *Logger) Printf(format string, a ...interface{}) {
|
2016-06-06 20:04:38 +02:00
|
|
|
if !l.config.Disabled {
|
2016-06-06 20:46:28 +02:00
|
|
|
l.underline.Printf(l.config.Prefix+format, a...)
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-06 20:46:28 +02:00
|
|
|
// Print calls l.Output to print to the logger.
|
|
|
|
// Arguments are handled in the manner of fmt.Print.
|
|
|
|
func (l *Logger) Print(a interface{}) {
|
2016-06-06 20:04:38 +02:00
|
|
|
if !l.config.Disabled {
|
2016-06-14 07:45:40 +02:00
|
|
|
l.ResetColors()
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Printf("%#v", a)
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-06 20:46:28 +02:00
|
|
|
// Println calls l.Output to print to the logger.
|
|
|
|
// Arguments are handled in the manner of fmt.Println.
|
|
|
|
func (l *Logger) Println(a interface{}) {
|
2016-06-06 20:04:38 +02:00
|
|
|
if !l.config.Disabled {
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Printf("%#v\n", a)
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-06 20:46:28 +02:00
|
|
|
// Fatal is equivalent to l.Dangerf("%#v",interface{}) followed by a call to panic().
|
|
|
|
func (l *Logger) Fatal(a interface{}) {
|
|
|
|
l.Warningf("%#v", a)
|
|
|
|
panic("")
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
|
2016-06-06 20:46:28 +02:00
|
|
|
// Fatalf is equivalent to l.Warningf() followed by a call to os.Exit(1).
|
|
|
|
func (l *Logger) Fatalf(format string, a ...interface{}) {
|
|
|
|
l.Warningf(format, a...)
|
2016-06-06 20:04:38 +02:00
|
|
|
os.Exit(1)
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
|
2016-06-06 20:46:28 +02:00
|
|
|
// Panic is equivalent to l.Dangerf("%#v",interface{}) followed by a call to panic().
|
|
|
|
func (l *Logger) Panic(a interface{}) {
|
2016-06-16 04:24:01 +02:00
|
|
|
l.Dangerf("%s\n", a)
|
2016-06-19 09:32:20 +02:00
|
|
|
panic(a)
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
|
2016-06-06 20:46:28 +02:00
|
|
|
// Panicf is equivalent to l.Dangerf() followed by a call to panic().
|
2016-05-30 16:08:09 +02:00
|
|
|
func (l *Logger) Panicf(format string, a ...interface{}) {
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Dangerf(format, a...)
|
2016-06-06 20:04:38 +02:00
|
|
|
panic("")
|
|
|
|
}
|
|
|
|
|
2016-06-18 00:11:03 +02:00
|
|
|
// Successf calls l.Output to print to the logger with the Success colors.
|
2016-06-06 20:04:38 +02:00
|
|
|
// Arguments are handled in the manner of fmt.Printf.
|
2016-06-18 00:11:03 +02:00
|
|
|
func (l *Logger) Successf(format string, a ...interface{}) {
|
2016-06-06 20:04:38 +02:00
|
|
|
if !l.config.Disabled {
|
2016-06-24 00:34:49 +02:00
|
|
|
l.underline.Add(attr(l.config.ColorFgSuccess))
|
|
|
|
l.setBg(l.config.ColorBgSuccess)
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Printf(format, a...)
|
2016-06-06 20:04:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Infof calls l.Output to print to the logger with the Info colors.
|
|
|
|
// Arguments are handled in the manner of fmt.Printf.
|
|
|
|
func (l *Logger) Infof(format string, a ...interface{}) {
|
|
|
|
if !l.config.Disabled {
|
2016-06-24 00:34:49 +02:00
|
|
|
l.underline.Add(attr(l.config.ColorFgInfo))
|
|
|
|
l.setBg(l.config.ColorBgInfo)
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Printf(format, a...)
|
2016-06-06 20:04:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Warningf calls l.Output to print to the logger with the Warning colors.
|
|
|
|
// Arguments are handled in the manner of fmt.Printf.
|
|
|
|
func (l *Logger) Warningf(format string, a ...interface{}) {
|
|
|
|
if !l.config.Disabled {
|
2016-06-24 00:34:49 +02:00
|
|
|
l.underline.Add(attr(l.config.ColorFgWarning))
|
|
|
|
l.setBg(l.config.ColorBgWarning)
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Printf(format, a...)
|
2016-06-06 20:04:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Dangerf calls l.Output to print to the logger with the Danger colors.
|
|
|
|
// Arguments are handled in the manner of fmt.Printf.
|
|
|
|
func (l *Logger) Dangerf(format string, a ...interface{}) {
|
|
|
|
if !l.config.Disabled {
|
2016-06-24 00:34:49 +02:00
|
|
|
l.underline.Add(attr(l.config.ColorFgDanger))
|
|
|
|
l.setBg(l.config.ColorBgDanger)
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Printf(format, a...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Otherf calls l.Output to print to the logger with the Other colors.
|
|
|
|
// Arguments are handled in the manner of fmt.Printf.
|
|
|
|
func (l *Logger) Otherf(format string, a ...interface{}) {
|
|
|
|
if !l.config.Disabled {
|
2016-06-24 00:34:49 +02:00
|
|
|
l.underline.Add(attr(l.config.ColorFgOther))
|
|
|
|
l.setBg(l.config.ColorBgOther)
|
2016-06-06 20:46:28 +02:00
|
|
|
l.Printf(format, a...)
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
}
|