aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/github.com/uber/jaeger-client-go/zipkin.go
blob: 636952b7f1d04ad1af34f8008cb103c0d334c93b (plain) (blame)
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// Copyright (c) 2017 Uber Technologies, Inc.
//
// 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 jaeger

import (
    "github.com/opentracing/opentracing-go"
)

// ZipkinSpanFormat is an OpenTracing carrier format constant
const ZipkinSpanFormat = "zipkin-span-format"

// ExtractableZipkinSpan is a type of Carrier used for integration with Zipkin-aware
// RPC frameworks (like TChannel). It does not support baggage, only trace IDs.
type ExtractableZipkinSpan interface {
    TraceID() uint64
    SpanID() uint64
    ParentID() uint64
    Flags() byte
}

// InjectableZipkinSpan is a type of Carrier used for integration with Zipkin-aware
// RPC frameworks (like TChannel). It does not support baggage, only trace IDs.
type InjectableZipkinSpan interface {
    SetTraceID(traceID uint64)
    SetSpanID(spanID uint64)
    SetParentID(parentID uint64)
    SetFlags(flags byte)
}

type zipkinPropagator struct {
    tracer *Tracer
}

func (p *zipkinPropagator) Inject(
    ctx SpanContext,
    abstractCarrier interface{},
) error {
    carrier, ok := abstractCarrier.(InjectableZipkinSpan)
    if !ok {
        return opentracing.ErrInvalidCarrier
    }

    carrier.SetTraceID(ctx.TraceID().Low) // TODO this cannot work with 128bit IDs
    carrier.SetSpanID(uint64(ctx.SpanID()))
    carrier.SetParentID(uint64(ctx.ParentID()))
    carrier.SetFlags(ctx.flags)
    return nil
}

func (p *zipkinPropagator) Extract(abstractCarrier interface{}) (SpanContext, error) {
    carrier, ok := abstractCarrier.(ExtractableZipkinSpan)
    if !ok {
        return emptyContext, opentracing.ErrInvalidCarrier
    }
    if carrier.TraceID() == 0 {
        return emptyContext, opentracing.ErrSpanContextNotFound
    }
    var ctx SpanContext
    ctx.traceID.Low = carrier.TraceID()
    ctx.spanID = SpanID(carrier.SpanID())
    ctx.parentID = SpanID(carrier.ParentID())
    ctx.flags = carrier.Flags()
    return ctx, nil
}