Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ErrLoggingInstance = errors.New("errLoggingInstance")
ErrLoggingInstance is the error returned when encountering issues registering, removing, fetching, or updating logging instances from the logging Manager.
Functions ¶
func DefaultFormatter ¶
DefaultFormatter is the default logging instance formatter -- this formatter simply adds colors to the log message based on log level.
func DefaultKlogFormatter ¶
DefaultKlogFormatter is the default logging instance formatter for *klog* logs. Ortica redirects klog logs through its own logging manager to give us more control, this formatter is applied by default to those messages only.
func InitManager ¶ added in v0.0.13
func InitManager(options ...Option)
InitManager initializes the logging manager with the provided options. It does nothing if the manager has already been initialized. This may be a bit awkward but since this is not expected to be used by anything but clabernetes and it works for us, it works!
func StdErrLog ¶ added in v0.0.13
func StdErrLog(a ...any)
StdErrLog writes `a` to stderr, it ignores failures.
func ValidateLogLevel ¶
ValidateLogLevel accepts a string l and returns a case-normalized log level corresponding to l, if l is a valid log level, or an error.
Types ¶
type Formatter ¶
Formatter is a type representing a valid logging formatter function. It should accept a logging instance, a level string, and a message string, returning a formatted message string.
type Instance ¶
type Instance interface { Debug(f string) Debugf(f string, a ...interface{}) Info(f string) Infof(f string, a ...interface{}) Warn(f string) Warnf(f string, a ...interface{}) Critical(f string) Criticalf(f string, a ...interface{}) // Write implements io.Writer so that an instance can be used most places. Messages received // via Write will always have the current formatter applied, and all messages will be queued // for egress unless this logging instance's level is Disabled. Write(p []byte) (n int, err error) GetName() string GetLevel() string }
Instance is a logging instance managed by the Manager.
type Manager ¶
type Manager interface { SetLoggerFormatter(name string, formatter Formatter) error SetLoggerFormatterAllInstances(formatter Formatter) SetLoggerLevelAllInstances(level string) SetLoggerLevel(name, level string) error RegisterLogger(name, level string) error RegisterAndGetLogger(name, level string) (Instance, error) MustRegisterAndGetLogger(name, level string) Instance GetLogger(name string) (Instance, error) DeleteLogger(name string) Flush() }
Manager is the interface representing the global logging manager singleton, this interface defines the ways to interact with this object.
func GetManager ¶
func GetManager() Manager
GetManager returns the global logging Manager. Panics if the logging manager has *not* been initialized (via InitManager).
type Option ¶ added in v0.0.13
type Option func(m *manager)
Option is a functional option type for applying options to the logging Manager.
func WithLogger ¶ added in v0.0.13
func WithLogger(logger func(...interface{})) Option
WithLogger appends a logger (a function that accepts an interface) to the logging Manager's set of loggers.