mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-07 11:57:49 +00:00
6b3f5b984c
* refactor: switch from opencensus to opentelemetry * tempo works as designed nooooot * fix: log traceids * with grafana agent * fix: http tracing * fix: cleanup files * chore: remove todo * fix: bad test * fix: ignore methods in grpc interceptors * fix: remove test log * clean up * typo * fix(config): configure tracing endpoint * fix(span): add error id to span * feat: metrics package * feat: metrics package * fix: counter * fix: metric * try metrics * fix: coutner metrics * fix: active sessin counter * fix: active sessin counter * fix: change current Sequence table * fix: change current Sequence table * fix: current sequences * fix: spooler div metrics * fix: console view * fix: merge master * fix: Last spool run on search result instead of eventtimestamp * fix: go mod * Update console/src/assets/i18n/de.json Co-authored-by: Livio Amstutz <livio.a@gmail.com> * fix: pr review * fix: map * update oidc pkg * fix: handlers * fix: value observer * fix: remove fmt * fix: handlers * fix: tests * fix: handler minimum cycle duration 1s * fix(spooler): handler channel buffer * fix interceptors Co-authored-by: adlerhurst <silvan.reusser@gmail.com> Co-authored-by: Livio Amstutz <livio.a@gmail.com>
70 lines
1.7 KiB
Go
70 lines
1.7 KiB
Go
package config
|
|
|
|
import (
|
|
"encoding/json"
|
|
|
|
"github.com/caos/zitadel/internal/errors"
|
|
"github.com/caos/zitadel/internal/telemetry/tracing"
|
|
"github.com/caos/zitadel/internal/telemetry/tracing/google"
|
|
"github.com/caos/zitadel/internal/telemetry/tracing/log"
|
|
"github.com/caos/zitadel/internal/telemetry/tracing/otel"
|
|
)
|
|
|
|
type TracingConfig struct {
|
|
Type string
|
|
Config tracing.Config
|
|
}
|
|
|
|
var tracer = map[string]func() tracing.Config{
|
|
"otel": func() tracing.Config { return &otel.Config{} },
|
|
"google": func() tracing.Config { return &google.Config{} },
|
|
"log": func() tracing.Config { return &log.Config{} },
|
|
"none": func() tracing.Config { return &NoTracing{} },
|
|
"": func() tracing.Config { return &NoTracing{} },
|
|
}
|
|
|
|
func (c *TracingConfig) UnmarshalJSON(data []byte) error {
|
|
var rc struct {
|
|
Type string
|
|
Config json.RawMessage
|
|
}
|
|
|
|
if err := json.Unmarshal(data, &rc); err != nil {
|
|
return errors.ThrowInternal(err, "TRACE-vmjS", "error parsing config")
|
|
}
|
|
|
|
c.Type = rc.Type
|
|
|
|
var err error
|
|
c.Config, err = newTracingConfig(c.Type, rc.Config)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return c.Config.NewTracer()
|
|
}
|
|
|
|
func newTracingConfig(tracerType string, configData []byte) (tracing.Config, error) {
|
|
t, ok := tracer[tracerType]
|
|
if !ok {
|
|
return nil, errors.ThrowInternalf(nil, "TRACE-HMEJ", "config type %s not supported", tracerType)
|
|
}
|
|
|
|
tracingConfig := t()
|
|
if len(configData) == 0 {
|
|
return tracingConfig, nil
|
|
}
|
|
|
|
if err := json.Unmarshal(configData, tracingConfig); err != nil {
|
|
return nil, errors.ThrowInternal(err, "TRACE-1tSS", "Could not read config: %v")
|
|
}
|
|
|
|
return tracingConfig, nil
|
|
}
|
|
|
|
type NoTracing struct{}
|
|
|
|
func (_ *NoTracing) NewTracer() error {
|
|
return nil
|
|
}
|