mirror of
https://github.com/status-im/status-go.git
synced 2025-01-10 14:47:06 +00:00
eeca435064
Update vendor Integrate rendezvous into status node Add a test with failover using rendezvous Use multiple servers in client Use discovery V5 by default and test that node can be started with rendezvous discovet Fix linter Update rendezvous client to one with instrumented stream Address feedback Fix test with updated topic limits Apply several suggestions Change log to debug for request errors because we continue execution Remove web3js after rebase Update rendezvous package
127 lines
2.9 KiB
Go
127 lines
2.9 KiB
Go
package log
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"os"
|
|
|
|
tracer "github.com/ipfs/go-log/tracer"
|
|
|
|
colorable "github.com/mattn/go-colorable"
|
|
opentrace "github.com/opentracing/opentracing-go"
|
|
logging "github.com/whyrusleeping/go-logging"
|
|
)
|
|
|
|
func init() {
|
|
SetupLogging()
|
|
}
|
|
|
|
var ansiGray = "\033[0;37m"
|
|
var ansiBlue = "\033[0;34m"
|
|
|
|
// LogFormats defines formats for logging (i.e. "color")
|
|
var LogFormats = map[string]string{
|
|
"nocolor": "%{time:2006-01-02 15:04:05.000000} %{level} %{module} %{shortfile}: %{message}",
|
|
"color": ansiGray + "%{time:15:04:05.000} %{color}%{level:5.5s} " + ansiBlue +
|
|
"%{module:10.10s}: %{color:reset}%{message} " + ansiGray + "%{shortfile}%{color:reset}",
|
|
}
|
|
|
|
var defaultLogFormat = "color"
|
|
|
|
// Logging environment variables
|
|
const (
|
|
envLogging = "IPFS_LOGGING"
|
|
envLoggingFmt = "IPFS_LOGGING_FMT"
|
|
)
|
|
|
|
// ErrNoSuchLogger is returned when the util pkg is asked for a non existant logger
|
|
var ErrNoSuchLogger = errors.New("Error: No such logger")
|
|
|
|
// loggers is the set of loggers in the system
|
|
var loggers = map[string]*logging.Logger{}
|
|
|
|
// SetupLogging will initialize the logger backend and set the flags.
|
|
func SetupLogging() {
|
|
|
|
lfmt := LogFormats[os.Getenv(envLoggingFmt)]
|
|
if lfmt == "" {
|
|
lfmt = LogFormats[defaultLogFormat]
|
|
}
|
|
|
|
backend := logging.NewLogBackend(colorable.NewColorableStderr(), "", 0)
|
|
logging.SetBackend(backend)
|
|
logging.SetFormatter(logging.MustStringFormatter(lfmt))
|
|
|
|
lvl := logging.ERROR
|
|
|
|
if logenv := os.Getenv(envLogging); logenv != "" {
|
|
var err error
|
|
lvl, err = logging.LogLevel(logenv)
|
|
if err != nil {
|
|
fmt.Println("error setting log levels", err)
|
|
}
|
|
}
|
|
|
|
// TracerPlugins are instantiated after this, so use loggable tracer
|
|
// by default, if a TracerPlugin is added it will override this
|
|
lgblRecorder := tracer.NewLoggableRecorder()
|
|
lgblTracer := tracer.New(lgblRecorder)
|
|
opentrace.SetGlobalTracer(lgblTracer)
|
|
|
|
SetAllLoggers(lvl)
|
|
}
|
|
|
|
// SetDebugLogging calls SetAllLoggers with logging.DEBUG
|
|
func SetDebugLogging() {
|
|
SetAllLoggers(logging.DEBUG)
|
|
}
|
|
|
|
// SetAllLoggers changes the logging.Level of all loggers to lvl
|
|
func SetAllLoggers(lvl logging.Level) {
|
|
logging.SetLevel(lvl, "")
|
|
for n := range loggers {
|
|
logging.SetLevel(lvl, n)
|
|
}
|
|
}
|
|
|
|
// SetLogLevel changes the log level of a specific subsystem
|
|
// name=="*" changes all subsystems
|
|
func SetLogLevel(name, level string) error {
|
|
lvl, err := logging.LogLevel(level)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// wildcard, change all
|
|
if name == "*" {
|
|
SetAllLoggers(lvl)
|
|
return nil
|
|
}
|
|
|
|
// Check if we have a logger by that name
|
|
if _, ok := loggers[name]; !ok {
|
|
return ErrNoSuchLogger
|
|
}
|
|
|
|
logging.SetLevel(lvl, name)
|
|
|
|
return nil
|
|
}
|
|
|
|
// GetSubsystems returns a slice containing the
|
|
// names of the current loggers
|
|
func GetSubsystems() []string {
|
|
subs := make([]string, 0, len(loggers))
|
|
|
|
for k := range loggers {
|
|
subs = append(subs, k)
|
|
}
|
|
return subs
|
|
}
|
|
|
|
func getLogger(name string) *logging.Logger {
|
|
log := logging.MustGetLogger(name)
|
|
loggers[name] = log
|
|
return log
|
|
}
|