io.opentelemetry.exporter.internal.otlp.traces.SpanLinkMarshaler Maven / Gradle / Ivy
/*
* 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.SpanMarshaler.encodeTraceState;
import io.opentelemetry.api.trace.TraceFlags;
import io.opentelemetry.api.trace.TraceState;
import io.opentelemetry.exporter.internal.marshal.MarshalerUtil;
import io.opentelemetry.exporter.internal.marshal.MarshalerWithSize;
import io.opentelemetry.exporter.internal.marshal.Serializer;
import io.opentelemetry.exporter.internal.otlp.KeyValueMarshaler;
import io.opentelemetry.proto.trace.v1.internal.Span;
import io.opentelemetry.sdk.trace.data.LinkData;
import java.io.IOException;
import java.util.List;
final class SpanLinkMarshaler extends MarshalerWithSize {
private static final SpanLinkMarshaler[] EMPTY = new SpanLinkMarshaler[0];
private final String traceId;
private final String spanId;
private final byte[] traceStateUtf8;
private final KeyValueMarshaler[] attributeMarshalers;
private final int droppedAttributesCount;
private final TraceFlags traceFlags;
private final boolean isLinkContextRemote;
static SpanLinkMarshaler[] createRepeated(List links) {
if (links.isEmpty()) {
return EMPTY;
}
SpanLinkMarshaler[] result = new SpanLinkMarshaler[links.size()];
int pos = 0;
for (LinkData link : links) {
result[pos++] = create(link);
}
return result;
}
// Visible for testing
static SpanLinkMarshaler create(LinkData link) {
byte[] traceStateUtf8 = encodeSpanLinkTraceState(link);
return new SpanLinkMarshaler(
link.getSpanContext().getTraceId(),
link.getSpanContext().getSpanId(),
link.getSpanContext().getTraceFlags(),
traceStateUtf8,
KeyValueMarshaler.createForAttributes(link.getAttributes()),
link.getTotalAttributeCount() - link.getAttributes().size(),
link.getSpanContext().isRemote());
}
private SpanLinkMarshaler(
String traceId,
String spanId,
TraceFlags traceFlags,
byte[] traceStateUtf8,
KeyValueMarshaler[] attributeMarshalers,
int droppedAttributesCount,
boolean isLinkContextRemote) {
super(
calculateSize(
traceId,
spanId,
traceFlags,
traceStateUtf8,
attributeMarshalers,
droppedAttributesCount,
isLinkContextRemote));
this.traceId = traceId;
this.spanId = spanId;
this.traceFlags = traceFlags;
this.traceStateUtf8 = traceStateUtf8;
this.attributeMarshalers = attributeMarshalers;
this.droppedAttributesCount = droppedAttributesCount;
this.isLinkContextRemote = isLinkContextRemote;
}
@Override
public void writeTo(Serializer output) throws IOException {
output.serializeTraceId(Span.Link.TRACE_ID, traceId);
output.serializeSpanId(Span.Link.SPAN_ID, spanId);
output.serializeString(Span.Link.TRACE_STATE, traceStateUtf8);
output.serializeRepeatedMessage(Span.Link.ATTRIBUTES, attributeMarshalers);
output.serializeUInt32(Span.Link.DROPPED_ATTRIBUTES_COUNT, droppedAttributesCount);
output.serializeFixed32(
Span.Link.FLAGS, SpanFlags.withParentIsRemoteFlags(traceFlags, isLinkContextRemote));
}
private static int calculateSize(
String traceId,
String spanId,
TraceFlags flags,
byte[] traceStateUtf8,
KeyValueMarshaler[] attributeMarshalers,
int droppedAttributesCount,
boolean isLinkContextRemote) {
int size = 0;
size += MarshalerUtil.sizeTraceId(Span.Link.TRACE_ID, traceId);
size += MarshalerUtil.sizeSpanId(Span.Link.SPAN_ID, spanId);
size += MarshalerUtil.sizeBytes(Span.Link.TRACE_STATE, traceStateUtf8);
size += MarshalerUtil.sizeRepeatedMessage(Span.Link.ATTRIBUTES, attributeMarshalers);
size += MarshalerUtil.sizeUInt32(Span.Link.DROPPED_ATTRIBUTES_COUNT, droppedAttributesCount);
size +=
MarshalerUtil.sizeFixed32(
Span.Link.FLAGS, SpanFlags.withParentIsRemoteFlags(flags, isLinkContextRemote));
return size;
}
static byte[] encodeSpanLinkTraceState(LinkData link) {
TraceState traceState = link.getSpanContext().getTraceState();
return encodeTraceState(traceState);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy