pkg/inst-api-semconv/instrumenter/rpc/rpc_attrs_extractor.go (53 lines of code) (raw):
// Copyright (c) 2024 Alibaba Group Holding Ltd.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package rpc
import (
"context"
"github.com/alibaba/opentelemetry-go-auto-instrumentation/pkg/inst-api/utils"
"go.opentelemetry.io/otel/attribute"
semconv "go.opentelemetry.io/otel/semconv/v1.30.0"
)
// TODO: remove server.address and put it into NetworkAttributesExtractor
type RpcAttrsExtractor[REQUEST any, RESPONSE any, GETTER RpcAttrsGetter[REQUEST]] struct {
Getter GETTER
}
func (r *RpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) OnStart(attributes []attribute.KeyValue, parentContext context.Context, request REQUEST) ([]attribute.KeyValue, context.Context) {
attributes = append(attributes, attribute.KeyValue{
Key: semconv.RPCSystemKey,
Value: attribute.StringValue(r.Getter.GetSystem(request)),
}, attribute.KeyValue{
Key: semconv.RPCServiceKey,
Value: attribute.StringValue(r.Getter.GetService(request)),
}, attribute.KeyValue{
Key: semconv.RPCMethodKey,
Value: attribute.StringValue(r.Getter.GetMethod(request)),
}, attribute.KeyValue{
Key: semconv.ServerAddressKey,
Value: attribute.StringValue(r.Getter.GetServerAddress(request)),
})
return attributes, parentContext
}
func (r *RpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) OnEnd(attributes []attribute.KeyValue, context context.Context, request REQUEST, response RESPONSE, err error) ([]attribute.KeyValue, context.Context) {
return attributes, context
}
type ServerRpcAttrsExtractor[REQUEST any, RESPONSE any, GETTER RpcAttrsGetter[REQUEST]] struct {
Base RpcAttrsExtractor[REQUEST, RESPONSE, GETTER]
}
func (s *ServerRpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) GetSpanKey() attribute.Key {
return utils.RPC_SERVER_KEY
}
func (s *ServerRpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) OnStart(attributes []attribute.KeyValue, parentContext context.Context, request REQUEST) ([]attribute.KeyValue, context.Context) {
return s.Base.OnStart(attributes, parentContext, request)
}
func (s *ServerRpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) OnEnd(attributes []attribute.KeyValue, context context.Context, request REQUEST, response RESPONSE, err error) ([]attribute.KeyValue, context.Context) {
return s.Base.OnEnd(attributes, context, request, response, err)
}
type ClientRpcAttrsExtractor[REQUEST any, RESPONSE any, GETTER RpcAttrsGetter[REQUEST]] struct {
Base RpcAttrsExtractor[REQUEST, RESPONSE, GETTER]
}
func (s *ClientRpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) GetSpanKey() attribute.Key {
return utils.RPC_CLIENT_KEY
}
func (s *ClientRpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) OnStart(attributes []attribute.KeyValue, parentContext context.Context, request REQUEST) ([]attribute.KeyValue, context.Context) {
return s.Base.OnStart(attributes, parentContext, request)
}
func (s *ClientRpcAttrsExtractor[REQUEST, RESPONSE, GETTER]) OnEnd(attributes []attribute.KeyValue, context context.Context, request REQUEST, response RESPONSE, err error) ([]attribute.KeyValue, context.Context) {
return s.Base.OnEnd(attributes, context, request, response, err)
}