diff --git a/CHANGELOG.md b/CHANGELOG.md index de8fc11a381..1769353155c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -37,6 +37,9 @@ release. - Clarify that attribute keys are case-sensitive. ([#3784](https://github.com/open-telemetry/opentelemetry-specification/pull/3784)) +- Support maps and heterogeneous arrays as attribute values + ([#2888](https://github.com/open-telemetry/opentelemetry-specification/pull/2888)) + ### Supplementary Guidelines ## v1.28.0 (2023-12-07) diff --git a/spec-compliance-matrix.md b/spec-compliance-matrix.md index abe1b80d33a..3f0f80d8187 100644 --- a/spec-compliance-matrix.md +++ b/spec-compliance-matrix.md @@ -65,6 +65,7 @@ formats is required. Implementing more than one format is optional. | Array of primitives (homogeneous) | | + | + | + | + | + | + | + | + | + | + | + | | `null` values documented as invalid/undefined | | + | + | + | + | + | N/A | + | | + | | N/A | | Unicode support for keys and string values | | + | + | + | + | + | + | + | + | + | + | + | +| Non-homogeneous arrays and maps (including nested) for attribute values | | | | | | | | | | | | | | [Span linking](specification/trace/api.md#specifying-links) | Optional | Go | Java | JS | Python | Ruby | Erlang | PHP | Rust | C++ | .NET | Swift | | Links can be recorded on span creation | | + | + | | + | + | + | + | + | + | + | | | Links can be recorded after span creation | | | | | | | | | | + | | | @@ -236,12 +237,14 @@ Disclaimer: this list of features is still a work in progress, please refer to t | OTLP File exporter | | | - | | - | | | | | | - | | | Can plug custom LogRecordExporter | | | + | | | | | + | | + | | | | Trace Context Injection | | | + | | + | | | + | | + | + | | +| Non-homogeneous arrays and maps (including nested) for attribute values| | | | | | | | | | | | | ## Resource | Feature | Optional | Go | Java | JS | Python | Ruby | Erlang | PHP | Rust | C++ | .NET | Swift | |---------------------------------------------------------------------------------------------------------------------------------------------|----------|----|------|----|--------|------|--------|-----|------|-----|------|-------| | Create from Attributes | | + | + | + | + | + | + | + | + | + | + | + | +| Non-homogeneous arrays and maps (including nested) for attribute values | | | | | | | | | | | | | | Create empty | | + | + | + | + | + | + | + | + | + | + | + | | [Merge (v2)](specification/resource/sdk.md#merge) | | + | + | | + | + | + | + | + | + | + | | | Retrieve attributes | | + | + | + | + | + | + | + | + | + | + | + | diff --git a/specification/common/README.md b/specification/common/README.md index 4b9adc77b2d..b7ec9d566e7 100644 --- a/specification/common/README.md +++ b/specification/common/README.md @@ -29,16 +29,31 @@ An `Attribute` is a key-value pair, which MUST have the following properties: - The attribute key MUST be a non-`null` and non-empty string. - Case sensitivity of keys is preserved. Keys that differ in casing are treated as distinct keys. -- The attribute value is either: +- The attribute value can be of `any` type, where any is defined as one of the following: - A primitive type: string, boolean, double precision floating point (IEEE 754-1985) or signed 64 bit integer. - - An array of primitive type values. The array MUST be homogeneous, - i.e., it MUST NOT contain values of different types. + - An array of values of primitive type [before 1.29.0]. + - An array of `any` values [since 1.29.0]. + - A key/value map, where key is string and value is `any` value. Any form of reference + cycle is disallowed. [since 1.29.0]. -For protocols that do not natively support non-string values, non-string values SHOULD be represented as JSON-encoded strings. For example, the expression `int64(100)` will be encoded as `100`, `float64(1.5)` will be encoded as `1.5`, and an empty array of any type will be encoded as `[]`. +Complex attribute types (such as arrays and maps) SHOULD be used sparingly. They may +be useful for example in situations where their use minimizes manipulation +of the data’s original structure. -Attribute values expressing a numerical value of zero, an empty string, or an -empty array are considered meaningful and MUST be stored and passed on to -processors / exporters. +The following value types MUST NOT be used as metric attribute values: + +- Non-homogeneous arrays (arrays containing values of different types). +- Nested arrays. +- Key/value maps. + +When exporting to protocols that do not natively support a particular non-string +value type the value should be converted to a string JSON-encoding of the value. +For example, the expression `int64(100)` will be encoded as `100`, `float64(1.5)` will +be encoded as `1.5`, and an empty array of any type will be encoded as `[]`. + +Attribute values expressing a numerical value of zero, an empty string, an +empty array or empty key/value map are considered meaningful and MUST be stored and +passed on to processors / exporters. Attribute values of `null` are not valid and attempting to set a `null` value is undefined behavior. diff --git a/specification/trace/sdk_exporters/jaeger.md b/specification/trace/sdk_exporters/jaeger.md index 32d11f0ede1..6967e10d65a 100644 --- a/specification/trace/sdk_exporters/jaeger.md +++ b/specification/trace/sdk_exporters/jaeger.md @@ -138,8 +138,8 @@ OpenTelemetry Span `Attribute`(s) MUST be reported as `tags` to Jaeger. Primitive types MUST be represented by the corresponding types of Jaeger tags. -Array values MUST be serialized to string like a JSON list as mentioned in -[semantic conventions](../../overview.md#semantic-conventions). +Array and map values MUST be serialized to a JSON and recorded as a tag of string type +as mentioned in [attribute value definition](../../common/README.md#attribute). ### Links diff --git a/specification/trace/sdk_exporters/zipkin.md b/specification/trace/sdk_exporters/zipkin.md index 9a902619cc5..57a96e5f166 100644 --- a/specification/trace/sdk_exporters/zipkin.md +++ b/specification/trace/sdk_exporters/zipkin.md @@ -131,8 +131,8 @@ document maps to the strongly-typed fields of Zipkin spans. Primitive types MUST be converted to string using en-US culture settings. Boolean values MUST use lower case strings `"true"` and `"false"`. -Array values MUST be serialized to string like a JSON list as mentioned in -[semantic conventions](../../overview.md#semantic-conventions). +Array and map values MUST be serialized to a JSON and recorded as a tag of string type +as mentioned in [attribute value definition](../../common/README.md#attribute). TBD: add examples