![dependabot[bot]](/assets/img/avatar_default.png)
Bumps the otel group with 5 updates in the / directory: | Package | From | To | | --- | --- | --- | | [go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc](https://github.com/open-telemetry/opentelemetry-go-contrib) | `0.51.0` | `0.53.0` | | [go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp](https://github.com/open-telemetry/opentelemetry-go-contrib) | `0.51.0` | `0.53.0` | | [go.opentelemetry.io/otel/exporters/otlp/otlptrace](https://github.com/open-telemetry/opentelemetry-go) | `1.26.0` | `1.28.0` | | [go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc](https://github.com/open-telemetry/opentelemetry-go) | `1.26.0` | `1.28.0` | | [go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp](https://github.com/open-telemetry/opentelemetry-go) | `1.26.0` | `1.28.0` | Updates `go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc` from 0.51.0 to 0.53.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go-contrib/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go-contrib/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go-contrib/compare/zpages/v0.51.0...zpages/v0.53.0) Updates `go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp` from 0.51.0 to 0.53.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go-contrib/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go-contrib/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go-contrib/compare/zpages/v0.51.0...zpages/v0.53.0) Updates `go.opentelemetry.io/otel` from 1.26.0 to 1.28.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.26.0...v1.28.0) Updates `go.opentelemetry.io/otel/exporters/otlp/otlptrace` from 1.26.0 to 1.28.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.26.0...v1.28.0) Updates `go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc` from 1.26.0 to 1.28.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.26.0...v1.28.0) Updates `go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp` from 1.26.0 to 1.28.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.26.0...v1.28.0) Updates `go.opentelemetry.io/otel/sdk` from 1.26.0 to 1.28.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.26.0...v1.28.0) Updates `go.opentelemetry.io/otel/trace` from 1.26.0 to 1.28.0 - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.26.0...v1.28.0) --- updated-dependencies: - dependency-name: go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel - dependency-name: go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel - dependency-name: go.opentelemetry.io/otel dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel - dependency-name: go.opentelemetry.io/otel/exporters/otlp/otlptrace dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel - dependency-name: go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel - dependency-name: go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel - dependency-name: go.opentelemetry.io/otel/sdk dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel - dependency-name: go.opentelemetry.io/otel/trace dependency-type: direct:production update-type: version-update:semver-minor dependency-group: otel ... Signed-off-by: dependabot[bot] <support@github.com>
101 lines
3.2 KiB
Go
101 lines
3.2 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
/*
|
|
Package attribute provide several helper functions for some commonly used
|
|
logic of processing attributes.
|
|
*/
|
|
package attribute // import "go.opentelemetry.io/otel/internal/attribute"
|
|
|
|
import (
|
|
"reflect"
|
|
)
|
|
|
|
// BoolSliceValue converts a bool slice into an array with same elements as slice.
|
|
func BoolSliceValue(v []bool) interface{} {
|
|
var zero bool
|
|
cp := reflect.New(reflect.ArrayOf(len(v), reflect.TypeOf(zero))).Elem()
|
|
reflect.Copy(cp, reflect.ValueOf(v))
|
|
return cp.Interface()
|
|
}
|
|
|
|
// Int64SliceValue converts an int64 slice into an array with same elements as slice.
|
|
func Int64SliceValue(v []int64) interface{} {
|
|
var zero int64
|
|
cp := reflect.New(reflect.ArrayOf(len(v), reflect.TypeOf(zero))).Elem()
|
|
reflect.Copy(cp, reflect.ValueOf(v))
|
|
return cp.Interface()
|
|
}
|
|
|
|
// Float64SliceValue converts a float64 slice into an array with same elements as slice.
|
|
func Float64SliceValue(v []float64) interface{} {
|
|
var zero float64
|
|
cp := reflect.New(reflect.ArrayOf(len(v), reflect.TypeOf(zero))).Elem()
|
|
reflect.Copy(cp, reflect.ValueOf(v))
|
|
return cp.Interface()
|
|
}
|
|
|
|
// StringSliceValue converts a string slice into an array with same elements as slice.
|
|
func StringSliceValue(v []string) interface{} {
|
|
var zero string
|
|
cp := reflect.New(reflect.ArrayOf(len(v), reflect.TypeOf(zero))).Elem()
|
|
reflect.Copy(cp, reflect.ValueOf(v))
|
|
return cp.Interface()
|
|
}
|
|
|
|
// AsBoolSlice converts a bool array into a slice into with same elements as array.
|
|
func AsBoolSlice(v interface{}) []bool {
|
|
rv := reflect.ValueOf(v)
|
|
if rv.Type().Kind() != reflect.Array {
|
|
return nil
|
|
}
|
|
var zero bool
|
|
correctLen := rv.Len()
|
|
correctType := reflect.ArrayOf(correctLen, reflect.TypeOf(zero))
|
|
cpy := reflect.New(correctType)
|
|
_ = reflect.Copy(cpy.Elem(), rv)
|
|
return cpy.Elem().Slice(0, correctLen).Interface().([]bool)
|
|
}
|
|
|
|
// AsInt64Slice converts an int64 array into a slice into with same elements as array.
|
|
func AsInt64Slice(v interface{}) []int64 {
|
|
rv := reflect.ValueOf(v)
|
|
if rv.Type().Kind() != reflect.Array {
|
|
return nil
|
|
}
|
|
var zero int64
|
|
correctLen := rv.Len()
|
|
correctType := reflect.ArrayOf(correctLen, reflect.TypeOf(zero))
|
|
cpy := reflect.New(correctType)
|
|
_ = reflect.Copy(cpy.Elem(), rv)
|
|
return cpy.Elem().Slice(0, correctLen).Interface().([]int64)
|
|
}
|
|
|
|
// AsFloat64Slice converts a float64 array into a slice into with same elements as array.
|
|
func AsFloat64Slice(v interface{}) []float64 {
|
|
rv := reflect.ValueOf(v)
|
|
if rv.Type().Kind() != reflect.Array {
|
|
return nil
|
|
}
|
|
var zero float64
|
|
correctLen := rv.Len()
|
|
correctType := reflect.ArrayOf(correctLen, reflect.TypeOf(zero))
|
|
cpy := reflect.New(correctType)
|
|
_ = reflect.Copy(cpy.Elem(), rv)
|
|
return cpy.Elem().Slice(0, correctLen).Interface().([]float64)
|
|
}
|
|
|
|
// AsStringSlice converts a string array into a slice into with same elements as array.
|
|
func AsStringSlice(v interface{}) []string {
|
|
rv := reflect.ValueOf(v)
|
|
if rv.Type().Kind() != reflect.Array {
|
|
return nil
|
|
}
|
|
var zero string
|
|
correctLen := rv.Len()
|
|
correctType := reflect.ArrayOf(correctLen, reflect.TypeOf(zero))
|
|
cpy := reflect.New(correctType)
|
|
_ = reflect.Copy(cpy.Elem(), rv)
|
|
return cpy.Elem().Slice(0, correctLen).Interface().([]string)
|
|
}
|