2024-10-29 16:50:52 +01:00
|
|
|
package build
|
|
|
|
|
2024-10-29 16:58:23 +01:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/btcsuite/btclog/v2"
|
|
|
|
)
|
2024-10-29 16:50:52 +01:00
|
|
|
|
|
|
|
const (
|
|
|
|
callSiteOff = "off"
|
|
|
|
callSiteShort = "short"
|
|
|
|
callSiteLong = "long"
|
2024-10-29 16:58:23 +01:00
|
|
|
|
|
|
|
defaultLogCompressor = Gzip
|
2024-10-29 17:08:08 +01:00
|
|
|
|
|
|
|
// DefaultMaxLogFiles is the default maximum number of log files to
|
|
|
|
// keep.
|
2024-10-30 12:23:18 +01:00
|
|
|
DefaultMaxLogFiles = 10
|
2024-10-29 17:08:08 +01:00
|
|
|
|
|
|
|
// DefaultMaxLogFileSize is the default maximum log file size in MB.
|
2024-10-30 12:23:18 +01:00
|
|
|
DefaultMaxLogFileSize = 20
|
2024-10-29 16:50:52 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// LogConfig holds logging configuration options.
|
|
|
|
//
|
|
|
|
//nolint:lll
|
|
|
|
type LogConfig struct {
|
|
|
|
Console *consoleLoggerCfg `group:"console" namespace:"console" description:"The logger writing to stdout and stderr."`
|
2024-10-29 16:53:24 +01:00
|
|
|
File *FileLoggerConfig `group:"file" namespace:"file" description:"The logger writing to LND's standard log file."`
|
2024-10-29 16:50:52 +01:00
|
|
|
}
|
|
|
|
|
2024-10-29 16:58:23 +01:00
|
|
|
// Validate validates the LogConfig struct values.
|
|
|
|
func (c *LogConfig) Validate() error {
|
|
|
|
if !SupportedLogCompressor(c.File.Compressor) {
|
|
|
|
return fmt.Errorf("invalid log compressor: %v",
|
|
|
|
c.File.Compressor)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-10-29 16:50:52 +01:00
|
|
|
// LoggerConfig holds options for a particular logger.
|
|
|
|
//
|
|
|
|
//nolint:lll
|
|
|
|
type LoggerConfig struct {
|
|
|
|
Disable bool `long:"disable" description:"Disable this logger."`
|
|
|
|
NoTimestamps bool `long:"no-timestamps" description:"Omit timestamps from log lines."`
|
|
|
|
CallSite string `long:"call-site" description:"Include the call-site of each log line." choice:"off" choice:"short" choice:"long"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// DefaultLogConfig returns the default logging config options.
|
|
|
|
func DefaultLogConfig() *LogConfig {
|
|
|
|
return &LogConfig{
|
|
|
|
Console: defaultConsoleLoggerCfg(),
|
2024-10-29 16:53:24 +01:00
|
|
|
File: &FileLoggerConfig{
|
2024-10-29 17:08:08 +01:00
|
|
|
Compressor: defaultLogCompressor,
|
|
|
|
MaxLogFiles: DefaultMaxLogFiles,
|
|
|
|
MaxLogFileSize: DefaultMaxLogFileSize,
|
2024-10-29 16:53:24 +01:00
|
|
|
LoggerConfig: LoggerConfig{
|
|
|
|
CallSite: callSiteOff,
|
|
|
|
},
|
2024-10-29 16:50:52 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// HandlerOptions returns the set of btclog.HandlerOptions that the state of the
|
|
|
|
// config struct translates to.
|
|
|
|
func (cfg *LoggerConfig) HandlerOptions() []btclog.HandlerOption {
|
|
|
|
opts := []btclog.HandlerOption{
|
|
|
|
// The default skip depth used by the logging library is 6 but
|
|
|
|
// since we wrap the logging handlers with another level of
|
|
|
|
// abstraction with the handlerSet, we increase the skip depth
|
|
|
|
// to 7 here.
|
|
|
|
btclog.WithCallSiteSkipDepth(7),
|
|
|
|
}
|
|
|
|
|
|
|
|
if cfg.NoTimestamps {
|
|
|
|
opts = append(opts, btclog.WithNoTimestamp())
|
|
|
|
}
|
|
|
|
|
|
|
|
switch cfg.CallSite {
|
|
|
|
case callSiteShort:
|
|
|
|
opts = append(opts, btclog.WithCallerFlags(btclog.Lshortfile))
|
|
|
|
case callSiteLong:
|
|
|
|
opts = append(opts, btclog.WithCallerFlags(btclog.Llongfile))
|
|
|
|
}
|
|
|
|
|
|
|
|
return opts
|
|
|
|
}
|
2024-10-29 16:53:24 +01:00
|
|
|
|
|
|
|
// FileLoggerConfig extends LoggerConfig with specific log file options.
|
2024-10-29 16:58:23 +01:00
|
|
|
//
|
|
|
|
//nolint:lll
|
2024-10-29 16:53:24 +01:00
|
|
|
type FileLoggerConfig struct {
|
|
|
|
LoggerConfig
|
2024-10-29 17:08:08 +01:00
|
|
|
Compressor string `long:"compressor" description:"Compression algorithm to use when rotating logs." choice:"gzip" choice:"zstd"`
|
|
|
|
MaxLogFiles int `long:"max-files" description:"Maximum logfiles to keep (0 for no rotation)"`
|
|
|
|
MaxLogFileSize int `long:"max-file-size" description:"Maximum logfile size in MB"`
|
2024-10-29 16:53:24 +01:00
|
|
|
}
|