2020-01-18 23:30:09 +00:00
|
|
|
package webrtc
|
|
|
|
|
|
|
|
import (
|
2020-01-24 15:47:37 +00:00
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
2020-01-18 23:30:09 +00:00
|
|
|
"github.com/pion/logging"
|
|
|
|
"github.com/rs/zerolog"
|
|
|
|
)
|
|
|
|
|
2020-01-25 14:29:52 +00:00
|
|
|
type nulllog struct{}
|
|
|
|
|
|
|
|
func (l nulllog) Trace(msg string) {}
|
|
|
|
func (l nulllog) Tracef(format string, args ...interface{}) {}
|
|
|
|
func (l nulllog) Debug(msg string) {}
|
|
|
|
func (l nulllog) Debugf(format string, args ...interface{}) {}
|
|
|
|
func (l nulllog) Info(msg string) {}
|
|
|
|
func (l nulllog) Infof(format string, args ...interface{}) {}
|
|
|
|
func (l nulllog) Warn(msg string) {}
|
|
|
|
func (l nulllog) Warnf(format string, args ...interface{}) {}
|
|
|
|
func (l nulllog) Error(msg string) {}
|
|
|
|
func (l nulllog) Errorf(format string, args ...interface{}) {}
|
|
|
|
|
2020-01-18 23:30:09 +00:00
|
|
|
type logger struct {
|
2020-01-25 14:29:52 +00:00
|
|
|
logger zerolog.Logger
|
|
|
|
subsystem string
|
2020-01-18 23:30:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (l logger) Trace(msg string) { l.logger.Trace().Msg(msg) }
|
|
|
|
func (l logger) Tracef(format string, args ...interface{}) { l.logger.Trace().Msgf(format, args...) }
|
|
|
|
func (l logger) Debug(msg string) { l.logger.Debug().Msg(msg) }
|
|
|
|
func (l logger) Debugf(format string, args ...interface{}) { l.logger.Debug().Msgf(format, args...) }
|
2020-01-24 15:47:37 +00:00
|
|
|
func (l logger) Info(msg string) {
|
|
|
|
if strings.Contains(msg, "packetio.Buffer is full") {
|
2020-01-25 14:29:52 +00:00
|
|
|
//l.logger.Panic().Msg(msg)
|
|
|
|
return
|
2020-01-24 15:47:37 +00:00
|
|
|
}
|
|
|
|
l.logger.Info().Msg(msg)
|
|
|
|
}
|
|
|
|
func (l logger) Infof(format string, args ...interface{}) {
|
|
|
|
msg := fmt.Sprintf(format, args...)
|
|
|
|
if strings.Contains(msg, "packetio.Buffer is full") {
|
2020-01-25 14:29:52 +00:00
|
|
|
// l.logger.Panic().Msg(msg)
|
|
|
|
return
|
2020-01-24 15:47:37 +00:00
|
|
|
}
|
2020-01-25 14:29:52 +00:00
|
|
|
l.logger.Info().Msg(msg)
|
2020-01-24 15:47:37 +00:00
|
|
|
}
|
2020-01-18 23:30:09 +00:00
|
|
|
func (l logger) Warn(msg string) { l.logger.Warn().Msg(msg) }
|
|
|
|
func (l logger) Warnf(format string, args ...interface{}) { l.logger.Warn().Msgf(format, args...) }
|
|
|
|
func (l logger) Error(msg string) { l.logger.Error().Msg(msg) }
|
|
|
|
func (l logger) Errorf(format string, args ...interface{}) { l.logger.Error().Msgf(format, args...) }
|
|
|
|
|
|
|
|
type loggerFactory struct {
|
|
|
|
logger zerolog.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l loggerFactory) NewLogger(subsystem string) logging.LeveledLogger {
|
2020-01-25 14:29:52 +00:00
|
|
|
if subsystem == "sctp" {
|
|
|
|
return nulllog{}
|
|
|
|
}
|
|
|
|
|
2020-01-18 23:30:09 +00:00
|
|
|
return logger{
|
2020-01-25 14:29:52 +00:00
|
|
|
subsystem: subsystem,
|
|
|
|
logger: l.logger.With().Str("subsystem", subsystem).Logger(),
|
2020-01-18 23:30:09 +00:00
|
|
|
}
|
|
|
|
}
|