io.jaegertracing.internal.baggage.BaggageSetter Maven / Gradle / Ivy
/*
* Copyright (c) 2017, Uber Technologies, Inc
*
* 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 io.jaegertracing.internal.baggage;
import io.jaegertracing.internal.JaegerSpan;
import io.jaegertracing.internal.JaegerSpanContext;
import io.jaegertracing.internal.metrics.Metrics;
import io.jaegertracing.spi.BaggageRestrictionManager;
import java.util.HashMap;
import java.util.Map;
/**
* BaggageSetter is a class that sets baggage and the logs associated
* with the baggage on a given {@link JaegerSpan}.
*/
public class BaggageSetter {
private final BaggageRestrictionManager restrictionManager;
private final Metrics metrics;
public BaggageSetter(BaggageRestrictionManager restrictionManager, Metrics metrics) {
this.restrictionManager = restrictionManager;
this.metrics = metrics;
}
/**
* Sets the baggage key:value on the {@link JaegerSpan} and the corresponding
* logs. Whether the baggage is set on the span depends on if the key
* is allowed to be set by this service.
*
* A {@link JaegerSpanContext} is returned with the new baggage key:value set
* if key is valid, else returns the existing {@link JaegerSpanContext}
* on the {@link JaegerSpan}.
*
* @param jaegerSpan the span to set the baggage on
* @param key the baggage key to set
* @param value the baggage value to set
* @return the JaegerSpanContext with the baggage set
*/
public JaegerSpanContext setBaggage(JaegerSpan jaegerSpan, String key, String value) {
Restriction restriction = restrictionManager.getRestriction(jaegerSpan.getServiceName(), key);
boolean truncated = false;
String prevItem = null;
if (!restriction.isKeyAllowed()) {
metrics.baggageUpdateFailure.inc(1);
logFields(jaegerSpan, key, value, prevItem, truncated, restriction.isKeyAllowed());
return jaegerSpan.context();
}
if (value != null && value.length() > restriction.getMaxValueLength()) {
truncated = true;
value = value.substring(0, restriction.getMaxValueLength());
metrics.baggageTruncate.inc(1);
}
prevItem = jaegerSpan.getBaggageItem(key);
logFields(jaegerSpan, key, value, prevItem, truncated, restriction.isKeyAllowed());
metrics.baggageUpdateSuccess.inc(1);
return jaegerSpan.context().withBaggageItem(key, value);
}
private void logFields(JaegerSpan jaegerSpan, String key, String value, String prevItem,
boolean truncated, boolean valid) {
if (!jaegerSpan.context().isSampled()) {
return;
}
Map fields = new HashMap();
fields.put("event", "baggage");
fields.put("key", key);
fields.put("value", value);
if (prevItem != null) {
fields.put("override", "true");
}
if (truncated) {
fields.put("truncated", "true");
}
if (!valid) {
fields.put("invalid", "true");
}
jaegerSpan.log(fields);
}
}