mirror of
https://github.com/tarampampam/error-pages.git
synced 2024-08-30 18:22:40 +00:00
39 lines
949 B
Go
39 lines
949 B
Go
|
// Package logger contains functions for a working with application logging.
|
||
|
package logger
|
||
|
|
||
|
import (
|
||
|
"go.uber.org/zap"
|
||
|
"go.uber.org/zap/zapcore"
|
||
|
)
|
||
|
|
||
|
// New creates new "zap" logger with little customization.
|
||
|
func New(verbose, debug, logJSON bool) (*zap.Logger, error) {
|
||
|
var config zap.Config
|
||
|
|
||
|
if logJSON {
|
||
|
config = zap.NewProductionConfig()
|
||
|
} else {
|
||
|
config = zap.NewDevelopmentConfig()
|
||
|
config.EncoderConfig.EncodeLevel = zapcore.LowercaseColorLevelEncoder
|
||
|
config.EncoderConfig.EncodeTime = zapcore.TimeEncoderOfLayout("15:04:05")
|
||
|
}
|
||
|
|
||
|
// default configuration for all encoders
|
||
|
config.Level = zap.NewAtomicLevelAt(zap.InfoLevel)
|
||
|
config.Development = false
|
||
|
config.DisableStacktrace = true
|
||
|
config.DisableCaller = true
|
||
|
|
||
|
if debug {
|
||
|
config.Development = true
|
||
|
config.DisableStacktrace = false
|
||
|
config.DisableCaller = false
|
||
|
}
|
||
|
|
||
|
if verbose || debug {
|
||
|
config.Level = zap.NewAtomicLevelAt(zap.DebugLevel)
|
||
|
}
|
||
|
|
||
|
return config.Build()
|
||
|
}
|