mirror of
https://github.com/grafana/grafana.git
synced 2025-01-16 11:42:35 -06:00
78978048c3
Signed-off-by: bergquist <carl.bergquist@gmail.com> Co-authored-by: Emil Tullstedt <emil.tullstedt@grafana.com> Co-authored-by: Dave Henderson <dave.henderson@grafana.com>
45 lines
948 B
Go
45 lines
948 B
Go
package log
|
|
|
|
import (
|
|
"context"
|
|
"sync/atomic"
|
|
)
|
|
|
|
type contextKey struct{}
|
|
|
|
var dbCallCounterNameKey = contextKey{}
|
|
|
|
// InitCounter creates a pointer on the context that can be incremented later
|
|
func InitCounter(ctx context.Context) context.Context {
|
|
var ptr *int64 = new(int64)
|
|
return context.WithValue(ctx, dbCallCounterNameKey, ptr)
|
|
}
|
|
|
|
// IncDBCallCounter increments the database counter on the context.
|
|
func IncDBCallCounter(ctx context.Context) context.Context {
|
|
if val := ctx.Value(dbCallCounterNameKey); val == nil {
|
|
ctx = InitCounter(ctx)
|
|
}
|
|
|
|
if val := ctx.Value(dbCallCounterNameKey); val != nil {
|
|
v2, ok := val.(*int64)
|
|
if ok {
|
|
atomic.AddInt64(v2, 1)
|
|
}
|
|
}
|
|
|
|
return ctx
|
|
}
|
|
|
|
// TotalDBCallCount returns the total number of requests for the context
|
|
func TotalDBCallCount(ctx context.Context) int64 {
|
|
if val := ctx.Value(dbCallCounterNameKey); val != nil {
|
|
v2, ok := val.(*int64)
|
|
if ok {
|
|
return *v2
|
|
}
|
|
}
|
|
|
|
return 0
|
|
}
|