-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy pathversion.go
71 lines (65 loc) · 2.41 KB
/
version.go
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
package api
// Version is a dumb way to version our collector handlers
type Version string
const (
// v01 is DEPRECATED
v01 Version = "v0.1"
// v02 is DEPRECATED
v02 Version = "v0.2"
// v03
// Traces: msgpack/JSON (Content-Type) slice of traces
v03 Version = "v0.3"
// v04
// Traces: msgpack/JSON (Content-Type) slice of traces + returns service sampling ratios
v04 Version = "v0.4"
// v05
//
// Content-Type: application/msgpack
// Payload: Traces with strings de-duplicated into a dictionary.
// Response: Service sampling rates.
//
// The payload is an array containing exactly 2 elements:
//
// 1. An array of all unique strings present in the payload (a dictionary referred to by index).
// 2. An array of traces, where each trace is an array of spans. A span is encoded as an array having
// exactly 12 elements, representing all span properties, in this exact order:
//
// 0: Service (uint32)
// 1: Name (uint32)
// 2: Resource (uint32)
// 3: TraceID (uint64)
// 4: SpanID (uint64)
// 5: ParentID (uint64)
// 6: Start (int64)
// 7: Duration (int64)
// 8: Error (int32)
// 9: Meta (map[uint32]uint32)
// 10: Metrics (map[uint32]float64)
// 11: Type (uint32)
//
// Considerations:
//
// - The "uint32" typed values in "Service", "Name", "Resource", "Type", "Meta" and "Metrics" represent
// the index at which the corresponding string is found in the dictionary. If any of the values are the
// empty string, then the empty string must be added into the dictionary.
//
// - None of the elements can be nil. If any of them are unset, they should be given their "zero-value". Here
// is an example of a span with all unset values:
//
// 0: 0 // Service is "" (index 0 in dictionary)
// 1: 0 // Name is ""
// 2: 0 // Resource is ""
// 3: 0 // TraceID
// 4: 0 // SpanID
// 5: 0 // ParentID
// 6: 0 // Start
// 7: 0 // Duration
// 8: 0 // Error
// 9: map[uint32]uint32{} // Meta (empty map)
// 10: map[uint32]float64{} // Metrics (empty map)
// 11: 0 // Type is ""
//
// The dictionary in this case would be []string{""}, having only the empty string at index 0.
//
v05 Version = "v0.5"
)