updated hlog
This commit is contained in:
@@ -9,17 +9,42 @@ import (
|
||||
"github.com/rs/zerolog/pkgerrors"
|
||||
)
|
||||
|
||||
type Logger = zerolog.Logger
|
||||
// Logger wraps a zerolog.Logger and manages an optional log file.
|
||||
// It embeds *zerolog.Logger, so all zerolog methods are available directly.
|
||||
type Logger struct {
|
||||
*zerolog.Logger
|
||||
logFile *os.File
|
||||
}
|
||||
|
||||
// Get a pointer to a new zerolog.Logger with the specified level and output
|
||||
// Can provide a file, writer or both. Must provide at least one of the two
|
||||
// NewLogger creates a new Logger instance based on the provided configuration.
|
||||
//
|
||||
// The logger output depends on cfg.LogOutput:
|
||||
// - "console": Logs to the provided io.Writer w
|
||||
// - "file": Logs to a file in cfg.LogDir (w can be nil)
|
||||
// - "both": Logs to both the io.Writer and a file
|
||||
//
|
||||
// When file logging is enabled, cfg.LogDir must be set to a valid directory path.
|
||||
// The log file will be named "server.log" and placed in that directory.
|
||||
//
|
||||
// The logger is configured with:
|
||||
// - Unix timestamp format
|
||||
// - Error stack trace marshaling
|
||||
// - Log level from cfg.LogLevel
|
||||
//
|
||||
// Returns an error if:
|
||||
// - cfg is nil
|
||||
// - w is nil when cfg.LogOutput is not "file"
|
||||
// - cfg.LogDir is empty when file logging is enabled
|
||||
// - cfg.LogFileName is empty when file logging is enabled
|
||||
// - The log file cannot be created
|
||||
func NewLogger(
|
||||
logLevel zerolog.Level,
|
||||
cfg *Config,
|
||||
w io.Writer,
|
||||
logFile *os.File,
|
||||
logDir string,
|
||||
) (*Logger, error) {
|
||||
if w == nil && logFile == nil {
|
||||
if cfg == nil {
|
||||
return nil, errors.New("No config provided")
|
||||
}
|
||||
if w == nil && cfg.LogOutput != "file" {
|
||||
return nil, errors.New("No Writer provided for log output.")
|
||||
}
|
||||
|
||||
@@ -31,6 +56,21 @@ func NewLogger(
|
||||
consoleWriter = zerolog.ConsoleWriter{Out: w}
|
||||
}
|
||||
|
||||
var logFile *os.File
|
||||
var err error
|
||||
if cfg.LogOutput == "file" || cfg.LogOutput == "both" {
|
||||
if cfg.LogDir == "" {
|
||||
return nil, errors.New("LOG_DIR must be set when LOG_OUTPUT is 'file' or 'both'")
|
||||
}
|
||||
if cfg.LogFileName == "" {
|
||||
return nil, errors.New("LOG_FILE_NAME must be set when LOG_OUTPUT is 'file' or 'both'")
|
||||
}
|
||||
logFile, err = newLogFile(cfg.LogDir, cfg.LogFileName, cfg.LogAppend)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "newLogFile")
|
||||
}
|
||||
}
|
||||
|
||||
var output io.Writer
|
||||
if logFile != nil {
|
||||
if w != nil {
|
||||
@@ -41,11 +81,17 @@ func NewLogger(
|
||||
} else {
|
||||
output = consoleWriter
|
||||
}
|
||||
|
||||
logger := zerolog.New(output).
|
||||
With().
|
||||
Timestamp().
|
||||
Logger().
|
||||
Level(logLevel)
|
||||
Level(cfg.LogLevel)
|
||||
|
||||
return &logger, nil
|
||||
hlog := &Logger{
|
||||
Logger: &logger,
|
||||
logFile: logFile,
|
||||
}
|
||||
|
||||
return hlog, nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user