mirror of
https://github.com/ceph/ceph-csi.git
synced 2025-01-18 02:39:30 +00:00
Merge pull request #244 from red-hat-storage/sync_us--devel
Syncing latest changes from upstream devel for ceph-csi
This commit is contained in:
commit
705b18014e
4
go.mod
4
go.mod
@ -39,7 +39,7 @@ require (
|
|||||||
k8s.io/apimachinery v0.29.0
|
k8s.io/apimachinery v0.29.0
|
||||||
k8s.io/client-go v12.0.0+incompatible
|
k8s.io/client-go v12.0.0+incompatible
|
||||||
k8s.io/cloud-provider v0.29.0
|
k8s.io/cloud-provider v0.29.0
|
||||||
k8s.io/klog/v2 v2.110.1
|
k8s.io/klog/v2 v2.120.0
|
||||||
k8s.io/kubernetes v1.29.0
|
k8s.io/kubernetes v1.29.0
|
||||||
k8s.io/mount-utils v0.29.0
|
k8s.io/mount-utils v0.29.0
|
||||||
k8s.io/pod-security-admission v0.0.0
|
k8s.io/pod-security-admission v0.0.0
|
||||||
@ -76,7 +76,7 @@ require (
|
|||||||
github.com/gemalto/flume v0.13.0 // indirect
|
github.com/gemalto/flume v0.13.0 // indirect
|
||||||
github.com/ghodss/yaml v1.0.1-0.20190212211648-25d852aebe32 // indirect
|
github.com/ghodss/yaml v1.0.1-0.20190212211648-25d852aebe32 // indirect
|
||||||
github.com/go-jose/go-jose/v3 v3.0.1 // indirect
|
github.com/go-jose/go-jose/v3 v3.0.1 // indirect
|
||||||
github.com/go-logr/logr v1.3.0 // indirect
|
github.com/go-logr/logr v1.4.1 // indirect
|
||||||
github.com/go-logr/stdr v1.2.2 // indirect
|
github.com/go-logr/stdr v1.2.2 // indirect
|
||||||
github.com/go-openapi/jsonpointer v0.19.6 // indirect
|
github.com/go-openapi/jsonpointer v0.19.6 // indirect
|
||||||
github.com/go-openapi/jsonreference v0.20.2 // indirect
|
github.com/go-openapi/jsonreference v0.20.2 // indirect
|
||||||
|
6
go.sum
6
go.sum
@ -1006,8 +1006,9 @@ github.com/go-logr/logr v1.2.0/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbV
|
|||||||
github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
||||||
github.com/go-logr/logr v1.2.3/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
github.com/go-logr/logr v1.2.3/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
||||||
github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
||||||
github.com/go-logr/logr v1.3.0 h1:2y3SDp0ZXuc6/cjLSZ+Q3ir+QB9T/iG5yYRXqsagWSY=
|
|
||||||
github.com/go-logr/logr v1.3.0/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
|
github.com/go-logr/logr v1.3.0/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
|
||||||
|
github.com/go-logr/logr v1.4.1 h1:pKouT5E8xu9zeFC39JXRDukb6JFQPXM5p5I91188VAQ=
|
||||||
|
github.com/go-logr/logr v1.4.1/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
|
||||||
github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag=
|
github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag=
|
||||||
github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE=
|
github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE=
|
||||||
github.com/go-logr/zapr v0.1.0/go.mod h1:tabnROwaDl0UNxkVeFRbY8bwB37GwRv0P8lg6aAiEnk=
|
github.com/go-logr/zapr v0.1.0/go.mod h1:tabnROwaDl0UNxkVeFRbY8bwB37GwRv0P8lg6aAiEnk=
|
||||||
@ -2584,8 +2585,9 @@ k8s.io/klog/v2 v2.0.0/go.mod h1:PBfzABfn139FHAV07az/IF9Wp1bkk3vpT2XSJ76fSDE=
|
|||||||
k8s.io/klog/v2 v2.2.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y=
|
k8s.io/klog/v2 v2.2.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y=
|
||||||
k8s.io/klog/v2 v2.4.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y=
|
k8s.io/klog/v2 v2.4.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y=
|
||||||
k8s.io/klog/v2 v2.80.1/go.mod h1:y1WjHnz7Dj687irZUWR/WLkLc5N1YHtjLdmgWjndZn0=
|
k8s.io/klog/v2 v2.80.1/go.mod h1:y1WjHnz7Dj687irZUWR/WLkLc5N1YHtjLdmgWjndZn0=
|
||||||
k8s.io/klog/v2 v2.110.1 h1:U/Af64HJf7FcwMcXyKm2RPM22WZzyR7OSpYj5tg3cL0=
|
|
||||||
k8s.io/klog/v2 v2.110.1/go.mod h1:YGtd1984u+GgbuZ7e08/yBuAfKLSO0+uR1Fhi6ExXjo=
|
k8s.io/klog/v2 v2.110.1/go.mod h1:YGtd1984u+GgbuZ7e08/yBuAfKLSO0+uR1Fhi6ExXjo=
|
||||||
|
k8s.io/klog/v2 v2.120.0 h1:z+q5mfovBj1fKFxiRzsa2DsJLPIVMk/KFL81LMOfK+8=
|
||||||
|
k8s.io/klog/v2 v2.120.0/go.mod h1:3Jpz1GvMt720eyJH1ckRHK1EDfpxISzJ7I9OYgaDtPE=
|
||||||
k8s.io/kms v0.29.0 h1:KJ1zaZt74CgvgV3NR7tnURJ/mJOKC5X3nwon/WdwgxI=
|
k8s.io/kms v0.29.0 h1:KJ1zaZt74CgvgV3NR7tnURJ/mJOKC5X3nwon/WdwgxI=
|
||||||
k8s.io/kms v0.29.0/go.mod h1:mB0f9HLxRXeXUfHfn1A7rpwOlzXI1gIWu86z6buNoYA=
|
k8s.io/kms v0.29.0/go.mod h1:mB0f9HLxRXeXUfHfn1A7rpwOlzXI1gIWu86z6buNoYA=
|
||||||
k8s.io/kube-openapi v0.0.0-20180731170545-e3762e86a74c/go.mod h1:BXM9ceUBTj2QnfH2MK1odQs778ajze1RxcmP6S8RVVc=
|
k8s.io/kube-openapi v0.0.0-20180731170545-e3762e86a74c/go.mod h1:BXM9ceUBTj2QnfH2MK1odQs778ajze1RxcmP6S8RVVc=
|
||||||
|
67
vendor/github.com/go-logr/logr/README.md
generated
vendored
67
vendor/github.com/go-logr/logr/README.md
generated
vendored
@ -91,11 +91,12 @@ logr design but also left out some parts and changed others:
|
|||||||
| Adding a name to a logger | `WithName` | no API |
|
| Adding a name to a logger | `WithName` | no API |
|
||||||
| Modify verbosity of log entries in a call chain | `V` | no API |
|
| Modify verbosity of log entries in a call chain | `V` | no API |
|
||||||
| Grouping of key/value pairs | not supported | `WithGroup`, `GroupValue` |
|
| Grouping of key/value pairs | not supported | `WithGroup`, `GroupValue` |
|
||||||
|
| Pass context for extracting additional values | no API | API variants like `InfoCtx` |
|
||||||
|
|
||||||
The high-level slog API is explicitly meant to be one of many different APIs
|
The high-level slog API is explicitly meant to be one of many different APIs
|
||||||
that can be layered on top of a shared `slog.Handler`. logr is one such
|
that can be layered on top of a shared `slog.Handler`. logr is one such
|
||||||
alternative API, with [interoperability](#slog-interoperability) provided by the [`slogr`](slogr)
|
alternative API, with [interoperability](#slog-interoperability) provided by
|
||||||
package.
|
some conversion functions.
|
||||||
|
|
||||||
### Inspiration
|
### Inspiration
|
||||||
|
|
||||||
@ -145,24 +146,24 @@ There are implementations for the following logging libraries:
|
|||||||
## slog interoperability
|
## slog interoperability
|
||||||
|
|
||||||
Interoperability goes both ways, using the `logr.Logger` API with a `slog.Handler`
|
Interoperability goes both ways, using the `logr.Logger` API with a `slog.Handler`
|
||||||
and using the `slog.Logger` API with a `logr.LogSink`. [slogr](./slogr) provides `NewLogr` and
|
and using the `slog.Logger` API with a `logr.LogSink`. `FromSlogHandler` and
|
||||||
`NewSlogHandler` API calls to convert between a `logr.Logger` and a `slog.Handler`.
|
`ToSlogHandler` convert between a `logr.Logger` and a `slog.Handler`.
|
||||||
As usual, `slog.New` can be used to wrap such a `slog.Handler` in the high-level
|
As usual, `slog.New` can be used to wrap such a `slog.Handler` in the high-level
|
||||||
slog API. `slogr` itself leaves that to the caller.
|
slog API.
|
||||||
|
|
||||||
## Using a `logr.Sink` as backend for slog
|
### Using a `logr.LogSink` as backend for slog
|
||||||
|
|
||||||
Ideally, a logr sink implementation should support both logr and slog by
|
Ideally, a logr sink implementation should support both logr and slog by
|
||||||
implementing both the normal logr interface(s) and `slogr.SlogSink`. Because
|
implementing both the normal logr interface(s) and `SlogSink`. Because
|
||||||
of a conflict in the parameters of the common `Enabled` method, it is [not
|
of a conflict in the parameters of the common `Enabled` method, it is [not
|
||||||
possible to implement both slog.Handler and logr.Sink in the same
|
possible to implement both slog.Handler and logr.Sink in the same
|
||||||
type](https://github.com/golang/go/issues/59110).
|
type](https://github.com/golang/go/issues/59110).
|
||||||
|
|
||||||
If both are supported, log calls can go from the high-level APIs to the backend
|
If both are supported, log calls can go from the high-level APIs to the backend
|
||||||
without the need to convert parameters. `NewLogr` and `NewSlogHandler` can
|
without the need to convert parameters. `FromSlogHandler` and `ToSlogHandler` can
|
||||||
convert back and forth without adding additional wrappers, with one exception:
|
convert back and forth without adding additional wrappers, with one exception:
|
||||||
when `Logger.V` was used to adjust the verbosity for a `slog.Handler`, then
|
when `Logger.V` was used to adjust the verbosity for a `slog.Handler`, then
|
||||||
`NewSlogHandler` has to use a wrapper which adjusts the verbosity for future
|
`ToSlogHandler` has to use a wrapper which adjusts the verbosity for future
|
||||||
log calls.
|
log calls.
|
||||||
|
|
||||||
Such an implementation should also support values that implement specific
|
Such an implementation should also support values that implement specific
|
||||||
@ -187,13 +188,13 @@ Not supporting slog has several drawbacks:
|
|||||||
These drawbacks are severe enough that applications using a mixture of slog and
|
These drawbacks are severe enough that applications using a mixture of slog and
|
||||||
logr should switch to a different backend.
|
logr should switch to a different backend.
|
||||||
|
|
||||||
## Using a `slog.Handler` as backend for logr
|
### Using a `slog.Handler` as backend for logr
|
||||||
|
|
||||||
Using a plain `slog.Handler` without support for logr works better than the
|
Using a plain `slog.Handler` without support for logr works better than the
|
||||||
other direction:
|
other direction:
|
||||||
- All logr verbosity levels can be mapped 1:1 to their corresponding slog level
|
- All logr verbosity levels can be mapped 1:1 to their corresponding slog level
|
||||||
by negating them.
|
by negating them.
|
||||||
- Stack unwinding is done by the `slogr.SlogSink` and the resulting program
|
- Stack unwinding is done by the `SlogSink` and the resulting program
|
||||||
counter is passed to the `slog.Handler`.
|
counter is passed to the `slog.Handler`.
|
||||||
- Names added via `Logger.WithName` are gathered and recorded in an additional
|
- Names added via `Logger.WithName` are gathered and recorded in an additional
|
||||||
attribute with `logger` as key and the names separated by slash as value.
|
attribute with `logger` as key and the names separated by slash as value.
|
||||||
@ -205,27 +206,39 @@ ideally support both `logr.Marshaler` and `slog.Valuer`. If compatibility
|
|||||||
with logr implementations without slog support is not important, then
|
with logr implementations without slog support is not important, then
|
||||||
`slog.Valuer` is sufficient.
|
`slog.Valuer` is sufficient.
|
||||||
|
|
||||||
## Context support for slog
|
### Context support for slog
|
||||||
|
|
||||||
Storing a logger in a `context.Context` is not supported by
|
Storing a logger in a `context.Context` is not supported by
|
||||||
slog. `logr.NewContext` and `logr.FromContext` can be used with slog like this
|
slog. `NewContextWithSlogLogger` and `FromContextAsSlogLogger` can be
|
||||||
to fill this gap:
|
used to fill this gap. They store and retrieve a `slog.Logger` pointer
|
||||||
|
under the same context key that is also used by `NewContext` and
|
||||||
|
`FromContext` for `logr.Logger` value.
|
||||||
|
|
||||||
func HandlerFromContext(ctx context.Context) slog.Handler {
|
When `NewContextWithSlogLogger` is followed by `FromContext`, the latter will
|
||||||
logger, err := logr.FromContext(ctx)
|
automatically convert the `slog.Logger` to a
|
||||||
if err == nil {
|
`logr.Logger`. `FromContextAsSlogLogger` does the same for the other direction.
|
||||||
return slogr.NewSlogHandler(logger)
|
|
||||||
}
|
|
||||||
return slog.Default().Handler()
|
|
||||||
}
|
|
||||||
|
|
||||||
func ContextWithHandler(ctx context.Context, handler slog.Handler) context.Context {
|
With this approach, binaries which use either slog or logr are as efficient as
|
||||||
return logr.NewContext(ctx, slogr.NewLogr(handler))
|
possible with no unnecessary allocations. This is also why the API stores a
|
||||||
}
|
`slog.Logger` pointer: when storing a `slog.Handler`, creating a `slog.Logger`
|
||||||
|
on retrieval would need to allocate one.
|
||||||
|
|
||||||
The downside is that storing and retrieving a `slog.Handler` needs more
|
The downside is that switching back and forth needs more allocations. Because
|
||||||
allocations compared to using a `logr.Logger`. Therefore the recommendation is
|
logr is the API that is already in use by different packages, in particular
|
||||||
to use the `logr.Logger` API in code which uses contextual logging.
|
Kubernetes, the recommendation is to use the `logr.Logger` API in code which
|
||||||
|
uses contextual logging.
|
||||||
|
|
||||||
|
An alternative to adding values to a logger and storing that logger in the
|
||||||
|
context is to store the values in the context and to configure a logging
|
||||||
|
backend to extract those values when emitting log entries. This only works when
|
||||||
|
log calls are passed the context, which is not supported by the logr API.
|
||||||
|
|
||||||
|
With the slog API, it is possible, but not
|
||||||
|
required. https://github.com/veqryn/slog-context is a package for slog which
|
||||||
|
provides additional support code for this approach. It also contains wrappers
|
||||||
|
for the context functions in logr, so developers who prefer to not use the logr
|
||||||
|
APIs directly can use those instead and the resulting code will still be
|
||||||
|
interoperable with logr.
|
||||||
|
|
||||||
## FAQ
|
## FAQ
|
||||||
|
|
||||||
|
33
vendor/github.com/go-logr/logr/context.go
generated
vendored
Normal file
33
vendor/github.com/go-logr/logr/context.go
generated
vendored
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2023 The logr Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package logr
|
||||||
|
|
||||||
|
// contextKey is how we find Loggers in a context.Context. With Go < 1.21,
|
||||||
|
// the value is always a Logger value. With Go >= 1.21, the value can be a
|
||||||
|
// Logger value or a slog.Logger pointer.
|
||||||
|
type contextKey struct{}
|
||||||
|
|
||||||
|
// notFoundError exists to carry an IsNotFound method.
|
||||||
|
type notFoundError struct{}
|
||||||
|
|
||||||
|
func (notFoundError) Error() string {
|
||||||
|
return "no logr.Logger was present"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (notFoundError) IsNotFound() bool {
|
||||||
|
return true
|
||||||
|
}
|
49
vendor/github.com/go-logr/logr/context_noslog.go
generated
vendored
Normal file
49
vendor/github.com/go-logr/logr/context_noslog.go
generated
vendored
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
//go:build !go1.21
|
||||||
|
// +build !go1.21
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright 2019 The logr Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package logr
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
)
|
||||||
|
|
||||||
|
// FromContext returns a Logger from ctx or an error if no Logger is found.
|
||||||
|
func FromContext(ctx context.Context) (Logger, error) {
|
||||||
|
if v, ok := ctx.Value(contextKey{}).(Logger); ok {
|
||||||
|
return v, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return Logger{}, notFoundError{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// FromContextOrDiscard returns a Logger from ctx. If no Logger is found, this
|
||||||
|
// returns a Logger that discards all log messages.
|
||||||
|
func FromContextOrDiscard(ctx context.Context) Logger {
|
||||||
|
if v, ok := ctx.Value(contextKey{}).(Logger); ok {
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
|
||||||
|
return Discard()
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewContext returns a new Context, derived from ctx, which carries the
|
||||||
|
// provided Logger.
|
||||||
|
func NewContext(ctx context.Context, logger Logger) context.Context {
|
||||||
|
return context.WithValue(ctx, contextKey{}, logger)
|
||||||
|
}
|
83
vendor/github.com/go-logr/logr/context_slog.go
generated
vendored
Normal file
83
vendor/github.com/go-logr/logr/context_slog.go
generated
vendored
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
//go:build go1.21
|
||||||
|
// +build go1.21
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright 2019 The logr Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package logr
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"log/slog"
|
||||||
|
)
|
||||||
|
|
||||||
|
// FromContext returns a Logger from ctx or an error if no Logger is found.
|
||||||
|
func FromContext(ctx context.Context) (Logger, error) {
|
||||||
|
v := ctx.Value(contextKey{})
|
||||||
|
if v == nil {
|
||||||
|
return Logger{}, notFoundError{}
|
||||||
|
}
|
||||||
|
|
||||||
|
switch v := v.(type) {
|
||||||
|
case Logger:
|
||||||
|
return v, nil
|
||||||
|
case *slog.Logger:
|
||||||
|
return FromSlogHandler(v.Handler()), nil
|
||||||
|
default:
|
||||||
|
// Not reached.
|
||||||
|
panic(fmt.Sprintf("unexpected value type for logr context key: %T", v))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// FromContextAsSlogLogger returns a slog.Logger from ctx or nil if no such Logger is found.
|
||||||
|
func FromContextAsSlogLogger(ctx context.Context) *slog.Logger {
|
||||||
|
v := ctx.Value(contextKey{})
|
||||||
|
if v == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
switch v := v.(type) {
|
||||||
|
case Logger:
|
||||||
|
return slog.New(ToSlogHandler(v))
|
||||||
|
case *slog.Logger:
|
||||||
|
return v
|
||||||
|
default:
|
||||||
|
// Not reached.
|
||||||
|
panic(fmt.Sprintf("unexpected value type for logr context key: %T", v))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// FromContextOrDiscard returns a Logger from ctx. If no Logger is found, this
|
||||||
|
// returns a Logger that discards all log messages.
|
||||||
|
func FromContextOrDiscard(ctx context.Context) Logger {
|
||||||
|
if logger, err := FromContext(ctx); err == nil {
|
||||||
|
return logger
|
||||||
|
}
|
||||||
|
return Discard()
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewContext returns a new Context, derived from ctx, which carries the
|
||||||
|
// provided Logger.
|
||||||
|
func NewContext(ctx context.Context, logger Logger) context.Context {
|
||||||
|
return context.WithValue(ctx, contextKey{}, logger)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewContextWithSlogLogger returns a new Context, derived from ctx, which carries the
|
||||||
|
// provided slog.Logger.
|
||||||
|
func NewContextWithSlogLogger(ctx context.Context, logger *slog.Logger) context.Context {
|
||||||
|
return context.WithValue(ctx, contextKey{}, logger)
|
||||||
|
}
|
189
vendor/github.com/go-logr/logr/funcr/funcr.go
generated
vendored
189
vendor/github.com/go-logr/logr/funcr/funcr.go
generated
vendored
@ -100,6 +100,11 @@ type Options struct {
|
|||||||
// details, see docs for Go's time.Layout.
|
// details, see docs for Go's time.Layout.
|
||||||
TimestampFormat string
|
TimestampFormat string
|
||||||
|
|
||||||
|
// LogInfoLevel tells funcr what key to use to log the info level.
|
||||||
|
// If not specified, the info level will be logged as "level".
|
||||||
|
// If this is set to "", the info level will not be logged at all.
|
||||||
|
LogInfoLevel *string
|
||||||
|
|
||||||
// Verbosity tells funcr which V logs to produce. Higher values enable
|
// Verbosity tells funcr which V logs to produce. Higher values enable
|
||||||
// more logs. Info logs at or below this level will be written, while logs
|
// more logs. Info logs at or below this level will be written, while logs
|
||||||
// above this level will be discarded.
|
// above this level will be discarded.
|
||||||
@ -213,6 +218,10 @@ func newFormatter(opts Options, outfmt outputFormat) Formatter {
|
|||||||
if opts.MaxLogDepth == 0 {
|
if opts.MaxLogDepth == 0 {
|
||||||
opts.MaxLogDepth = defaultMaxLogDepth
|
opts.MaxLogDepth = defaultMaxLogDepth
|
||||||
}
|
}
|
||||||
|
if opts.LogInfoLevel == nil {
|
||||||
|
opts.LogInfoLevel = new(string)
|
||||||
|
*opts.LogInfoLevel = "level"
|
||||||
|
}
|
||||||
f := Formatter{
|
f := Formatter{
|
||||||
outputFormat: outfmt,
|
outputFormat: outfmt,
|
||||||
prefix: "",
|
prefix: "",
|
||||||
@ -227,12 +236,15 @@ func newFormatter(opts Options, outfmt outputFormat) Formatter {
|
|||||||
// implementation. It should be constructed with NewFormatter. Some of
|
// implementation. It should be constructed with NewFormatter. Some of
|
||||||
// its methods directly implement logr.LogSink.
|
// its methods directly implement logr.LogSink.
|
||||||
type Formatter struct {
|
type Formatter struct {
|
||||||
outputFormat outputFormat
|
outputFormat outputFormat
|
||||||
prefix string
|
prefix string
|
||||||
values []any
|
values []any
|
||||||
valuesStr string
|
valuesStr string
|
||||||
depth int
|
parentValuesStr string
|
||||||
opts *Options
|
depth int
|
||||||
|
opts *Options
|
||||||
|
group string // for slog groups
|
||||||
|
groupDepth int
|
||||||
}
|
}
|
||||||
|
|
||||||
// outputFormat indicates which outputFormat to use.
|
// outputFormat indicates which outputFormat to use.
|
||||||
@ -253,33 +265,62 @@ func (f Formatter) render(builtins, args []any) string {
|
|||||||
// Empirically bytes.Buffer is faster than strings.Builder for this.
|
// Empirically bytes.Buffer is faster than strings.Builder for this.
|
||||||
buf := bytes.NewBuffer(make([]byte, 0, 1024))
|
buf := bytes.NewBuffer(make([]byte, 0, 1024))
|
||||||
if f.outputFormat == outputJSON {
|
if f.outputFormat == outputJSON {
|
||||||
buf.WriteByte('{')
|
buf.WriteByte('{') // for the whole line
|
||||||
}
|
}
|
||||||
|
|
||||||
vals := builtins
|
vals := builtins
|
||||||
if hook := f.opts.RenderBuiltinsHook; hook != nil {
|
if hook := f.opts.RenderBuiltinsHook; hook != nil {
|
||||||
vals = hook(f.sanitize(vals))
|
vals = hook(f.sanitize(vals))
|
||||||
}
|
}
|
||||||
f.flatten(buf, vals, false, false) // keys are ours, no need to escape
|
f.flatten(buf, vals, false, false) // keys are ours, no need to escape
|
||||||
continuing := len(builtins) > 0
|
continuing := len(builtins) > 0
|
||||||
if len(f.valuesStr) > 0 {
|
|
||||||
|
if f.parentValuesStr != "" {
|
||||||
if continuing {
|
if continuing {
|
||||||
if f.outputFormat == outputJSON {
|
buf.WriteByte(f.comma())
|
||||||
buf.WriteByte(',')
|
|
||||||
} else {
|
|
||||||
buf.WriteByte(' ')
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
buf.WriteString(f.parentValuesStr)
|
||||||
continuing = true
|
continuing = true
|
||||||
buf.WriteString(f.valuesStr)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
groupDepth := f.groupDepth
|
||||||
|
if f.group != "" {
|
||||||
|
if f.valuesStr != "" || len(args) != 0 {
|
||||||
|
if continuing {
|
||||||
|
buf.WriteByte(f.comma())
|
||||||
|
}
|
||||||
|
buf.WriteString(f.quoted(f.group, true)) // escape user-provided keys
|
||||||
|
buf.WriteByte(f.colon())
|
||||||
|
buf.WriteByte('{') // for the group
|
||||||
|
continuing = false
|
||||||
|
} else {
|
||||||
|
// The group was empty
|
||||||
|
groupDepth--
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.valuesStr != "" {
|
||||||
|
if continuing {
|
||||||
|
buf.WriteByte(f.comma())
|
||||||
|
}
|
||||||
|
buf.WriteString(f.valuesStr)
|
||||||
|
continuing = true
|
||||||
|
}
|
||||||
|
|
||||||
vals = args
|
vals = args
|
||||||
if hook := f.opts.RenderArgsHook; hook != nil {
|
if hook := f.opts.RenderArgsHook; hook != nil {
|
||||||
vals = hook(f.sanitize(vals))
|
vals = hook(f.sanitize(vals))
|
||||||
}
|
}
|
||||||
f.flatten(buf, vals, continuing, true) // escape user-provided keys
|
f.flatten(buf, vals, continuing, true) // escape user-provided keys
|
||||||
if f.outputFormat == outputJSON {
|
|
||||||
buf.WriteByte('}')
|
for i := 0; i < groupDepth; i++ {
|
||||||
|
buf.WriteByte('}') // for the groups
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if f.outputFormat == outputJSON {
|
||||||
|
buf.WriteByte('}') // for the whole line
|
||||||
|
}
|
||||||
|
|
||||||
return buf.String()
|
return buf.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -298,9 +339,16 @@ func (f Formatter) flatten(buf *bytes.Buffer, kvList []any, continuing bool, esc
|
|||||||
if len(kvList)%2 != 0 {
|
if len(kvList)%2 != 0 {
|
||||||
kvList = append(kvList, noValue)
|
kvList = append(kvList, noValue)
|
||||||
}
|
}
|
||||||
|
copied := false
|
||||||
for i := 0; i < len(kvList); i += 2 {
|
for i := 0; i < len(kvList); i += 2 {
|
||||||
k, ok := kvList[i].(string)
|
k, ok := kvList[i].(string)
|
||||||
if !ok {
|
if !ok {
|
||||||
|
if !copied {
|
||||||
|
newList := make([]any, len(kvList))
|
||||||
|
copy(newList, kvList)
|
||||||
|
kvList = newList
|
||||||
|
copied = true
|
||||||
|
}
|
||||||
k = f.nonStringKey(kvList[i])
|
k = f.nonStringKey(kvList[i])
|
||||||
kvList[i] = k
|
kvList[i] = k
|
||||||
}
|
}
|
||||||
@ -308,7 +356,7 @@ func (f Formatter) flatten(buf *bytes.Buffer, kvList []any, continuing bool, esc
|
|||||||
|
|
||||||
if i > 0 || continuing {
|
if i > 0 || continuing {
|
||||||
if f.outputFormat == outputJSON {
|
if f.outputFormat == outputJSON {
|
||||||
buf.WriteByte(',')
|
buf.WriteByte(f.comma())
|
||||||
} else {
|
} else {
|
||||||
// In theory the format could be something we don't understand. In
|
// In theory the format could be something we don't understand. In
|
||||||
// practice, we control it, so it won't be.
|
// practice, we control it, so it won't be.
|
||||||
@ -316,24 +364,35 @@ func (f Formatter) flatten(buf *bytes.Buffer, kvList []any, continuing bool, esc
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if escapeKeys {
|
buf.WriteString(f.quoted(k, escapeKeys))
|
||||||
buf.WriteString(prettyString(k))
|
buf.WriteByte(f.colon())
|
||||||
} else {
|
|
||||||
// this is faster
|
|
||||||
buf.WriteByte('"')
|
|
||||||
buf.WriteString(k)
|
|
||||||
buf.WriteByte('"')
|
|
||||||
}
|
|
||||||
if f.outputFormat == outputJSON {
|
|
||||||
buf.WriteByte(':')
|
|
||||||
} else {
|
|
||||||
buf.WriteByte('=')
|
|
||||||
}
|
|
||||||
buf.WriteString(f.pretty(v))
|
buf.WriteString(f.pretty(v))
|
||||||
}
|
}
|
||||||
return kvList
|
return kvList
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (f Formatter) quoted(str string, escape bool) string {
|
||||||
|
if escape {
|
||||||
|
return prettyString(str)
|
||||||
|
}
|
||||||
|
// this is faster
|
||||||
|
return `"` + str + `"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f Formatter) comma() byte {
|
||||||
|
if f.outputFormat == outputJSON {
|
||||||
|
return ','
|
||||||
|
}
|
||||||
|
return ' '
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f Formatter) colon() byte {
|
||||||
|
if f.outputFormat == outputJSON {
|
||||||
|
return ':'
|
||||||
|
}
|
||||||
|
return '='
|
||||||
|
}
|
||||||
|
|
||||||
func (f Formatter) pretty(value any) string {
|
func (f Formatter) pretty(value any) string {
|
||||||
return f.prettyWithFlags(value, 0, 0)
|
return f.prettyWithFlags(value, 0, 0)
|
||||||
}
|
}
|
||||||
@ -407,12 +466,12 @@ func (f Formatter) prettyWithFlags(value any, flags uint32, depth int) string {
|
|||||||
}
|
}
|
||||||
for i := 0; i < len(v); i += 2 {
|
for i := 0; i < len(v); i += 2 {
|
||||||
if i > 0 {
|
if i > 0 {
|
||||||
buf.WriteByte(',')
|
buf.WriteByte(f.comma())
|
||||||
}
|
}
|
||||||
k, _ := v[i].(string) // sanitize() above means no need to check success
|
k, _ := v[i].(string) // sanitize() above means no need to check success
|
||||||
// arbitrary keys might need escaping
|
// arbitrary keys might need escaping
|
||||||
buf.WriteString(prettyString(k))
|
buf.WriteString(prettyString(k))
|
||||||
buf.WriteByte(':')
|
buf.WriteByte(f.colon())
|
||||||
buf.WriteString(f.prettyWithFlags(v[i+1], 0, depth+1))
|
buf.WriteString(f.prettyWithFlags(v[i+1], 0, depth+1))
|
||||||
}
|
}
|
||||||
if flags&flagRawStruct == 0 {
|
if flags&flagRawStruct == 0 {
|
||||||
@ -481,7 +540,7 @@ func (f Formatter) prettyWithFlags(value any, flags uint32, depth int) string {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if printComma {
|
if printComma {
|
||||||
buf.WriteByte(',')
|
buf.WriteByte(f.comma())
|
||||||
}
|
}
|
||||||
printComma = true // if we got here, we are rendering a field
|
printComma = true // if we got here, we are rendering a field
|
||||||
if fld.Anonymous && fld.Type.Kind() == reflect.Struct && name == "" {
|
if fld.Anonymous && fld.Type.Kind() == reflect.Struct && name == "" {
|
||||||
@ -492,10 +551,8 @@ func (f Formatter) prettyWithFlags(value any, flags uint32, depth int) string {
|
|||||||
name = fld.Name
|
name = fld.Name
|
||||||
}
|
}
|
||||||
// field names can't contain characters which need escaping
|
// field names can't contain characters which need escaping
|
||||||
buf.WriteByte('"')
|
buf.WriteString(f.quoted(name, false))
|
||||||
buf.WriteString(name)
|
buf.WriteByte(f.colon())
|
||||||
buf.WriteByte('"')
|
|
||||||
buf.WriteByte(':')
|
|
||||||
buf.WriteString(f.prettyWithFlags(v.Field(i).Interface(), 0, depth+1))
|
buf.WriteString(f.prettyWithFlags(v.Field(i).Interface(), 0, depth+1))
|
||||||
}
|
}
|
||||||
if flags&flagRawStruct == 0 {
|
if flags&flagRawStruct == 0 {
|
||||||
@ -520,7 +577,7 @@ func (f Formatter) prettyWithFlags(value any, flags uint32, depth int) string {
|
|||||||
buf.WriteByte('[')
|
buf.WriteByte('[')
|
||||||
for i := 0; i < v.Len(); i++ {
|
for i := 0; i < v.Len(); i++ {
|
||||||
if i > 0 {
|
if i > 0 {
|
||||||
buf.WriteByte(',')
|
buf.WriteByte(f.comma())
|
||||||
}
|
}
|
||||||
e := v.Index(i)
|
e := v.Index(i)
|
||||||
buf.WriteString(f.prettyWithFlags(e.Interface(), 0, depth+1))
|
buf.WriteString(f.prettyWithFlags(e.Interface(), 0, depth+1))
|
||||||
@ -534,7 +591,7 @@ func (f Formatter) prettyWithFlags(value any, flags uint32, depth int) string {
|
|||||||
i := 0
|
i := 0
|
||||||
for it.Next() {
|
for it.Next() {
|
||||||
if i > 0 {
|
if i > 0 {
|
||||||
buf.WriteByte(',')
|
buf.WriteByte(f.comma())
|
||||||
}
|
}
|
||||||
// If a map key supports TextMarshaler, use it.
|
// If a map key supports TextMarshaler, use it.
|
||||||
keystr := ""
|
keystr := ""
|
||||||
@ -556,7 +613,7 @@ func (f Formatter) prettyWithFlags(value any, flags uint32, depth int) string {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
buf.WriteString(keystr)
|
buf.WriteString(keystr)
|
||||||
buf.WriteByte(':')
|
buf.WriteByte(f.colon())
|
||||||
buf.WriteString(f.prettyWithFlags(it.Value().Interface(), 0, depth+1))
|
buf.WriteString(f.prettyWithFlags(it.Value().Interface(), 0, depth+1))
|
||||||
i++
|
i++
|
||||||
}
|
}
|
||||||
@ -706,6 +763,53 @@ func (f Formatter) sanitize(kvList []any) []any {
|
|||||||
return kvList
|
return kvList
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// startGroup opens a new group scope (basically a sub-struct), which locks all
|
||||||
|
// the current saved values and starts them anew. This is needed to satisfy
|
||||||
|
// slog.
|
||||||
|
func (f *Formatter) startGroup(group string) {
|
||||||
|
// Unnamed groups are just inlined.
|
||||||
|
if group == "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Any saved values can no longer be changed.
|
||||||
|
buf := bytes.NewBuffer(make([]byte, 0, 1024))
|
||||||
|
continuing := false
|
||||||
|
|
||||||
|
if f.parentValuesStr != "" {
|
||||||
|
buf.WriteString(f.parentValuesStr)
|
||||||
|
continuing = true
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.group != "" && f.valuesStr != "" {
|
||||||
|
if continuing {
|
||||||
|
buf.WriteByte(f.comma())
|
||||||
|
}
|
||||||
|
buf.WriteString(f.quoted(f.group, true)) // escape user-provided keys
|
||||||
|
buf.WriteByte(f.colon())
|
||||||
|
buf.WriteByte('{') // for the group
|
||||||
|
continuing = false
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.valuesStr != "" {
|
||||||
|
if continuing {
|
||||||
|
buf.WriteByte(f.comma())
|
||||||
|
}
|
||||||
|
buf.WriteString(f.valuesStr)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NOTE: We don't close the scope here - that's done later, when a log line
|
||||||
|
// is actually rendered (because we have N scopes to close).
|
||||||
|
|
||||||
|
f.parentValuesStr = buf.String()
|
||||||
|
|
||||||
|
// Start collecting new values.
|
||||||
|
f.group = group
|
||||||
|
f.groupDepth++
|
||||||
|
f.valuesStr = ""
|
||||||
|
f.values = nil
|
||||||
|
}
|
||||||
|
|
||||||
// Init configures this Formatter from runtime info, such as the call depth
|
// Init configures this Formatter from runtime info, such as the call depth
|
||||||
// imposed by logr itself.
|
// imposed by logr itself.
|
||||||
// Note that this receiver is a pointer, so depth can be saved.
|
// Note that this receiver is a pointer, so depth can be saved.
|
||||||
@ -740,7 +844,10 @@ func (f Formatter) FormatInfo(level int, msg string, kvList []any) (prefix, args
|
|||||||
if policy := f.opts.LogCaller; policy == All || policy == Info {
|
if policy := f.opts.LogCaller; policy == All || policy == Info {
|
||||||
args = append(args, "caller", f.caller())
|
args = append(args, "caller", f.caller())
|
||||||
}
|
}
|
||||||
args = append(args, "level", level, "msg", msg)
|
if key := *f.opts.LogInfoLevel; key != "" {
|
||||||
|
args = append(args, key, level)
|
||||||
|
}
|
||||||
|
args = append(args, "msg", msg)
|
||||||
return prefix, f.render(args, kvList)
|
return prefix, f.render(args, kvList)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
105
vendor/github.com/go-logr/logr/funcr/slogsink.go
generated
vendored
Normal file
105
vendor/github.com/go-logr/logr/funcr/slogsink.go
generated
vendored
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
//go:build go1.21
|
||||||
|
// +build go1.21
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright 2023 The logr Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package funcr
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"log/slog"
|
||||||
|
|
||||||
|
"github.com/go-logr/logr"
|
||||||
|
)
|
||||||
|
|
||||||
|
var _ logr.SlogSink = &fnlogger{}
|
||||||
|
|
||||||
|
const extraSlogSinkDepth = 3 // 2 for slog, 1 for SlogSink
|
||||||
|
|
||||||
|
func (l fnlogger) Handle(_ context.Context, record slog.Record) error {
|
||||||
|
kvList := make([]any, 0, 2*record.NumAttrs())
|
||||||
|
record.Attrs(func(attr slog.Attr) bool {
|
||||||
|
kvList = attrToKVs(attr, kvList)
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
|
||||||
|
if record.Level >= slog.LevelError {
|
||||||
|
l.WithCallDepth(extraSlogSinkDepth).Error(nil, record.Message, kvList...)
|
||||||
|
} else {
|
||||||
|
level := l.levelFromSlog(record.Level)
|
||||||
|
l.WithCallDepth(extraSlogSinkDepth).Info(level, record.Message, kvList...)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l fnlogger) WithAttrs(attrs []slog.Attr) logr.SlogSink {
|
||||||
|
kvList := make([]any, 0, 2*len(attrs))
|
||||||
|
for _, attr := range attrs {
|
||||||
|
kvList = attrToKVs(attr, kvList)
|
||||||
|
}
|
||||||
|
l.AddValues(kvList)
|
||||||
|
return &l
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l fnlogger) WithGroup(name string) logr.SlogSink {
|
||||||
|
l.startGroup(name)
|
||||||
|
return &l
|
||||||
|
}
|
||||||
|
|
||||||
|
// attrToKVs appends a slog.Attr to a logr-style kvList. It handle slog Groups
|
||||||
|
// and other details of slog.
|
||||||
|
func attrToKVs(attr slog.Attr, kvList []any) []any {
|
||||||
|
attrVal := attr.Value.Resolve()
|
||||||
|
if attrVal.Kind() == slog.KindGroup {
|
||||||
|
groupVal := attrVal.Group()
|
||||||
|
grpKVs := make([]any, 0, 2*len(groupVal))
|
||||||
|
for _, attr := range groupVal {
|
||||||
|
grpKVs = attrToKVs(attr, grpKVs)
|
||||||
|
}
|
||||||
|
if attr.Key == "" {
|
||||||
|
// slog says we have to inline these
|
||||||
|
kvList = append(kvList, grpKVs...)
|
||||||
|
} else {
|
||||||
|
kvList = append(kvList, attr.Key, PseudoStruct(grpKVs))
|
||||||
|
}
|
||||||
|
} else if attr.Key != "" {
|
||||||
|
kvList = append(kvList, attr.Key, attrVal.Any())
|
||||||
|
}
|
||||||
|
|
||||||
|
return kvList
|
||||||
|
}
|
||||||
|
|
||||||
|
// levelFromSlog adjusts the level by the logger's verbosity and negates it.
|
||||||
|
// It ensures that the result is >= 0. This is necessary because the result is
|
||||||
|
// passed to a LogSink and that API did not historically document whether
|
||||||
|
// levels could be negative or what that meant.
|
||||||
|
//
|
||||||
|
// Some example usage:
|
||||||
|
//
|
||||||
|
// logrV0 := getMyLogger()
|
||||||
|
// logrV2 := logrV0.V(2)
|
||||||
|
// slogV2 := slog.New(logr.ToSlogHandler(logrV2))
|
||||||
|
// slogV2.Debug("msg") // =~ logrV2.V(4) =~ logrV0.V(6)
|
||||||
|
// slogV2.Info("msg") // =~ logrV2.V(0) =~ logrV0.V(2)
|
||||||
|
// slogv2.Warn("msg") // =~ logrV2.V(-4) =~ logrV0.V(0)
|
||||||
|
func (l fnlogger) levelFromSlog(level slog.Level) int {
|
||||||
|
result := -level
|
||||||
|
if result < 0 {
|
||||||
|
result = 0 // because LogSink doesn't expect negative V levels
|
||||||
|
}
|
||||||
|
return int(result)
|
||||||
|
}
|
43
vendor/github.com/go-logr/logr/logr.go
generated
vendored
43
vendor/github.com/go-logr/logr/logr.go
generated
vendored
@ -207,10 +207,6 @@ limitations under the License.
|
|||||||
// those.
|
// those.
|
||||||
package logr
|
package logr
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
)
|
|
||||||
|
|
||||||
// New returns a new Logger instance. This is primarily used by libraries
|
// New returns a new Logger instance. This is primarily used by libraries
|
||||||
// implementing LogSink, rather than end users. Passing a nil sink will create
|
// implementing LogSink, rather than end users. Passing a nil sink will create
|
||||||
// a Logger which discards all log lines.
|
// a Logger which discards all log lines.
|
||||||
@ -410,45 +406,6 @@ func (l Logger) IsZero() bool {
|
|||||||
return l.sink == nil
|
return l.sink == nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// contextKey is how we find Loggers in a context.Context.
|
|
||||||
type contextKey struct{}
|
|
||||||
|
|
||||||
// FromContext returns a Logger from ctx or an error if no Logger is found.
|
|
||||||
func FromContext(ctx context.Context) (Logger, error) {
|
|
||||||
if v, ok := ctx.Value(contextKey{}).(Logger); ok {
|
|
||||||
return v, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
return Logger{}, notFoundError{}
|
|
||||||
}
|
|
||||||
|
|
||||||
// notFoundError exists to carry an IsNotFound method.
|
|
||||||
type notFoundError struct{}
|
|
||||||
|
|
||||||
func (notFoundError) Error() string {
|
|
||||||
return "no logr.Logger was present"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (notFoundError) IsNotFound() bool {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// FromContextOrDiscard returns a Logger from ctx. If no Logger is found, this
|
|
||||||
// returns a Logger that discards all log messages.
|
|
||||||
func FromContextOrDiscard(ctx context.Context) Logger {
|
|
||||||
if v, ok := ctx.Value(contextKey{}).(Logger); ok {
|
|
||||||
return v
|
|
||||||
}
|
|
||||||
|
|
||||||
return Discard()
|
|
||||||
}
|
|
||||||
|
|
||||||
// NewContext returns a new Context, derived from ctx, which carries the
|
|
||||||
// provided Logger.
|
|
||||||
func NewContext(ctx context.Context, logger Logger) context.Context {
|
|
||||||
return context.WithValue(ctx, contextKey{}, logger)
|
|
||||||
}
|
|
||||||
|
|
||||||
// RuntimeInfo holds information that the logr "core" library knows which
|
// RuntimeInfo holds information that the logr "core" library knows which
|
||||||
// LogSinks might want to know.
|
// LogSinks might want to know.
|
||||||
type RuntimeInfo struct {
|
type RuntimeInfo struct {
|
||||||
|
@ -17,18 +17,16 @@ See the License for the specific language governing permissions and
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package slogr
|
package logr
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
|
|
||||||
"github.com/go-logr/logr"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type slogHandler struct {
|
type slogHandler struct {
|
||||||
// May be nil, in which case all logs get discarded.
|
// May be nil, in which case all logs get discarded.
|
||||||
sink logr.LogSink
|
sink LogSink
|
||||||
// Non-nil if sink is non-nil and implements SlogSink.
|
// Non-nil if sink is non-nil and implements SlogSink.
|
||||||
slogSink SlogSink
|
slogSink SlogSink
|
||||||
|
|
||||||
@ -54,7 +52,7 @@ func (l *slogHandler) GetLevel() slog.Level {
|
|||||||
return l.levelBias
|
return l.levelBias
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *slogHandler) Enabled(ctx context.Context, level slog.Level) bool {
|
func (l *slogHandler) Enabled(_ context.Context, level slog.Level) bool {
|
||||||
return l.sink != nil && (level >= slog.LevelError || l.sink.Enabled(l.levelFromSlog(level)))
|
return l.sink != nil && (level >= slog.LevelError || l.sink.Enabled(l.levelFromSlog(level)))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,9 +70,7 @@ func (l *slogHandler) Handle(ctx context.Context, record slog.Record) error {
|
|||||||
|
|
||||||
kvList := make([]any, 0, 2*record.NumAttrs())
|
kvList := make([]any, 0, 2*record.NumAttrs())
|
||||||
record.Attrs(func(attr slog.Attr) bool {
|
record.Attrs(func(attr slog.Attr) bool {
|
||||||
if attr.Key != "" {
|
kvList = attrToKVs(attr, l.groupPrefix, kvList)
|
||||||
kvList = append(kvList, l.addGroupPrefix(attr.Key), attr.Value.Resolve().Any())
|
|
||||||
}
|
|
||||||
return true
|
return true
|
||||||
})
|
})
|
||||||
if record.Level >= slog.LevelError {
|
if record.Level >= slog.LevelError {
|
||||||
@ -90,15 +86,15 @@ func (l *slogHandler) Handle(ctx context.Context, record slog.Record) error {
|
|||||||
// are called by Handle, code in slog gets skipped.
|
// are called by Handle, code in slog gets skipped.
|
||||||
//
|
//
|
||||||
// This offset currently (Go 1.21.0) works for calls through
|
// This offset currently (Go 1.21.0) works for calls through
|
||||||
// slog.New(NewSlogHandler(...)). There's no guarantee that the call
|
// slog.New(ToSlogHandler(...)). There's no guarantee that the call
|
||||||
// chain won't change. Wrapping the handler will also break unwinding. It's
|
// chain won't change. Wrapping the handler will also break unwinding. It's
|
||||||
// still better than not adjusting at all....
|
// still better than not adjusting at all....
|
||||||
//
|
//
|
||||||
// This cannot be done when constructing the handler because NewLogr needs
|
// This cannot be done when constructing the handler because FromSlogHandler needs
|
||||||
// access to the original sink without this adjustment. A second copy would
|
// access to the original sink without this adjustment. A second copy would
|
||||||
// work, but then WithAttrs would have to be called for both of them.
|
// work, but then WithAttrs would have to be called for both of them.
|
||||||
func (l *slogHandler) sinkWithCallDepth() logr.LogSink {
|
func (l *slogHandler) sinkWithCallDepth() LogSink {
|
||||||
if sink, ok := l.sink.(logr.CallDepthLogSink); ok {
|
if sink, ok := l.sink.(CallDepthLogSink); ok {
|
||||||
return sink.WithCallDepth(2)
|
return sink.WithCallDepth(2)
|
||||||
}
|
}
|
||||||
return l.sink
|
return l.sink
|
||||||
@ -109,60 +105,88 @@ func (l *slogHandler) WithAttrs(attrs []slog.Attr) slog.Handler {
|
|||||||
return l
|
return l
|
||||||
}
|
}
|
||||||
|
|
||||||
copy := *l
|
clone := *l
|
||||||
if l.slogSink != nil {
|
if l.slogSink != nil {
|
||||||
copy.slogSink = l.slogSink.WithAttrs(attrs)
|
clone.slogSink = l.slogSink.WithAttrs(attrs)
|
||||||
copy.sink = copy.slogSink
|
clone.sink = clone.slogSink
|
||||||
} else {
|
} else {
|
||||||
kvList := make([]any, 0, 2*len(attrs))
|
kvList := make([]any, 0, 2*len(attrs))
|
||||||
for _, attr := range attrs {
|
for _, attr := range attrs {
|
||||||
if attr.Key != "" {
|
kvList = attrToKVs(attr, l.groupPrefix, kvList)
|
||||||
kvList = append(kvList, l.addGroupPrefix(attr.Key), attr.Value.Resolve().Any())
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
copy.sink = l.sink.WithValues(kvList...)
|
clone.sink = l.sink.WithValues(kvList...)
|
||||||
}
|
}
|
||||||
return ©
|
return &clone
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *slogHandler) WithGroup(name string) slog.Handler {
|
func (l *slogHandler) WithGroup(name string) slog.Handler {
|
||||||
if l.sink == nil {
|
if l.sink == nil {
|
||||||
return l
|
return l
|
||||||
}
|
}
|
||||||
copy := *l
|
if name == "" {
|
||||||
if l.slogSink != nil {
|
// slog says to inline empty groups
|
||||||
copy.slogSink = l.slogSink.WithGroup(name)
|
return l
|
||||||
copy.sink = l.slogSink
|
|
||||||
} else {
|
|
||||||
copy.groupPrefix = copy.addGroupPrefix(name)
|
|
||||||
}
|
}
|
||||||
return ©
|
clone := *l
|
||||||
|
if l.slogSink != nil {
|
||||||
|
clone.slogSink = l.slogSink.WithGroup(name)
|
||||||
|
clone.sink = clone.slogSink
|
||||||
|
} else {
|
||||||
|
clone.groupPrefix = addPrefix(clone.groupPrefix, name)
|
||||||
|
}
|
||||||
|
return &clone
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *slogHandler) addGroupPrefix(name string) string {
|
// attrToKVs appends a slog.Attr to a logr-style kvList. It handle slog Groups
|
||||||
if l.groupPrefix == "" {
|
// and other details of slog.
|
||||||
|
func attrToKVs(attr slog.Attr, groupPrefix string, kvList []any) []any {
|
||||||
|
attrVal := attr.Value.Resolve()
|
||||||
|
if attrVal.Kind() == slog.KindGroup {
|
||||||
|
groupVal := attrVal.Group()
|
||||||
|
grpKVs := make([]any, 0, 2*len(groupVal))
|
||||||
|
prefix := groupPrefix
|
||||||
|
if attr.Key != "" {
|
||||||
|
prefix = addPrefix(groupPrefix, attr.Key)
|
||||||
|
}
|
||||||
|
for _, attr := range groupVal {
|
||||||
|
grpKVs = attrToKVs(attr, prefix, grpKVs)
|
||||||
|
}
|
||||||
|
kvList = append(kvList, grpKVs...)
|
||||||
|
} else if attr.Key != "" {
|
||||||
|
kvList = append(kvList, addPrefix(groupPrefix, attr.Key), attrVal.Any())
|
||||||
|
}
|
||||||
|
|
||||||
|
return kvList
|
||||||
|
}
|
||||||
|
|
||||||
|
func addPrefix(prefix, name string) string {
|
||||||
|
if prefix == "" {
|
||||||
return name
|
return name
|
||||||
}
|
}
|
||||||
return l.groupPrefix + groupSeparator + name
|
if name == "" {
|
||||||
|
return prefix
|
||||||
|
}
|
||||||
|
return prefix + groupSeparator + name
|
||||||
}
|
}
|
||||||
|
|
||||||
// levelFromSlog adjusts the level by the logger's verbosity and negates it.
|
// levelFromSlog adjusts the level by the logger's verbosity and negates it.
|
||||||
// It ensures that the result is >= 0. This is necessary because the result is
|
// It ensures that the result is >= 0. This is necessary because the result is
|
||||||
// passed to a logr.LogSink and that API did not historically document whether
|
// passed to a LogSink and that API did not historically document whether
|
||||||
// levels could be negative or what that meant.
|
// levels could be negative or what that meant.
|
||||||
//
|
//
|
||||||
// Some example usage:
|
// Some example usage:
|
||||||
// logrV0 := getMyLogger()
|
//
|
||||||
// logrV2 := logrV0.V(2)
|
// logrV0 := getMyLogger()
|
||||||
// slogV2 := slog.New(slogr.NewSlogHandler(logrV2))
|
// logrV2 := logrV0.V(2)
|
||||||
// slogV2.Debug("msg") // =~ logrV2.V(4) =~ logrV0.V(6)
|
// slogV2 := slog.New(logr.ToSlogHandler(logrV2))
|
||||||
// slogV2.Info("msg") // =~ logrV2.V(0) =~ logrV0.V(2)
|
// slogV2.Debug("msg") // =~ logrV2.V(4) =~ logrV0.V(6)
|
||||||
// slogv2.Warn("msg") // =~ logrV2.V(-4) =~ logrV0.V(0)
|
// slogV2.Info("msg") // =~ logrV2.V(0) =~ logrV0.V(2)
|
||||||
|
// slogv2.Warn("msg") // =~ logrV2.V(-4) =~ logrV0.V(0)
|
||||||
func (l *slogHandler) levelFromSlog(level slog.Level) int {
|
func (l *slogHandler) levelFromSlog(level slog.Level) int {
|
||||||
result := -level
|
result := -level
|
||||||
result += l.levelBias // in case the original logr.Logger had a V level
|
result += l.levelBias // in case the original Logger had a V level
|
||||||
if result < 0 {
|
if result < 0 {
|
||||||
result = 0 // because logr.LogSink doesn't expect negative V levels
|
result = 0 // because LogSink doesn't expect negative V levels
|
||||||
}
|
}
|
||||||
return int(result)
|
return int(result)
|
||||||
}
|
}
|
48
vendor/github.com/go-logr/logr/slogr/slogr.go → vendor/github.com/go-logr/logr/slogr.go
generated
vendored
48
vendor/github.com/go-logr/logr/slogr/slogr.go → vendor/github.com/go-logr/logr/slogr.go
generated
vendored
@ -17,54 +17,46 @@ See the License for the specific language governing permissions and
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Package slogr enables usage of a slog.Handler with logr.Logger as front-end
|
package logr
|
||||||
// API and of a logr.LogSink through the slog.Handler and thus slog.Logger
|
|
||||||
// APIs.
|
|
||||||
//
|
|
||||||
// See the README in the top-level [./logr] package for a discussion of
|
|
||||||
// interoperability.
|
|
||||||
package slogr
|
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
|
|
||||||
"github.com/go-logr/logr"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// NewLogr returns a logr.Logger which writes to the slog.Handler.
|
// FromSlogHandler returns a Logger which writes to the slog.Handler.
|
||||||
//
|
//
|
||||||
// The logr verbosity level is mapped to slog levels such that V(0) becomes
|
// The logr verbosity level is mapped to slog levels such that V(0) becomes
|
||||||
// slog.LevelInfo and V(4) becomes slog.LevelDebug.
|
// slog.LevelInfo and V(4) becomes slog.LevelDebug.
|
||||||
func NewLogr(handler slog.Handler) logr.Logger {
|
func FromSlogHandler(handler slog.Handler) Logger {
|
||||||
if handler, ok := handler.(*slogHandler); ok {
|
if handler, ok := handler.(*slogHandler); ok {
|
||||||
if handler.sink == nil {
|
if handler.sink == nil {
|
||||||
return logr.Discard()
|
return Discard()
|
||||||
}
|
}
|
||||||
return logr.New(handler.sink).V(int(handler.levelBias))
|
return New(handler.sink).V(int(handler.levelBias))
|
||||||
}
|
}
|
||||||
return logr.New(&slogSink{handler: handler})
|
return New(&slogSink{handler: handler})
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewSlogHandler returns a slog.Handler which writes to the same sink as the logr.Logger.
|
// ToSlogHandler returns a slog.Handler which writes to the same sink as the Logger.
|
||||||
//
|
//
|
||||||
// The returned logger writes all records with level >= slog.LevelError as
|
// The returned logger writes all records with level >= slog.LevelError as
|
||||||
// error log entries with LogSink.Error, regardless of the verbosity level of
|
// error log entries with LogSink.Error, regardless of the verbosity level of
|
||||||
// the logr.Logger:
|
// the Logger:
|
||||||
//
|
//
|
||||||
// logger := <some logr.Logger with 0 as verbosity level>
|
// logger := <some Logger with 0 as verbosity level>
|
||||||
// slog.New(NewSlogHandler(logger.V(10))).Error(...) -> logSink.Error(...)
|
// slog.New(ToSlogHandler(logger.V(10))).Error(...) -> logSink.Error(...)
|
||||||
//
|
//
|
||||||
// The level of all other records gets reduced by the verbosity
|
// The level of all other records gets reduced by the verbosity
|
||||||
// level of the logr.Logger and the result is negated. If it happens
|
// level of the Logger and the result is negated. If it happens
|
||||||
// to be negative, then it gets replaced by zero because a LogSink
|
// to be negative, then it gets replaced by zero because a LogSink
|
||||||
// is not expected to handled negative levels:
|
// is not expected to handled negative levels:
|
||||||
//
|
//
|
||||||
// slog.New(NewSlogHandler(logger)).Debug(...) -> logger.GetSink().Info(level=4, ...)
|
// slog.New(ToSlogHandler(logger)).Debug(...) -> logger.GetSink().Info(level=4, ...)
|
||||||
// slog.New(NewSlogHandler(logger)).Warning(...) -> logger.GetSink().Info(level=0, ...)
|
// slog.New(ToSlogHandler(logger)).Warning(...) -> logger.GetSink().Info(level=0, ...)
|
||||||
// slog.New(NewSlogHandler(logger)).Info(...) -> logger.GetSink().Info(level=0, ...)
|
// slog.New(ToSlogHandler(logger)).Info(...) -> logger.GetSink().Info(level=0, ...)
|
||||||
// slog.New(NewSlogHandler(logger.V(4))).Info(...) -> logger.GetSink().Info(level=4, ...)
|
// slog.New(ToSlogHandler(logger.V(4))).Info(...) -> logger.GetSink().Info(level=4, ...)
|
||||||
func NewSlogHandler(logger logr.Logger) slog.Handler {
|
func ToSlogHandler(logger Logger) slog.Handler {
|
||||||
if sink, ok := logger.GetSink().(*slogSink); ok && logger.GetV() == 0 {
|
if sink, ok := logger.GetSink().(*slogSink); ok && logger.GetV() == 0 {
|
||||||
return sink.handler
|
return sink.handler
|
||||||
}
|
}
|
||||||
@ -87,7 +79,7 @@ func NewSlogHandler(logger logr.Logger) slog.Handler {
|
|||||||
// - verbosity levels > slog.LevelInfo can be recorded
|
// - verbosity levels > slog.LevelInfo can be recorded
|
||||||
// - less overhead
|
// - less overhead
|
||||||
//
|
//
|
||||||
// Both APIs (logr.Logger and slog.Logger/Handler) then are supported equally
|
// Both APIs (Logger and slog.Logger/Handler) then are supported equally
|
||||||
// well. Developers can pick whatever API suits them better and/or mix
|
// well. Developers can pick whatever API suits them better and/or mix
|
||||||
// packages which use either API in the same binary with a common logging
|
// packages which use either API in the same binary with a common logging
|
||||||
// implementation.
|
// implementation.
|
||||||
@ -97,10 +89,10 @@ func NewSlogHandler(logger logr.Logger) slog.Handler {
|
|||||||
// different prototype of the common Enabled method.
|
// different prototype of the common Enabled method.
|
||||||
//
|
//
|
||||||
// An implementation could support both interfaces in two different types, but then
|
// An implementation could support both interfaces in two different types, but then
|
||||||
// additional interfaces would be needed to convert between those types in NewLogr
|
// additional interfaces would be needed to convert between those types in FromSlogHandler
|
||||||
// and NewSlogHandler.
|
// and ToSlogHandler.
|
||||||
type SlogSink interface {
|
type SlogSink interface {
|
||||||
logr.LogSink
|
LogSink
|
||||||
|
|
||||||
Handle(ctx context.Context, record slog.Record) error
|
Handle(ctx context.Context, record slog.Record) error
|
||||||
WithAttrs(attrs []slog.Attr) SlogSink
|
WithAttrs(attrs []slog.Attr) SlogSink
|
@ -17,24 +17,22 @@ See the License for the specific language governing permissions and
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package slogr
|
package logr
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
"runtime"
|
"runtime"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-logr/logr"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
_ logr.LogSink = &slogSink{}
|
_ LogSink = &slogSink{}
|
||||||
_ logr.CallDepthLogSink = &slogSink{}
|
_ CallDepthLogSink = &slogSink{}
|
||||||
_ Underlier = &slogSink{}
|
_ Underlier = &slogSink{}
|
||||||
)
|
)
|
||||||
|
|
||||||
// Underlier is implemented by the LogSink returned by NewLogr.
|
// Underlier is implemented by the LogSink returned by NewFromLogHandler.
|
||||||
type Underlier interface {
|
type Underlier interface {
|
||||||
// GetUnderlying returns the Handler used by the LogSink.
|
// GetUnderlying returns the Handler used by the LogSink.
|
||||||
GetUnderlying() slog.Handler
|
GetUnderlying() slog.Handler
|
||||||
@ -54,7 +52,7 @@ type slogSink struct {
|
|||||||
handler slog.Handler
|
handler slog.Handler
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *slogSink) Init(info logr.RuntimeInfo) {
|
func (l *slogSink) Init(info RuntimeInfo) {
|
||||||
l.callDepth = info.CallDepth
|
l.callDepth = info.CallDepth
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -62,7 +60,7 @@ func (l *slogSink) GetUnderlying() slog.Handler {
|
|||||||
return l.handler
|
return l.handler
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *slogSink) WithCallDepth(depth int) logr.LogSink {
|
func (l *slogSink) WithCallDepth(depth int) LogSink {
|
||||||
newLogger := *l
|
newLogger := *l
|
||||||
newLogger.callDepth += depth
|
newLogger.callDepth += depth
|
||||||
return &newLogger
|
return &newLogger
|
||||||
@ -93,18 +91,18 @@ func (l *slogSink) log(err error, msg string, level slog.Level, kvList ...interf
|
|||||||
record.AddAttrs(slog.Any(errKey, err))
|
record.AddAttrs(slog.Any(errKey, err))
|
||||||
}
|
}
|
||||||
record.Add(kvList...)
|
record.Add(kvList...)
|
||||||
l.handler.Handle(context.Background(), record)
|
_ = l.handler.Handle(context.Background(), record)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l slogSink) WithName(name string) logr.LogSink {
|
func (l slogSink) WithName(name string) LogSink {
|
||||||
if l.name != "" {
|
if l.name != "" {
|
||||||
l.name = l.name + "/"
|
l.name += "/"
|
||||||
}
|
}
|
||||||
l.name += name
|
l.name += name
|
||||||
return &l
|
return &l
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l slogSink) WithValues(kvList ...interface{}) logr.LogSink {
|
func (l slogSink) WithValues(kvList ...interface{}) LogSink {
|
||||||
l.handler = l.handler.WithAttrs(kvListToAttrs(kvList...))
|
l.handler = l.handler.WithAttrs(kvListToAttrs(kvList...))
|
||||||
return &l
|
return &l
|
||||||
}
|
}
|
4
vendor/k8s.io/klog/v2/OWNERS
generated
vendored
4
vendor/k8s.io/klog/v2/OWNERS
generated
vendored
@ -1,14 +1,16 @@
|
|||||||
# See the OWNERS docs at https://go.k8s.io/owners
|
# See the OWNERS docs at https://go.k8s.io/owners
|
||||||
reviewers:
|
reviewers:
|
||||||
- harshanarayana
|
- harshanarayana
|
||||||
|
- mengjiao-liu
|
||||||
- pohly
|
- pohly
|
||||||
approvers:
|
approvers:
|
||||||
- dims
|
- dims
|
||||||
|
- pohly
|
||||||
- thockin
|
- thockin
|
||||||
- serathius
|
|
||||||
emeritus_approvers:
|
emeritus_approvers:
|
||||||
- brancz
|
- brancz
|
||||||
- justinsb
|
- justinsb
|
||||||
- lavalamp
|
- lavalamp
|
||||||
- piosz
|
- piosz
|
||||||
|
- serathius
|
||||||
- tallclair
|
- tallclair
|
||||||
|
31
vendor/k8s.io/klog/v2/contextual_slog.go
generated
vendored
Normal file
31
vendor/k8s.io/klog/v2/contextual_slog.go
generated
vendored
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
//go:build go1.21
|
||||||
|
// +build go1.21
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright 2021 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package klog
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log/slog"
|
||||||
|
|
||||||
|
"github.com/go-logr/logr"
|
||||||
|
)
|
||||||
|
|
||||||
|
// SetSlogLogger reconfigures klog to log through the slog logger. The logger must not be nil.
|
||||||
|
func SetSlogLogger(logger *slog.Logger) {
|
||||||
|
SetLoggerWithOptions(logr.FromSlogHandler(logger.Handler()), ContextualLogger(true))
|
||||||
|
}
|
23
vendor/k8s.io/klog/v2/klog.go
generated
vendored
23
vendor/k8s.io/klog/v2/klog.go
generated
vendored
@ -14,9 +14,26 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
// Package klog implements logging analogous to the Google-internal C++ INFO/ERROR/V setup.
|
// Package klog contains the following functionality:
|
||||||
// It provides functions Info, Warning, Error, Fatal, plus formatting variants such as
|
//
|
||||||
// Infof. It also provides V-style logging controlled by the -v and -vmodule=file=2 flags.
|
// - output routing as defined via command line flags ([InitFlags])
|
||||||
|
// - log formatting as text, either with a single, unstructured string ([Info], [Infof], etc.)
|
||||||
|
// or as a structured log entry with message and key/value pairs ([InfoS], etc.)
|
||||||
|
// - management of a go-logr [Logger] ([SetLogger], [Background], [TODO])
|
||||||
|
// - helper functions for logging values ([Format]) and managing the state of klog ([CaptureState], [State.Restore])
|
||||||
|
// - wrappers for [logr] APIs for contextual logging where the wrappers can
|
||||||
|
// be turned into no-ops ([EnableContextualLogging], [NewContext], [FromContext],
|
||||||
|
// [LoggerWithValues], [LoggerWithName]); if the ability to turn off
|
||||||
|
// contextual logging is not needed, then go-logr can also be used directly
|
||||||
|
// - type aliases for go-logr types to simplify imports in code which uses both (e.g. [Logger])
|
||||||
|
// - [k8s.io/klog/v2/textlogger]: a logger which uses the same formatting as klog log with
|
||||||
|
// simpler output routing; beware that it comes with its own command line flags
|
||||||
|
// and does not use the ones from klog
|
||||||
|
// - [k8s.io/klog/v2/ktesting]: per-test output in Go unit tests
|
||||||
|
// - [k8s.io/klog/v2/klogr]: a deprecated, standalone [logr.Logger] on top of the main klog package;
|
||||||
|
// use [Background] instead if klog output routing is needed, [k8s.io/klog/v2/textlogger] if not
|
||||||
|
// - [k8s.io/klog/v2/examples]: demos of this functionality
|
||||||
|
// - [k8s.io/klog/v2/test]: reusable tests for [logr.Logger] implementations
|
||||||
//
|
//
|
||||||
// Basic examples:
|
// Basic examples:
|
||||||
//
|
//
|
||||||
|
10
vendor/k8s.io/klog/v2/klogr_slog.go
generated
vendored
10
vendor/k8s.io/klog/v2/klogr_slog.go
generated
vendored
@ -25,7 +25,7 @@ import (
|
|||||||
"strconv"
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-logr/logr/slogr"
|
"github.com/go-logr/logr"
|
||||||
|
|
||||||
"k8s.io/klog/v2/internal/buffer"
|
"k8s.io/klog/v2/internal/buffer"
|
||||||
"k8s.io/klog/v2/internal/serialize"
|
"k8s.io/klog/v2/internal/serialize"
|
||||||
@ -35,7 +35,7 @@ import (
|
|||||||
|
|
||||||
func (l *klogger) Handle(ctx context.Context, record slog.Record) error {
|
func (l *klogger) Handle(ctx context.Context, record slog.Record) error {
|
||||||
if logging.logger != nil {
|
if logging.logger != nil {
|
||||||
if slogSink, ok := logging.logger.GetSink().(slogr.SlogSink); ok {
|
if slogSink, ok := logging.logger.GetSink().(logr.SlogSink); ok {
|
||||||
// Let that logger do the work.
|
// Let that logger do the work.
|
||||||
return slogSink.Handle(ctx, record)
|
return slogSink.Handle(ctx, record)
|
||||||
}
|
}
|
||||||
@ -77,13 +77,13 @@ func slogOutput(file string, line int, now time.Time, err error, s severity.Seve
|
|||||||
buffer.PutBuffer(b)
|
buffer.PutBuffer(b)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *klogger) WithAttrs(attrs []slog.Attr) slogr.SlogSink {
|
func (l *klogger) WithAttrs(attrs []slog.Attr) logr.SlogSink {
|
||||||
clone := *l
|
clone := *l
|
||||||
clone.values = serialize.WithValues(l.values, sloghandler.Attrs2KVList(l.groups, attrs))
|
clone.values = serialize.WithValues(l.values, sloghandler.Attrs2KVList(l.groups, attrs))
|
||||||
return &clone
|
return &clone
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *klogger) WithGroup(name string) slogr.SlogSink {
|
func (l *klogger) WithGroup(name string) logr.SlogSink {
|
||||||
clone := *l
|
clone := *l
|
||||||
if clone.groups != "" {
|
if clone.groups != "" {
|
||||||
clone.groups += "." + name
|
clone.groups += "." + name
|
||||||
@ -93,4 +93,4 @@ func (l *klogger) WithGroup(name string) slogr.SlogSink {
|
|||||||
return &clone
|
return &clone
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ slogr.SlogSink = &klogger{}
|
var _ logr.SlogSink = &klogger{}
|
||||||
|
34
vendor/k8s.io/klog/v2/safeptr.go
generated
vendored
Normal file
34
vendor/k8s.io/klog/v2/safeptr.go
generated
vendored
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
//go:build go1.18
|
||||||
|
// +build go1.18
|
||||||
|
|
||||||
|
/*
|
||||||
|
Copyright 2023 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package klog
|
||||||
|
|
||||||
|
// SafePtr is a function that takes a pointer of any type (T) as an argument.
|
||||||
|
// If the provided pointer is not nil, it returns the same pointer. If it is nil, it returns nil instead.
|
||||||
|
//
|
||||||
|
// This function is particularly useful to prevent nil pointer dereferencing when:
|
||||||
|
//
|
||||||
|
// - The type implements interfaces that are called by the logger, such as `fmt.Stringer`.
|
||||||
|
// - And these interface implementations do not perform nil checks themselves.
|
||||||
|
func SafePtr[T any](p *T) any {
|
||||||
|
if p == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
return p
|
||||||
|
}
|
7
vendor/modules.txt
vendored
7
vendor/modules.txt
vendored
@ -216,11 +216,10 @@ github.com/go-jose/go-jose/v3
|
|||||||
github.com/go-jose/go-jose/v3/cipher
|
github.com/go-jose/go-jose/v3/cipher
|
||||||
github.com/go-jose/go-jose/v3/json
|
github.com/go-jose/go-jose/v3/json
|
||||||
github.com/go-jose/go-jose/v3/jwt
|
github.com/go-jose/go-jose/v3/jwt
|
||||||
# github.com/go-logr/logr v1.3.0
|
# github.com/go-logr/logr v1.4.1
|
||||||
## explicit; go 1.18
|
## explicit; go 1.18
|
||||||
github.com/go-logr/logr
|
github.com/go-logr/logr
|
||||||
github.com/go-logr/logr/funcr
|
github.com/go-logr/logr/funcr
|
||||||
github.com/go-logr/logr/slogr
|
|
||||||
# github.com/go-logr/stdr v1.2.2
|
# github.com/go-logr/stdr v1.2.2
|
||||||
## explicit; go 1.16
|
## explicit; go 1.16
|
||||||
github.com/go-logr/stdr
|
github.com/go-logr/stdr
|
||||||
@ -1462,8 +1461,8 @@ k8s.io/controller-manager/pkg/features
|
|||||||
k8s.io/controller-manager/pkg/features/register
|
k8s.io/controller-manager/pkg/features/register
|
||||||
k8s.io/controller-manager/pkg/leadermigration/config
|
k8s.io/controller-manager/pkg/leadermigration/config
|
||||||
k8s.io/controller-manager/pkg/leadermigration/options
|
k8s.io/controller-manager/pkg/leadermigration/options
|
||||||
# k8s.io/klog/v2 v2.110.1
|
# k8s.io/klog/v2 v2.120.0
|
||||||
## explicit; go 1.13
|
## explicit; go 1.18
|
||||||
k8s.io/klog/v2
|
k8s.io/klog/v2
|
||||||
k8s.io/klog/v2/internal/buffer
|
k8s.io/klog/v2/internal/buffer
|
||||||
k8s.io/klog/v2/internal/clock
|
k8s.io/klog/v2/internal/clock
|
||||||
|
Loading…
Reference in New Issue
Block a user