2022-01-06 06:40:23 -05:00
|
|
|
package settings
|
|
|
|
|
|
|
|
|
|
import (
|
2024-03-25 19:14:20 +00:00
|
|
|
"fmt"
|
|
|
|
|
|
2023-05-25 12:08:43 +00:00
|
|
|
"github.com/qdm12/gosettings"
|
2024-03-25 19:14:20 +00:00
|
|
|
"github.com/qdm12/gosettings/reader"
|
2022-01-06 06:40:23 -05:00
|
|
|
"github.com/qdm12/gotree"
|
2022-03-30 07:46:53 +00:00
|
|
|
"github.com/qdm12/log"
|
2022-01-06 06:40:23 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// Log contains settings to configure the logger.
|
|
|
|
|
type Log struct {
|
|
|
|
|
// Level is the log level of the logger.
|
2024-03-25 19:14:20 +00:00
|
|
|
// It cannot be empty in the internal state.
|
|
|
|
|
Level string
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (l Log) validate() (err error) {
|
2024-03-25 19:14:20 +00:00
|
|
|
_, err = log.ParseLevel(l.Level)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("level: %w", err)
|
|
|
|
|
}
|
2022-01-06 06:40:23 -05:00
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (l *Log) copy() (copied Log) {
|
|
|
|
|
return Log{
|
2024-03-25 19:14:20 +00:00
|
|
|
Level: l.Level,
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// overrideWith overrides fields of the receiver
|
|
|
|
|
// settings object with any field set in the other
|
|
|
|
|
// settings.
|
|
|
|
|
func (l *Log) overrideWith(other Log) {
|
2024-03-25 19:14:20 +00:00
|
|
|
l.Level = gosettings.OverrideWithComparable(l.Level, other.Level)
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (l *Log) setDefaults() {
|
2024-03-25 19:14:20 +00:00
|
|
|
l.Level = gosettings.DefaultComparable(l.Level, log.LevelInfo.String())
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (l Log) String() string {
|
|
|
|
|
return l.toLinesNode().String()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (l Log) toLinesNode() (node *gotree.Node) {
|
|
|
|
|
node = gotree.New("Log settings:")
|
2024-03-25 19:14:20 +00:00
|
|
|
node.Appendf("Log level: %s", l.Level)
|
2022-01-06 06:40:23 -05:00
|
|
|
return node
|
|
|
|
|
}
|
2024-03-25 19:14:20 +00:00
|
|
|
|
|
|
|
|
func (l *Log) read(r *reader.Reader) (err error) {
|
|
|
|
|
l.Level = r.String("LOG_LEVEL")
|
|
|
|
|
return nil
|
|
|
|
|
}
|