in pkg/inst-api-semconv/instrumenter/db/db_client_extractor.go [88:123]
func (d *DbClientAttrsExtractor[REQUEST, RESPONSE, GETTER]) OnEnd(attrs []attribute.KeyValue, context context.Context, request REQUEST, response RESPONSE, err error) ([]attribute.KeyValue, context.Context) {
attrs, context = d.Base.OnEnd(attrs, context, request, response, err)
attrs = append(attrs, attribute.KeyValue{
Key: semconv.DBQueryTextKey,
Value: attribute.StringValue(d.Base.Getter.GetStatement(request)),
}, attribute.KeyValue{
Key: semconv.DBOperationNameKey,
Value: attribute.StringValue(d.Base.Getter.GetOperation(request)),
}, attribute.KeyValue{
Key: semconv.ServerAddressKey,
Value: attribute.StringValue(d.Base.Getter.GetServerAddress(request)),
}, attribute.KeyValue{
Key: semconv.DBCollectionNameKey,
Value: attribute.StringValue(d.Base.Getter.GetCollection(request)),
})
batchSize := d.Base.Getter.GetBatchSize(request)
if batchSize > 0 {
attrs = append(attrs, attribute.KeyValue{Key: semconv.DBOperationBatchSizeKey, Value: attribute.IntValue(batchSize)})
}
dbNameSpace := d.Base.Getter.GetDbNamespace(request)
if dbNameSpace != "" {
attrs = append(attrs, attribute.KeyValue{Key: semconv.DBNamespaceKey, Value: attribute.StringValue(dbNameSpace)})
}
if d.Base.AttributesFilter != nil {
attrs = d.Base.AttributesFilter(attrs)
}
if experimentalAttributesEnabler.Enable() {
params := d.Base.Getter.GetParameters(request)
if len(params) > 0 {
for i, param := range params {
attrs = append(attrs, attribute.String("db.query.parameter."+strconv.Itoa(i), fmt.Sprintf("%v", param)))
}
}
}
return attrs, context
}