mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
8dedcb8c51
Relevant changes; - swarmkit#2681 Handle an edge case in CA rotation where we reclaim CA service from an external CA - swarmkit#2750 Use gometalinter; switch from x/net/context -> context Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
31 lines
874 B
Go
31 lines
874 B
Go
package log
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/sirupsen/logrus"
|
|
"google.golang.org/grpc/grpclog"
|
|
)
|
|
|
|
type logrusWrapper struct {
|
|
*logrus.Entry
|
|
}
|
|
|
|
// V provides the functionality that returns whether a particular log level is at
|
|
// least l - this is needed to meet the LoggerV2 interface. GRPC's logging levels
|
|
// are: https://github.com/grpc/grpc-go/blob/master/grpclog/loggerv2.go#L71
|
|
// 0=info, 1=warning, 2=error, 3=fatal
|
|
// logrus's are: https://github.com/sirupsen/logrus/blob/master/logrus.go
|
|
// 0=panic, 1=fatal, 2=error, 3=warn, 4=info, 5=debug
|
|
func (lw logrusWrapper) V(l int) bool {
|
|
// translate to logrus level
|
|
logrusLevel := 4 - l
|
|
return int(lw.Logger.Level) <= logrusLevel
|
|
}
|
|
|
|
func init() {
|
|
ctx := WithModule(context.Background(), "grpc")
|
|
|
|
// completely replace the grpc logger with the logrus logger.
|
|
grpclog.SetLoggerV2(logrusWrapper{Entry: G(ctx)})
|
|
}
|