All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.opentelemetry.exporter.internal.otlp.traces.SpanLinkStatelessMarshaler Maven / Gradle / Ivy

There is a newer version: 1.45.0
Show newest version
/*
 * 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