mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-28 03:57:09 +02:00
335f4de960
* Add the log/global package * Implement the stubbed features * Add ConcurrentSafe tests * Restructure with internal implementation * Add internal global state * Use internal state in log/global * Add TestDelegation * Fix lint * Clean log_test.go * Clean up * Add changelog entry * Simplify TestMultipleGlobalLoggerProvider * Shorten log.go * Fix comment text wrapping * Shorten state_test.go * Don't pollute output in TestSetLoggerProvider
54 lines
1.3 KiB
Go
54 lines
1.3 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package global // import "go.opentelemetry.io/otel/log/internal/global"
|
|
|
|
import (
|
|
"errors"
|
|
"sync"
|
|
"sync/atomic"
|
|
|
|
"go.opentelemetry.io/otel/internal/global"
|
|
"go.opentelemetry.io/otel/log"
|
|
)
|
|
|
|
var (
|
|
globalLoggerProvider = defaultLoggerProvider()
|
|
|
|
delegateLoggerOnce sync.Once
|
|
)
|
|
|
|
func defaultLoggerProvider() *atomic.Value {
|
|
v := &atomic.Value{}
|
|
v.Store(loggerProviderHolder{provider: &loggerProvider{}})
|
|
return v
|
|
}
|
|
|
|
type loggerProviderHolder struct {
|
|
provider log.LoggerProvider
|
|
}
|
|
|
|
// GetLoggerProvider returns the global LoggerProvider.
|
|
func GetLoggerProvider() log.LoggerProvider {
|
|
return globalLoggerProvider.Load().(loggerProviderHolder).provider
|
|
}
|
|
|
|
// SetLoggerProvider sets the global LoggerProvider.
|
|
func SetLoggerProvider(provider log.LoggerProvider) {
|
|
current := GetLoggerProvider()
|
|
if _, cOk := current.(*loggerProvider); cOk {
|
|
if _, mpOk := provider.(*loggerProvider); mpOk && current == provider {
|
|
err := errors.New("invalid delegation: LoggerProvider self-delegation")
|
|
global.Error(err, "No delegate will be configured")
|
|
return
|
|
}
|
|
}
|
|
|
|
delegateLoggerOnce.Do(func() {
|
|
if def, ok := current.(*loggerProvider); ok {
|
|
def.setDelegate(provider)
|
|
}
|
|
})
|
|
globalLoggerProvider.Store(loggerProviderHolder{provider: provider})
|
|
}
|