diff options
| -rw-r--r-- | go.mod | 2 | ||||
| -rw-r--r-- | go.sum | 2 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/.golangci.yml | 40 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/.travis.yml | 14 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/README.md | 44 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/entry.go | 49 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/exported.go | 2 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/go.mod | 3 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/go.sum | 6 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/json_formatter.go | 4 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/logger.go | 11 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/logrus.go | 2 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/terminal_check_bsd.go | 2 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/terminal_check_js.go | 7 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/terminal_check_unix.go | 2 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/text_formatter.go | 47 | ||||
| -rw-r--r-- | vendor/github.com/sirupsen/logrus/writer.go | 6 | ||||
| -rw-r--r-- | vendor/modules.txt | 2 | 
18 files changed, 181 insertions, 64 deletions
| @@ -49,7 +49,7 @@ require (  	github.com/pmezard/go-difflib v1.0.0  	github.com/rootless-containers/rootlesskit v0.8.0  	github.com/seccomp/containers-golang v0.0.0-20190312124753-8ca8945ccf5f -	github.com/sirupsen/logrus v1.4.2 +	github.com/sirupsen/logrus v1.5.0  	github.com/spf13/cobra v0.0.6  	github.com/spf13/pflag v1.0.5  	github.com/stretchr/testify v1.5.1 @@ -432,6 +432,8 @@ github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPx  github.com/sirupsen/logrus v1.4.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q=  github.com/sirupsen/logrus v1.4.2 h1:SPIRibHv4MatM3XXNO2BJeFLZwZ2LvZgfQ5+UNI2im4=  github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= +github.com/sirupsen/logrus v1.5.0 h1:1N5EYkVAPEywqZRJd7cwnRtCb6xJx7NH3T3WUTF980Q= +github.com/sirupsen/logrus v1.5.0/go.mod h1:+F7Ogzej0PZc/94MaYx/nvG9jOFMD2osvC3s+Squfpo=  github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM=  github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=  github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ= diff --git a/vendor/github.com/sirupsen/logrus/.golangci.yml b/vendor/github.com/sirupsen/logrus/.golangci.yml new file mode 100644 index 000000000..65dc28503 --- /dev/null +++ b/vendor/github.com/sirupsen/logrus/.golangci.yml @@ -0,0 +1,40 @@ +run: +  # do not run on test files yet +  tests: false + +# all available settings of specific linters +linters-settings: +  errcheck: +    # report about not checking of errors in type assetions: `a := b.(MyStruct)`; +    # default is false: such cases aren't reported by default. +    check-type-assertions: false + +    # report about assignment of errors to blank identifier: `num, _ := strconv.Atoi(numStr)`; +    # default is false: such cases aren't reported by default. +    check-blank: false + +  lll: +    line-length: 100 +    tab-width: 4 + +  prealloc: +    simple: false +    range-loops: false +    for-loops: false + +  whitespace: +    multi-if: false   # Enforces newlines (or comments) after every multi-line if statement +    multi-func: false # Enforces newlines (or comments) after every multi-line function signature + +linters: +  enable: +    - megacheck +    - govet +  disable: +    - maligned +    - prealloc +  disable-all: false +  presets: +    - bugs +    - unused +  fast: false diff --git a/vendor/github.com/sirupsen/logrus/.travis.yml b/vendor/github.com/sirupsen/logrus/.travis.yml index 848938a6d..5e20aa414 100644 --- a/vendor/github.com/sirupsen/logrus/.travis.yml +++ b/vendor/github.com/sirupsen/logrus/.travis.yml @@ -4,21 +4,13 @@ git:    depth: 1  env:    - GO111MODULE=on -  - GO111MODULE=off -go: [ 1.11.x, 1.12.x ] -os: [ linux, osx ] -matrix: -  exclude: -    - go: 1.12.x -      env: GO111MODULE=off -    - go: 1.11.x -      os: osx +go: [1.13.x, 1.14.x] +os: [linux, osx]  install:    - ./travis/install.sh -  - if [[ "$GO111MODULE" ==  "on" ]]; then go mod download; fi -  - if [[ "$GO111MODULE" == "off" ]]; then go get github.com/stretchr/testify/assert golang.org/x/sys/unix github.com/konsorten/go-windows-terminal-sequences; fi  script:    - ./travis/cross_build.sh +  - ./travis/lint.sh    - export GOMAXPROCS=4    - export GORACE=halt_on_error=1    - go test -race -v ./... diff --git a/vendor/github.com/sirupsen/logrus/README.md b/vendor/github.com/sirupsen/logrus/README.md index a4796eb07..5796706db 100644 --- a/vendor/github.com/sirupsen/logrus/README.md +++ b/vendor/github.com/sirupsen/logrus/README.md @@ -1,8 +1,28 @@ -# Logrus <img src="http://i.imgur.com/hTeVwmJ.png" width="40" height="40" alt=":walrus:" class="emoji" title=":walrus:"/> [](https://travis-ci.org/sirupsen/logrus) [](https://godoc.org/github.com/sirupsen/logrus) +# Logrus <img src="http://i.imgur.com/hTeVwmJ.png" width="40" height="40" alt=":walrus:" class="emoji" title=":walrus:"/> [](https://travis-ci.org/sirupsen/logrus) [](https://godoc.org/github.com/sirupsen/logrus)  Logrus is a structured logger for Go (golang), completely API compatible with  the standard library logger. +**Logrus is in maintenance-mode.** We will not be introducing new features. It's +simply too hard to do in a way that won't break many people's projects, which is +the last thing you want from your Logging library (again...). + +This does not mean Logrus is dead. Logrus will continue to be maintained for +security, (backwards compatible) bug fixes, and performance (where we are +limited by the interface).  + +I believe Logrus' biggest contribution is to have played a part in today's +widespread use of structured logging in Golang. There doesn't seem to be a +reason to do a major, breaking iteration into Logrus V2, since the fantastic Go +community has built those independently. Many fantastic alternatives have sprung +up. Logrus would look like those, had it been re-designed with what we know +about structured logging in Go today. Check out, for example, +[Zerolog][zerolog], [Zap][zap], and [Apex][apex]. + +[zerolog]: https://github.com/rs/zerolog +[zap]: https://github.com/uber-go/zap +[apex]: https://github.com/apex/log +  **Seeing weird case-sensitive problems?** It's in the past been possible to  import Logrus as both upper- and lower-case. Due to the Go package environment,  this caused issues in the community and we needed a standard. Some environments @@ -15,11 +35,6 @@ comments](https://github.com/sirupsen/logrus/issues/553#issuecomment-306591437).  For an in-depth explanation of the casing issue, see [this  comment](https://github.com/sirupsen/logrus/issues/570#issuecomment-313933276). -**Are you interested in assisting in maintaining Logrus?** Currently I have a -lot of obligations, and I am unable to provide Logrus with the maintainership it -needs. If you'd like to help, please reach out to me at `simon at author's -username dot com`. -  Nicely color-coded in development (when a TTY is attached, otherwise just  plain text): @@ -187,7 +202,7 @@ func main() {    log.Out = os.Stdout    // You could set this to any `io.Writer` such as a file -  // file, err := os.OpenFile("logrus.log", os.O_CREATE|os.O_WRONLY, 0666) +  // file, err := os.OpenFile("logrus.log", os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)    // if err == nil {    //  log.Out = file    // } else { @@ -272,7 +287,7 @@ func init() {  ```  Note: Syslog hook also support connecting to local syslog (Ex. "/dev/log" or "/var/run/syslog" or "/var/run/log"). For the detail, please check the [syslog hook README](hooks/syslog/README.md). -A list of currently known of service hook can be found in this wiki [page](https://github.com/sirupsen/logrus/wiki/Hooks) +A list of currently known service hooks can be found in this wiki [page](https://github.com/sirupsen/logrus/wiki/Hooks)  #### Level logging @@ -354,6 +369,7 @@ The built-in logging formatters are:      [github.com/mattn/go-colorable](https://github.com/mattn/go-colorable).    * When colors are enabled, levels are truncated to 4 characters by default. To disable      truncation set the `DisableLevelTruncation` field to `true`. +  * When outputting to a TTY, it's often helpful to visually scan down a column where all the levels are the same width. Setting the `PadLevelText` field to `true` enables this behavior, by adding padding to the level text.    * All options are listed in the [generated docs](https://godoc.org/github.com/sirupsen/logrus#TextFormatter).  * `logrus.JSONFormatter`. Logs fields as JSON.    * All options are listed in the [generated docs](https://godoc.org/github.com/sirupsen/logrus#JSONFormatter). @@ -364,8 +380,10 @@ Third party logging formatters:  * [`GELF`](https://github.com/fabienm/go-logrus-formatters). Formats entries so they comply to Graylog's [GELF 1.1 specification](http://docs.graylog.org/en/2.4/pages/gelf.html).  * [`logstash`](https://github.com/bshuster-repo/logrus-logstash-hook). Logs fields as [Logstash](http://logstash.net) Events.  * [`prefixed`](https://github.com/x-cray/logrus-prefixed-formatter). Displays log entry source along with alternative layout. -* [`zalgo`](https://github.com/aybabtme/logzalgo). Invoking the P͉̫o̳̼̊w̖͈̰͎e̬͔̭͂r͚̼̹̲ ̫͓͉̳͈ō̠͕͖̚f̝͍̠ ͕̲̞͖͑Z̖̫̤̫ͪa͉̬͈̗l͖͎g̳̥o̰̥̅!̣͔̲̻͊̄ ̙̘̦̹̦. +* [`zalgo`](https://github.com/aybabtme/logzalgo). Invoking the Power of Zalgo.  * [`nested-logrus-formatter`](https://github.com/antonfisher/nested-logrus-formatter). Converts logrus fields to a nested structure. +* [`powerful-logrus-formatter`](https://github.com/zput/zxcTool). get fileName, log's line number and the latest function's name when print log; Sava log to files. +* [`caption-json-formatter`](https://github.com/nolleh/caption_json_formatter). logrus's message json formatter with human-readable caption added.  You can define your formatter by implementing the `Formatter` interface,  requiring a `Format` method. `Format` takes an `*Entry`. `entry.Data` is a @@ -430,14 +448,14 @@ entries. It should not be a feature of the application-level logger.  | Tool | Description |  | ---- | ----------- | -|[Logrus Mate](https://github.com/gogap/logrus_mate)|Logrus mate is a tool for Logrus to manage loggers, you can initial logger's level, hook and formatter by config file, the logger will generated with different config at different environment.| +|[Logrus Mate](https://github.com/gogap/logrus_mate)|Logrus mate is a tool for Logrus to manage loggers, you can initial logger's level, hook and formatter by config file, the logger will be generated with different configs in different environments.|  |[Logrus Viper Helper](https://github.com/heirko/go-contrib/tree/master/logrusHelper)|An Helper around Logrus to wrap with spf13/Viper to load configuration with fangs! And to simplify Logrus configuration use some behavior of [Logrus Mate](https://github.com/gogap/logrus_mate). [sample](https://github.com/heirko/iris-contrib/blob/master/middleware/logrus-logger/example) |  #### Testing  Logrus has a built in facility for asserting the presence of log messages. This is implemented through the `test` hook and provides: -* decorators for existing logger (`test.NewLocal` and `test.NewGlobal`) which basically just add the `test` hook +* decorators for existing logger (`test.NewLocal` and `test.NewGlobal`) which basically just adds the `test` hook  * a test logger (`test.NewNullLogger`) that just records log messages (and does not output any):  ```go @@ -465,7 +483,7 @@ func TestSomething(t*testing.T){  Logrus can register one or more functions that will be called when any `fatal`  level message is logged. The registered handlers will be executed before -logrus performs a `os.Exit(1)`. This behavior may be helpful if callers need +logrus performs an `os.Exit(1)`. This behavior may be helpful if callers need  to gracefully shutdown. Unlike a `panic("Something went wrong...")` call which can be intercepted with a deferred `recover` a call to `os.Exit(1)` can not be intercepted.  ``` @@ -490,6 +508,6 @@ Situation when locking is not needed includes:    1) logger.Out is protected by locks. -  2) logger.Out is a os.File handler opened with `O_APPEND` flag, and every write is smaller than 4k. (This allow multi-thread/multi-process writing) +  2) logger.Out is an os.File handler opened with `O_APPEND` flag, and every write is smaller than 4k. (This allows multi-thread/multi-process writing)       (Refer to http://www.notthewizard.com/2014/06/17/are-files-appends-really-atomic/) diff --git a/vendor/github.com/sirupsen/logrus/entry.go b/vendor/github.com/sirupsen/logrus/entry.go index 63e25583c..27b14bfb1 100644 --- a/vendor/github.com/sirupsen/logrus/entry.go +++ b/vendor/github.com/sirupsen/logrus/entry.go @@ -85,10 +85,15 @@ func NewEntry(logger *Logger) *Entry {  	}  } +// Returns the bytes representation of this entry from the formatter. +func (entry *Entry) Bytes() ([]byte, error) { +	return entry.Logger.Formatter.Format(entry) +} +  // Returns the string representation from the reader and ultimately the  // formatter.  func (entry *Entry) String() (string, error) { -	serialized, err := entry.Logger.Formatter.Format(entry) +	serialized, err := entry.Bytes()  	if err != nil {  		return "", err  	} @@ -103,7 +108,11 @@ func (entry *Entry) WithError(err error) *Entry {  // Add a context to the Entry.  func (entry *Entry) WithContext(ctx context.Context) *Entry { -	return &Entry{Logger: entry.Logger, Data: entry.Data, Time: entry.Time, err: entry.err, Context: ctx} +	dataCopy := make(Fields, len(entry.Data)) +	for k, v := range entry.Data { +		dataCopy[k] = v +	} +	return &Entry{Logger: entry.Logger, Data: dataCopy, Time: entry.Time, err: entry.err, Context: ctx}  }  // Add a single field to the Entry. @@ -113,6 +122,8 @@ func (entry *Entry) WithField(key string, value interface{}) *Entry {  // Add a map of fields to the Entry.  func (entry *Entry) WithFields(fields Fields) *Entry { +	entry.Logger.mu.Lock() +	defer entry.Logger.mu.Unlock()  	data := make(Fields, len(entry.Data)+len(fields))  	for k, v := range entry.Data {  		data[k] = v @@ -144,7 +155,11 @@ func (entry *Entry) WithFields(fields Fields) *Entry {  // Overrides the time of the Entry.  func (entry *Entry) WithTime(t time.Time) *Entry { -	return &Entry{Logger: entry.Logger, Data: entry.Data, Time: t, err: entry.err, Context: entry.Context} +	dataCopy := make(Fields, len(entry.Data)) +	for k, v := range entry.Data { +		dataCopy[k] = v +	} +	return &Entry{Logger: entry.Logger, Data: dataCopy, Time: t, err: entry.err, Context: entry.Context}  }  // getPackageName reduces a fully qualified function name to the package name @@ -165,15 +180,20 @@ func getPackageName(f string) string {  // getCaller retrieves the name of the first non-logrus calling function  func getCaller() *runtime.Frame { -  	// cache this package's fully-qualified name  	callerInitOnce.Do(func() { -		pcs := make([]uintptr, 2) +		pcs := make([]uintptr, maximumCallerDepth)  		_ = runtime.Callers(0, pcs) -		logrusPackage = getPackageName(runtime.FuncForPC(pcs[1]).Name()) -		// now that we have the cache, we can skip a minimum count of known-logrus functions -		// XXX this is dubious, the number of frames may vary +		// dynamic get the package name and the minimum caller depth +		for i := 0; i < maximumCallerDepth; i++ { +			funcName := runtime.FuncForPC(pcs[i]).Name() +			if strings.Contains(funcName, "getCaller") { +				logrusPackage = getPackageName(funcName) +				break +			} +		} +  		minimumCallerDepth = knownLogrusFrames  	}) @@ -187,7 +207,7 @@ func getCaller() *runtime.Frame {  		// If the caller isn't part of this package, we're done  		if pkg != logrusPackage { -			return &f +			return &f //nolint:scopelint  		}  	} @@ -217,9 +237,11 @@ func (entry Entry) log(level Level, msg string) {  	entry.Level = level  	entry.Message = msg +	entry.Logger.mu.Lock()  	if entry.Logger.ReportCaller {  		entry.Caller = getCaller()  	} +	entry.Logger.mu.Unlock()  	entry.fireHooks() @@ -255,11 +277,10 @@ func (entry *Entry) write() {  	serialized, err := entry.Logger.Formatter.Format(entry)  	if err != nil {  		fmt.Fprintf(os.Stderr, "Failed to obtain reader, %v\n", err) -	} else { -		_, err = entry.Logger.Out.Write(serialized) -		if err != nil { -			fmt.Fprintf(os.Stderr, "Failed to write to log, %v\n", err) -		} +		return +	} +	if _, err = entry.Logger.Out.Write(serialized); err != nil { +		fmt.Fprintf(os.Stderr, "Failed to write to log, %v\n", err)  	}  } diff --git a/vendor/github.com/sirupsen/logrus/exported.go b/vendor/github.com/sirupsen/logrus/exported.go index 62fc2f219..42b04f6c8 100644 --- a/vendor/github.com/sirupsen/logrus/exported.go +++ b/vendor/github.com/sirupsen/logrus/exported.go @@ -80,7 +80,7 @@ func WithFields(fields Fields) *Entry {  	return std.WithFields(fields)  } -// WithTime creats an entry from the standard logger and overrides the time of +// WithTime creates an entry from the standard logger and overrides the time of  // logs generated with it.  //  // Note that it doesn't log until you call Debug, Print, Info, Warn, Fatal diff --git a/vendor/github.com/sirupsen/logrus/go.mod b/vendor/github.com/sirupsen/logrus/go.mod index 12fdf9898..9ea6e841b 100644 --- a/vendor/github.com/sirupsen/logrus/go.mod +++ b/vendor/github.com/sirupsen/logrus/go.mod @@ -4,7 +4,8 @@ require (  	github.com/davecgh/go-spew v1.1.1 // indirect  	github.com/konsorten/go-windows-terminal-sequences v1.0.1  	github.com/pmezard/go-difflib v1.0.0 // indirect -	github.com/stretchr/objx v0.1.1 // indirect  	github.com/stretchr/testify v1.2.2  	golang.org/x/sys v0.0.0-20190422165155-953cdadca894  ) + +go 1.13 diff --git a/vendor/github.com/sirupsen/logrus/go.sum b/vendor/github.com/sirupsen/logrus/go.sum index 596c318b9..95a3f07de 100644 --- a/vendor/github.com/sirupsen/logrus/go.sum +++ b/vendor/github.com/sirupsen/logrus/go.sum @@ -1,16 +1,10 @@  github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=  github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= -github.com/konsorten/go-windows-terminal-sequences v0.0.0-20180402223658-b729f2633dfe h1:CHRGQ8V7OlCYtwaKPJi3iA7J+YdNKdo8j7nG5IgDhjs= -github.com/konsorten/go-windows-terminal-sequences v0.0.0-20180402223658-b729f2633dfe/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=  github.com/konsorten/go-windows-terminal-sequences v1.0.1 h1:mweAR1A6xJ3oS2pRaGiHgQ4OO8tzTaLawm8vnODuwDk=  github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=  github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=  github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= -github.com/stretchr/objx v0.1.1 h1:2vfRuCMp5sSVIDSqO8oNnWJq7mPa6KVP3iPIwFBuy8A= -github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=  github.com/stretchr/testify v1.2.2 h1:bSDNvY7ZPG5RlJ8otE/7V6gMiyenm9RtJ7IUVIAoJ1w=  github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= -golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33 h1:I6FyU15t786LL7oL/hn43zqTuEGr4PN7F4XJ1p4E3Y8= -golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=  golang.org/x/sys v0.0.0-20190422165155-953cdadca894 h1:Cz4ceDQGXuKRnVBDTS23GTn/pU5OE2C0WrNTOYK1Uuc=  golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= diff --git a/vendor/github.com/sirupsen/logrus/json_formatter.go b/vendor/github.com/sirupsen/logrus/json_formatter.go index 098a21a06..ba7f23711 100644 --- a/vendor/github.com/sirupsen/logrus/json_formatter.go +++ b/vendor/github.com/sirupsen/logrus/json_formatter.go @@ -28,6 +28,9 @@ type JSONFormatter struct {  	// DisableTimestamp allows disabling automatic timestamps in output  	DisableTimestamp bool +	// DisableHTMLEscape allows disabling html escaping in output +	DisableHTMLEscape bool +  	// DataKey allows users to put all the log entry parameters into a nested dictionary at a given key.  	DataKey string @@ -110,6 +113,7 @@ func (f *JSONFormatter) Format(entry *Entry) ([]byte, error) {  	}  	encoder := json.NewEncoder(b) +	encoder.SetEscapeHTML(!f.DisableHTMLEscape)  	if f.PrettyPrint {  		encoder.SetIndent("", "  ")  	} diff --git a/vendor/github.com/sirupsen/logrus/logger.go b/vendor/github.com/sirupsen/logrus/logger.go index c0c0b1e55..6fdda748e 100644 --- a/vendor/github.com/sirupsen/logrus/logger.go +++ b/vendor/github.com/sirupsen/logrus/logger.go @@ -68,10 +68,10 @@ func (mw *MutexWrap) Disable() {  // `Out` and `Hooks` directly on the default logger instance. You can also just  // instantiate your own:  // -//    var log = &Logger{ +//    var log = &logrus.Logger{  //      Out: os.Stderr, -//      Formatter: new(JSONFormatter), -//      Hooks: make(LevelHooks), +//      Formatter: new(logrus.JSONFormatter), +//      Hooks: make(logrus.LevelHooks),  //      Level: logrus.DebugLevel,  //    }  // @@ -100,8 +100,9 @@ func (logger *Logger) releaseEntry(entry *Entry) {  	logger.entryPool.Put(entry)  } -// Adds a field to the log entry, note that it doesn't log until you call -// Debug, Print, Info, Warn, Error, Fatal or Panic. It only creates a log entry. +// WithField allocates a new entry and adds a field to it. +// Debug, Print, Info, Warn, Error, Fatal or Panic must be then applied to +// this new returned entry.  // If you want multiple fields, use `WithFields`.  func (logger *Logger) WithField(key string, value interface{}) *Entry {  	entry := logger.newEntry() diff --git a/vendor/github.com/sirupsen/logrus/logrus.go b/vendor/github.com/sirupsen/logrus/logrus.go index 8644761f7..2f16224cb 100644 --- a/vendor/github.com/sirupsen/logrus/logrus.go +++ b/vendor/github.com/sirupsen/logrus/logrus.go @@ -51,7 +51,7 @@ func (level *Level) UnmarshalText(text []byte) error {  		return err  	} -	*level = Level(l) +	*level = l  	return nil  } diff --git a/vendor/github.com/sirupsen/logrus/terminal_check_bsd.go b/vendor/github.com/sirupsen/logrus/terminal_check_bsd.go index 3c4f43f91..499789984 100644 --- a/vendor/github.com/sirupsen/logrus/terminal_check_bsd.go +++ b/vendor/github.com/sirupsen/logrus/terminal_check_bsd.go @@ -1,4 +1,5 @@  // +build darwin dragonfly freebsd netbsd openbsd +// +build !js  package logrus @@ -10,4 +11,3 @@ func isTerminal(fd int) bool {  	_, err := unix.IoctlGetTermios(fd, ioctlReadTermios)  	return err == nil  } - diff --git a/vendor/github.com/sirupsen/logrus/terminal_check_js.go b/vendor/github.com/sirupsen/logrus/terminal_check_js.go new file mode 100644 index 000000000..ebdae3ec6 --- /dev/null +++ b/vendor/github.com/sirupsen/logrus/terminal_check_js.go @@ -0,0 +1,7 @@ +// +build js + +package logrus + +func isTerminal(fd int) bool { +	return false +} diff --git a/vendor/github.com/sirupsen/logrus/terminal_check_unix.go b/vendor/github.com/sirupsen/logrus/terminal_check_unix.go index 355dc966f..cc4fe6e31 100644 --- a/vendor/github.com/sirupsen/logrus/terminal_check_unix.go +++ b/vendor/github.com/sirupsen/logrus/terminal_check_unix.go @@ -1,4 +1,5 @@  // +build linux aix +// +build !js  package logrus @@ -10,4 +11,3 @@ func isTerminal(fd int) bool {  	_, err := unix.IoctlGetTermios(fd, ioctlReadTermios)  	return err == nil  } - diff --git a/vendor/github.com/sirupsen/logrus/text_formatter.go b/vendor/github.com/sirupsen/logrus/text_formatter.go index e01587c43..2d15a239f 100644 --- a/vendor/github.com/sirupsen/logrus/text_formatter.go +++ b/vendor/github.com/sirupsen/logrus/text_formatter.go @@ -6,9 +6,11 @@ import (  	"os"  	"runtime"  	"sort" +	"strconv"  	"strings"  	"sync"  	"time" +	"unicode/utf8"  )  const ( @@ -32,6 +34,9 @@ type TextFormatter struct {  	// Force disabling colors.  	DisableColors bool +	// Force quoting of all values +	ForceQuote bool +  	// Override coloring based on CLICOLOR and CLICOLOR_FORCE. - https://bixense.com/clicolors/  	EnvironmentOverrideColors bool @@ -57,6 +62,10 @@ type TextFormatter struct {  	// Disables the truncation of the level text to 4 characters.  	DisableLevelTruncation bool +	// PadLevelText Adds padding the level text so that all the levels output at the same length +	// PadLevelText is a superset of the DisableLevelTruncation option +	PadLevelText bool +  	// QuoteEmptyFields will wrap empty fields in quotes if true  	QuoteEmptyFields bool @@ -79,23 +88,32 @@ type TextFormatter struct {  	CallerPrettyfier func(*runtime.Frame) (function string, file string)  	terminalInitOnce sync.Once + +	// The max length of the level text, generated dynamically on init +	levelTextMaxLength int  }  func (f *TextFormatter) init(entry *Entry) {  	if entry.Logger != nil {  		f.isTerminal = checkIfTerminal(entry.Logger.Out)  	} +	// Get the max length of the level text +	for _, level := range AllLevels { +		levelTextLength := utf8.RuneCount([]byte(level.String())) +		if levelTextLength > f.levelTextMaxLength { +			f.levelTextMaxLength = levelTextLength +		} +	}  }  func (f *TextFormatter) isColored() bool {  	isColored := f.ForceColors || (f.isTerminal && (runtime.GOOS != "windows"))  	if f.EnvironmentOverrideColors { -		if force, ok := os.LookupEnv("CLICOLOR_FORCE"); ok && force != "0" { +		switch force, ok := os.LookupEnv("CLICOLOR_FORCE"); { +		case ok && force != "0":  			isColored = true -		} else if ok && force == "0" { -			isColored = false -		} else if os.Getenv("CLICOLOR") == "0" { +		case ok && force == "0", os.Getenv("CLICOLOR") == "0":  			isColored = false  		}  	} @@ -217,9 +235,18 @@ func (f *TextFormatter) printColored(b *bytes.Buffer, entry *Entry, keys []strin  	}  	levelText := strings.ToUpper(entry.Level.String()) -	if !f.DisableLevelTruncation { +	if !f.DisableLevelTruncation && !f.PadLevelText {  		levelText = levelText[0:4]  	} +	if f.PadLevelText { +		// Generates the format string used in the next line, for example "%-6s" or "%-7s". +		// Based on the max level text length. +		formatString := "%-" + strconv.Itoa(f.levelTextMaxLength) + "s" +		// Formats the level text by appending spaces up to the max length, for example: +		// 	- "INFO   " +		//	- "WARNING" +		levelText = fmt.Sprintf(formatString, levelText) +	}  	// Remove a single newline if it already exists in the message to keep  	// the behavior of logrus text_formatter the same as the stdlib log package @@ -243,11 +270,12 @@ func (f *TextFormatter) printColored(b *bytes.Buffer, entry *Entry, keys []strin  		}  	} -	if f.DisableTimestamp { +	switch { +	case f.DisableTimestamp:  		fmt.Fprintf(b, "\x1b[%dm%s\x1b[0m%s %-44s ", levelColor, levelText, caller, entry.Message) -	} else if !f.FullTimestamp { +	case !f.FullTimestamp:  		fmt.Fprintf(b, "\x1b[%dm%s\x1b[0m[%04d]%s %-44s ", levelColor, levelText, int(entry.Time.Sub(baseTimestamp)/time.Second), caller, entry.Message) -	} else { +	default:  		fmt.Fprintf(b, "\x1b[%dm%s\x1b[0m[%s]%s %-44s ", levelColor, levelText, entry.Time.Format(timestampFormat), caller, entry.Message)  	}  	for _, k := range keys { @@ -258,6 +286,9 @@ func (f *TextFormatter) printColored(b *bytes.Buffer, entry *Entry, keys []strin  }  func (f *TextFormatter) needsQuoting(text string) bool { +	if f.ForceQuote { +		return true +	}  	if f.QuoteEmptyFields && len(text) == 0 {  		return true  	} diff --git a/vendor/github.com/sirupsen/logrus/writer.go b/vendor/github.com/sirupsen/logrus/writer.go index 9e1f75135..72e8e3a1b 100644 --- a/vendor/github.com/sirupsen/logrus/writer.go +++ b/vendor/github.com/sirupsen/logrus/writer.go @@ -6,10 +6,16 @@ import (  	"runtime"  ) +// Writer at INFO level. See WriterLevel for details.  func (logger *Logger) Writer() *io.PipeWriter {  	return logger.WriterLevel(InfoLevel)  } +// WriterLevel returns an io.Writer that can be used to write arbitrary text to +// the logger at the given log level. Each line written to the writer will be +// printed in the usual way using formatters and hooks. The writer is part of an +// io.Pipe and it is the callers responsibility to close the writer when done. +// This can be used to override the standard library logger easily.  func (logger *Logger) WriterLevel(level Level) *io.PipeWriter {  	return NewEntry(logger).WriterLevel(level)  } diff --git a/vendor/modules.txt b/vendor/modules.txt index b143eea5a..4502c6ebc 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -469,7 +469,7 @@ github.com/safchain/ethtool  github.com/seccomp/containers-golang  # github.com/seccomp/libseccomp-golang v0.9.1  github.com/seccomp/libseccomp-golang -# github.com/sirupsen/logrus v1.4.2 +# github.com/sirupsen/logrus v1.5.0  github.com/sirupsen/logrus  github.com/sirupsen/logrus/hooks/syslog  # github.com/spf13/cobra v0.0.6 | 
