2024-02-16 17:09:58 +02:00
|
|
|
// Copyright The OpenTelemetry 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 log // import "go.opentelemetry.io/otel/log"
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"go.opentelemetry.io/otel/attribute"
|
2024-02-18 17:51:13 +02:00
|
|
|
"go.opentelemetry.io/otel/log/embedded"
|
2024-02-16 17:09:58 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Logger emits log records.
|
|
|
|
//
|
|
|
|
// Warning: Methods may be added to this interface in minor releases. See
|
|
|
|
// package documentation on API implementation for information on how to set
|
|
|
|
// default behavior for unimplemented methods.
|
|
|
|
type Logger interface {
|
2024-02-18 17:51:13 +02:00
|
|
|
// Users of the interface can ignore this. This embedded type is only used
|
|
|
|
// by implementations of this interface. See the "API Implementations"
|
|
|
|
// section of the package documentation for more information.
|
|
|
|
embedded.Logger
|
2024-02-16 17:09:58 +02:00
|
|
|
|
|
|
|
// Emit emits a log record.
|
|
|
|
//
|
|
|
|
// The record may be held by the implementation. Callers should not mutate
|
|
|
|
// the record after passed.
|
|
|
|
//
|
|
|
|
// Implementations of this method need to be safe for a user to call
|
|
|
|
// concurrently.
|
|
|
|
Emit(ctx context.Context, record Record)
|
|
|
|
}
|
|
|
|
|
|
|
|
// LoggerOption applies configuration options to a [Logger].
|
|
|
|
type LoggerOption interface {
|
|
|
|
// applyLogger is used to set a LoggerOption value of a LoggerConfig.
|
|
|
|
applyLogger(LoggerConfig) LoggerConfig
|
|
|
|
}
|
|
|
|
|
|
|
|
// LoggerConfig contains options for a [Logger].
|
|
|
|
type LoggerConfig struct {
|
|
|
|
// Ensure forward compatibility by explicitly making this not comparable.
|
|
|
|
noCmp [0]func() //nolint: unused // This is indeed used.
|
2024-02-18 18:13:42 +02:00
|
|
|
|
|
|
|
version string
|
|
|
|
schemaURL string
|
|
|
|
attrs attribute.Set
|
2024-02-16 17:09:58 +02:00
|
|
|
}
|
|
|
|
|
2024-02-18 18:13:42 +02:00
|
|
|
// NewLoggerConfig returns a new [LoggerConfig] with all the options applied.
|
|
|
|
func NewLoggerConfig(options ...LoggerOption) LoggerConfig {
|
|
|
|
var c LoggerConfig
|
|
|
|
for _, opt := range options {
|
|
|
|
c = opt.applyLogger(c)
|
|
|
|
}
|
|
|
|
return c
|
|
|
|
}
|
2024-02-16 17:09:58 +02:00
|
|
|
|
|
|
|
// InstrumentationVersion returns the version of the library providing
|
|
|
|
// instrumentation.
|
2024-02-18 18:13:42 +02:00
|
|
|
func (cfg LoggerConfig) InstrumentationVersion() string {
|
|
|
|
return cfg.version
|
|
|
|
}
|
2024-02-16 17:09:58 +02:00
|
|
|
|
|
|
|
// InstrumentationAttributes returns the attributes associated with the library
|
|
|
|
// providing instrumentation.
|
2024-02-18 18:13:42 +02:00
|
|
|
func (cfg LoggerConfig) InstrumentationAttributes() attribute.Set {
|
|
|
|
return cfg.attrs
|
|
|
|
}
|
2024-02-16 17:09:58 +02:00
|
|
|
|
|
|
|
// SchemaURL returns the schema URL of the library providing instrumentation.
|
2024-02-18 18:13:42 +02:00
|
|
|
func (cfg LoggerConfig) SchemaURL() string {
|
|
|
|
return cfg.schemaURL
|
|
|
|
}
|
|
|
|
|
|
|
|
type loggerOptionFunc func(LoggerConfig) LoggerConfig
|
|
|
|
|
|
|
|
func (fn loggerOptionFunc) applyLogger(cfg LoggerConfig) LoggerConfig {
|
|
|
|
return fn(cfg)
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithInstrumentationVersion returns a [LoggerOption] that sets the
|
|
|
|
// instrumentation version of a [Logger].
|
|
|
|
func WithInstrumentationVersion(version string) LoggerOption {
|
|
|
|
return loggerOptionFunc(func(config LoggerConfig) LoggerConfig {
|
|
|
|
config.version = version
|
|
|
|
return config
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithInstrumentationAttributes returns a [LoggerOption] that sets the
|
|
|
|
// instrumentation attributes of a [Logger].
|
|
|
|
//
|
|
|
|
// The passed attributes will be de-duplicated.
|
|
|
|
func WithInstrumentationAttributes(attr ...attribute.KeyValue) LoggerOption {
|
|
|
|
return loggerOptionFunc(func(config LoggerConfig) LoggerConfig {
|
|
|
|
config.attrs = attribute.NewSet(attr...)
|
|
|
|
return config
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithSchemaURL returns a [LoggerOption] that sets the schema URL for a
|
|
|
|
// [Logger].
|
|
|
|
func WithSchemaURL(schemaURL string) LoggerOption {
|
|
|
|
return loggerOptionFunc(func(config LoggerConfig) LoggerConfig {
|
|
|
|
config.schemaURL = schemaURL
|
|
|
|
return config
|
|
|
|
})
|
|
|
|
}
|