From d442a26f85324a1c2f8ef214fb57428a39a37aea Mon Sep 17 00:00:00 2001 From: Nikita Skrynnik <93182827+NikitaSkrynnik@users.noreply.github.com> Date: Sat, 28 Dec 2024 01:27:29 +1100 Subject: [PATCH] Remove deprecated opentelemetry interceptors (#1712) * remove deprecated opentelemtry interceprtors Signed-off-by: NikitaSkrynnik * remove some excluded rules from golang config Signed-off-by: NikitaSkrynnik --------- Signed-off-by: NikitaSkrynnik --- .golangci.yml | 5 ---- pkg/tools/tracing/grpcoptions.go | 48 ++++++-------------------------- 2 files changed, 8 insertions(+), 45 deletions(-) diff --git a/.golangci.yml b/.golangci.yml index 6816afee2..b4c064e1e 100644 --- a/.golangci.yml +++ b/.golangci.yml @@ -256,8 +256,3 @@ issues: - path: pkg/tools/opa/policies.go linters: - revive - # TODO - remove deprecated opentelemetry functions - https://github.com/networkservicemesh/sdk/issues/1691 - - path: pkg/tools/tracing/grpcoptions.go - linters: - - staticcheck - text: "SA1019: otelgrpc.*" diff --git a/pkg/tools/tracing/grpcoptions.go b/pkg/tools/tracing/grpcoptions.go index 01a6e5436..d933d9e67 100644 --- a/pkg/tools/tracing/grpcoptions.go +++ b/pkg/tools/tracing/grpcoptions.go @@ -2,6 +2,8 @@ // // Copyright (c) 2021-2022 Doc.ai and/or its affiliates. // +// Copyright (c) 2024 Cisco Systems, Inc. +// // SPDX-License-Identifier: Apache-2.0 // // Licensed under the Apache License, Version 2.0 (the "License"); @@ -20,60 +22,26 @@ package tracing import ( - "context" - "go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc" - "go.opentelemetry.io/otel" "google.golang.org/grpc" - "google.golang.org/protobuf/proto" "github.com/networkservicemesh/sdk/pkg/tools/opentelemetry" ) // WithTracing - returns array of grpc.ServerOption that should be passed to grpc.Dial to enable opentelemetry tracing func WithTracing() []grpc.ServerOption { + opts := []grpc.ServerOption{} if opentelemetry.IsEnabled() { - interceptor := func( - ctx context.Context, - req interface{}, - info *grpc.UnaryServerInfo, - handler grpc.UnaryHandler, - ) (resp interface{}, err error) { - return otelgrpc.UnaryServerInterceptor(otelgrpc.WithTracerProvider(otel.GetTracerProvider()))(ctx, proto.Clone(req.(proto.Message)), info, handler) - } - return []grpc.ServerOption{ - grpc.ChainUnaryInterceptor( - interceptor), - grpc.ChainStreamInterceptor( - otelgrpc.StreamServerInterceptor(otelgrpc.WithTracerProvider(otel.GetTracerProvider()))), - } - } - return []grpc.ServerOption{ - grpc.EmptyServerOption{}, + opts = append(opts, grpc.StatsHandler(otelgrpc.NewServerHandler())) } + return opts } // WithTracingDial returns array of grpc.DialOption that should be passed to grpc.Dial to enable opentelemetry tracing func WithTracingDial() []grpc.DialOption { + opts := []grpc.DialOption{} if opentelemetry.IsEnabled() { - interceptor := func( - ctx context.Context, - method string, - req, reply interface{}, - cc *grpc.ClientConn, - invoker grpc.UnaryInvoker, - opts ...grpc.CallOption, - ) error { - return otelgrpc.UnaryClientInterceptor(otelgrpc.WithTracerProvider(otel.GetTracerProvider()))(ctx, method, proto.Clone(req.(proto.Message)), reply, cc, invoker, opts...) - } - return []grpc.DialOption{ - grpc.WithChainUnaryInterceptor( - interceptor), - grpc.WithChainStreamInterceptor( - otelgrpc.StreamClientInterceptor(otelgrpc.WithTracerProvider(otel.GetTracerProvider()))), - } - } - return []grpc.DialOption{ - grpc.EmptyDialOption{}, + opts = append(opts, grpc.WithStatsHandler(otelgrpc.NewClientHandler())) } + return opts }