mirror of
https://github.com/pomerium/pomerium.git
synced 2025-04-28 18:06:34 +02:00
* update tracing config definitions * new tracing system * performance improvements * only configure tracing in envoy if it is enabled in pomerium * [tracing] refactor to use custom extension for trace id editing (#5420) refactor to use custom extension for trace id editing * set default tracing sample rate to 1.0 * fix proxy service http middleware * improve some existing auth related traces * test fixes * bump envoyproxy/go-control-plane * code cleanup * test fixes * Fix missing spans for well-known endpoints * import extension apis from pomerium/envoy-custom
35 lines
734 B
Go
35 lines
734 B
Go
package config
|
|
|
|
import (
|
|
"context"
|
|
"sync"
|
|
|
|
"github.com/pomerium/pomerium/internal/log"
|
|
)
|
|
|
|
// The LogManager configures logging based on options.
|
|
type LogManager struct {
|
|
mu sync.Mutex
|
|
}
|
|
|
|
// NewLogManager creates a new LogManager.
|
|
func NewLogManager(ctx context.Context, src Source) *LogManager {
|
|
mgr := &LogManager{}
|
|
src.OnConfigChange(ctx, mgr.OnConfigChange)
|
|
mgr.OnConfigChange(ctx, src.GetConfig())
|
|
return mgr
|
|
}
|
|
|
|
// OnConfigChange is called whenever configuration changes.
|
|
func (mgr *LogManager) OnConfigChange(_ context.Context, cfg *Config) {
|
|
if cfg == nil || cfg.Options == nil {
|
|
return
|
|
}
|
|
|
|
mgr.mu.Lock()
|
|
defer mgr.mu.Unlock()
|
|
|
|
if cfg.Options.LogLevel != "" {
|
|
log.SetLevel(cfg.Options.LogLevel.ToZerolog())
|
|
}
|
|
}
|