io.opentelemetry.exporter.internal.otlp.traces.SpanLinkStatelessMarshaler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of opentelemetry-exporter-otlp-common Show documentation
Show all versions of opentelemetry-exporter-otlp-common Show documentation
OpenTelemetry Protocol Exporter
/*
* Copyright The OpenTelemetry Authors
* SPDX-License-Identifier: Apache-2.0
*/
package io.opentelemetry.exporter.internal.otlp.traces;
import static io.opentelemetry.exporter.internal.otlp.traces.SpanLinkMarshaler.encodeSpanLinkTraceState;
import io.opentelemetry.exporter.internal.marshal.MarshalerContext;
import io.opentelemetry.exporter.internal.marshal.MarshalerUtil;
import io.opentelemetry.exporter.internal.marshal.Serializer;
import io.opentelemetry.exporter.internal.marshal.StatelessMarshaler;
import io.opentelemetry.exporter.internal.marshal.StatelessMarshalerUtil;
import io.opentelemetry.exporter.internal.otlp.AttributeKeyValueStatelessMarshaler;
import io.opentelemetry.proto.trace.v1.internal.Span;
import io.opentelemetry.sdk.trace.data.LinkData;
import java.io.IOException;
/** See {@link SpanLinkMarshaler}. */
final class SpanLinkStatelessMarshaler implements StatelessMarshaler {
static final SpanLinkStatelessMarshaler INSTANCE = new SpanLinkStatelessMarshaler();
private SpanLinkStatelessMarshaler() {}
@Override
public void writeTo(Serializer output, LinkData link, MarshalerContext context)
throws IOException {
output.serializeTraceId(Span.Link.TRACE_ID, link.getSpanContext().getTraceId(), context);
output.serializeSpanId(Span.Link.SPAN_ID, link.getSpanContext().getSpanId(), context);
output.serializeString(Span.Link.TRACE_STATE, context.getData(byte[].class));
output.serializeRepeatedMessageWithContext(
Span.Link.ATTRIBUTES,
link.getAttributes(),
AttributeKeyValueStatelessMarshaler.INSTANCE,
context);
int droppedAttributesCount = link.getTotalAttributeCount() - link.getAttributes().size();
output.serializeUInt32(Span.Link.DROPPED_ATTRIBUTES_COUNT, droppedAttributesCount);
output.serializeFixed32(
Span.Link.FLAGS,
SpanFlags.withParentIsRemoteFlags(
link.getSpanContext().getTraceFlags(), link.getSpanContext().isRemote()));
}
@Override
public int getBinarySerializedSize(LinkData link, MarshalerContext context) {
byte[] traceStateUtf8 = encodeSpanLinkTraceState(link);
context.addData(traceStateUtf8);
int size = 0;
size += MarshalerUtil.sizeTraceId(Span.Link.TRACE_ID, link.getSpanContext().getTraceId());
size += MarshalerUtil.sizeSpanId(Span.Link.SPAN_ID, link.getSpanContext().getSpanId());
size += MarshalerUtil.sizeBytes(Span.Link.TRACE_STATE, traceStateUtf8);
size +=
StatelessMarshalerUtil.sizeRepeatedMessageWithContext(
Span.Link.ATTRIBUTES,
link.getAttributes(),
AttributeKeyValueStatelessMarshaler.INSTANCE,
context);
int droppedAttributesCount = link.getTotalAttributeCount() - link.getAttributes().size();
size += MarshalerUtil.sizeUInt32(Span.Link.DROPPED_ATTRIBUTES_COUNT, droppedAttributesCount);
size +=
MarshalerUtil.sizeFixed32(
Span.Link.FLAGS,
SpanFlags.withParentIsRemoteFlags(
link.getSpanContext().getTraceFlags(), link.getSpanContext().isRemote()));
return size;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy