You've already forked opentelemetry-go
mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2026-06-03 18:35:08 +02:00
5e9a80b3ce
Fixes #7933 Add BYTES type to https://pkg.go.dev/go.opentelemetry.io/otel/attribute - Introduces BYTES type and byte - Adds Bytes / BytesValue constructors - Implements hashing support - Adds base64 representation in Emit() - Adds test coverage for constructors, hashing, and set equality ``` $ go test -run=^$ -bench=BenchmarkByteSlice goos: linux goarch: amd64 pkg: go.opentelemetry.io/otel/attribute cpu: 13th Gen Intel(R) Core(TM) i7-13800H BenchmarkByteSlice/Value-20 149529567 7.993 ns/op 0 B/op 0 allocs/op BenchmarkByteSlice/KeyValue-20 136973736 8.768 ns/op 0 B/op 0 allocs/op BenchmarkByteSlice/AsByteSlice-20 562915658 2.120 ns/op 0 B/op 0 allocs/op BenchmarkByteSlice/Emit-20 29149410 40.26 ns/op 16 B/op 1 allocs/op PASS ``` --------- Co-authored-by: Tyler Yahn <MrAlias@users.noreply.github.com> Co-authored-by: Robert Pająk <pellared@hotmail.com>
135 lines
3.6 KiB
Go
135 lines
3.6 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package attribute // import "go.opentelemetry.io/otel/attribute"
|
|
|
|
// Key represents the key part in key-value pairs. It's a string. The
|
|
// allowed character set in the key depends on the use of the key.
|
|
type Key string
|
|
|
|
// Bool creates a KeyValue instance with a BOOL Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- Bool(name, value).
|
|
func (k Key) Bool(v bool) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: BoolValue(v),
|
|
}
|
|
}
|
|
|
|
// BoolSlice creates a KeyValue instance with a BOOLSLICE Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- BoolSlice(name, value).
|
|
func (k Key) BoolSlice(v []bool) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: BoolSliceValue(v),
|
|
}
|
|
}
|
|
|
|
// Int creates a KeyValue instance with an INT64 Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- Int(name, value).
|
|
func (k Key) Int(v int) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: IntValue(v),
|
|
}
|
|
}
|
|
|
|
// IntSlice creates a KeyValue instance with an INT64SLICE Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- IntSlice(name, value).
|
|
func (k Key) IntSlice(v []int) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: IntSliceValue(v),
|
|
}
|
|
}
|
|
|
|
// Int64 creates a KeyValue instance with an INT64 Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- Int64(name, value).
|
|
func (k Key) Int64(v int64) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: Int64Value(v),
|
|
}
|
|
}
|
|
|
|
// Int64Slice creates a KeyValue instance with an INT64SLICE Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- Int64Slice(name, value).
|
|
func (k Key) Int64Slice(v []int64) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: Int64SliceValue(v),
|
|
}
|
|
}
|
|
|
|
// Float64 creates a KeyValue instance with a FLOAT64 Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- Float64(name, value).
|
|
func (k Key) Float64(v float64) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: Float64Value(v),
|
|
}
|
|
}
|
|
|
|
// Float64Slice creates a KeyValue instance with a FLOAT64SLICE Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- Float64(name, value).
|
|
func (k Key) Float64Slice(v []float64) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: Float64SliceValue(v),
|
|
}
|
|
}
|
|
|
|
// String creates a KeyValue instance with a STRING Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- String(name, value).
|
|
func (k Key) String(v string) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: StringValue(v),
|
|
}
|
|
}
|
|
|
|
// StringSlice creates a KeyValue instance with a STRINGSLICE Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- StringSlice(name, value).
|
|
func (k Key) StringSlice(v []string) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: StringSliceValue(v),
|
|
}
|
|
}
|
|
|
|
// ByteSlice creates a KeyValue instance with a BYTESLICE Value.
|
|
//
|
|
// If creating both a key and value at the same time, use the provided
|
|
// convenience function instead -- ByteSlice(name, value).
|
|
func (k Key) ByteSlice(v []byte) KeyValue {
|
|
return KeyValue{
|
|
Key: k,
|
|
Value: ByteSliceValue(v),
|
|
}
|
|
}
|
|
|
|
// Defined reports whether the key is not empty.
|
|
func (k Key) Defined() bool {
|
|
return len(k) != 0
|
|
}
|