1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
|
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
package minsev // import "go.opentelemetry.io/contrib/processors/minsev"
import (
"context"
"fmt"
"os"
"strings"
"sync"
"go.opentelemetry.io/otel/log"
)
const key = "OTEL_LOG_LEVEL"
var getSeverity = sync.OnceValue(func() log.Severity {
conv := map[string]log.Severity{
"": log.SeverityInfo, // Default to SeverityInfo for unset.
"debug": log.SeverityDebug,
"info": log.SeverityInfo,
"warn": log.SeverityWarn,
"error": log.SeverityError,
}
// log.SeverityUndefined for unknown values.
return conv[strings.ToLower(os.Getenv(key))]
})
type EnvSeverity struct{}
func (EnvSeverity) Severity() log.Severity { return getSeverity() }
func ExampleSeveritier() {
// Mock an environment variable setup that would be done externally.
_ = os.Setenv(key, "error")
p := NewLogProcessor(&processor{}, EnvSeverity{})
ctx, params := context.Background(), log.EnabledParameters{}
params.SetSeverity(log.SeverityDebug)
fmt.Println(p.Enabled(ctx, params))
params.SetSeverity(log.SeverityError)
fmt.Println(p.Enabled(ctx, params))
// Output:
// false
// true
}
|