diff --git a/experimental/packages/opentelemetry-instrumentation-grpc/src/instrumentation.ts b/experimental/packages/opentelemetry-instrumentation-grpc/src/instrumentation.ts index 3daec0b63c5..9a1aa048021 100644 --- a/experimental/packages/opentelemetry-instrumentation-grpc/src/instrumentation.ts +++ b/experimental/packages/opentelemetry-instrumentation-grpc/src/instrumentation.ts @@ -41,8 +41,10 @@ import type { metadataCaptureType, } from './internal-types'; import type { GrpcInstrumentationConfig } from './types'; +import { SemconvStability } from './types'; import { + Attributes, context, propagation, ROOT_CONTEXT, @@ -51,11 +53,14 @@ import { trace, Span, } from '@opentelemetry/api'; +import { getEnv } from '@opentelemetry/core'; import { InstrumentationNodeModuleDefinition, InstrumentationBase, } from '@opentelemetry/instrumentation'; import { + ATTR_CLIENT_ADDRESS, + ATTR_CLIENT_PORT, SEMATTRS_NET_PEER_NAME, SEMATTRS_NET_PEER_PORT, SEMATTRS_RPC_METHOD, @@ -90,9 +95,21 @@ import { VERSION } from './version'; export class GrpcInstrumentation extends InstrumentationBase { private _metadataCapture: metadataCaptureType; + private _semconvStability = SemconvStability.OLD; + constructor(config: GrpcInstrumentationConfig = {}) { super('@opentelemetry/instrumentation-grpc', VERSION, config); this._metadataCapture = this._createMetadataCapture(); + + for (const entry in getEnv().OTEL_SEMCONV_STABILITY_OPT_IN) { + if (entry.toLowerCase() === 'http/dup') { + // http/dup takes highest precedence. If it is found, there is no need to read the rest of the list + this._semconvStability = SemconvStability.DUPLICATE; + break; + } else if (entry.toLowerCase() === 'http') { + this._semconvStability = SemconvStability.STABLE; + } + } } init() { @@ -326,7 +343,11 @@ export class GrpcInstrumentation extends InstrumentationBase