Skip to content

Commit

Permalink
feat: add telemetry pkg
Browse files Browse the repository at this point in the history
  • Loading branch information
eminetto committed Apr 6, 2023
1 parent fa08169 commit c87d18e
Showing 1 changed file with 86 additions and 0 deletions.
86 changes: 86 additions & 0 deletions internal/telemetry/opentelemetry.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
package telemetry

import (
"context"
"go.opentelemetry.io/otel"
"go.opentelemetry.io/otel/exporters/otlp/otlptrace"
"go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp"
"go.opentelemetry.io/otel/propagation"
"go.opentelemetry.io/otel/sdk/resource"
sdktrace "go.opentelemetry.io/otel/sdk/trace"
semconv "go.opentelemetry.io/otel/semconv/v1.12.0"
"go.opentelemetry.io/otel/trace"
)

type Telemetry interface {
Start(ctx context.Context, name string, opts ...trace.SpanStartOption) (context.Context, Span)
Shutdown(ctx context.Context)
}

type Span interface {
trace.Span
}

type OTel struct {
provider *sdktrace.TracerProvider
tracer trace.Tracer
}

func New(ctx context.Context, serviceName string) (*OTel, error) {
var tp *sdktrace.TracerProvider
var err error
tp, err = createTraceProvider(ctx, serviceName)
if err != nil {
return nil, err
}
otel.SetTracerProvider(tp)
otel.SetTextMapPropagator(propagation.NewCompositeTextMapPropagator(propagation.TraceContext{}, propagation.Baggage{}))
tracer := tp.Tracer(serviceName)

return &OTel{
provider: tp,
tracer: tracer,
}, nil
}

func (ot *OTel) Start(ctx context.Context, name string, opts ...trace.SpanStartOption) (context.Context, Span) {
if len(opts) == 0 {
return ot.tracer.Start(ctx, name)
}
return ot.tracer.Start(ctx, name, opts[0])
}

func (ot *OTel) Shutdown(ctx context.Context) {
ot.provider.Shutdown(ctx)
}

func createResource(ctx context.Context, serviceName string) (*resource.Resource, error) {
return resource.New(ctx,
resource.WithAttributes(
semconv.ServiceNameKey.String(serviceName),
),
)
}

func createTraceProvider(ctx context.Context, serviceName string) (*sdktrace.TracerProvider, error) {
res, err := createResource(ctx, serviceName)
if err != nil {
return nil, err
}

client := otlptracehttp.NewClient()
exp, err := otlptrace.New(ctx, client)
if err != nil {
return nil, err
}
tp := sdktrace.NewTracerProvider(
sdktrace.WithBatcher(exp),
sdktrace.WithResource(res),
sdktrace.WithResource(resource.NewWithAttributes(
semconv.SchemaURL,
semconv.ServiceNameKey.String(serviceName),
semconv.DeploymentEnvironmentKey.String("prod"),
)),
)
return tp, nil
}

0 comments on commit c87d18e

Please sign in to comment.