/*
* Copyright 2015, The Sporting Exchange Limited
*
* 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 com.betfair.cougar.modules.zipkin.impl.http;
import com.betfair.cougar.api.RequestUUID;
import com.betfair.cougar.client.ClientCallContext;
import com.betfair.cougar.client.api.CompoundContextEmitter;
import com.betfair.cougar.client.api.ContextEmitter;
import com.betfair.cougar.modules.zipkin.api.ZipkinData;
import com.betfair.cougar.modules.zipkin.api.ZipkinKeys;
import com.betfair.cougar.modules.zipkin.api.ZipkinRequestUUID;
import org.apache.http.Header;
import org.apache.http.message.BasicHeader;
import java.util.List;
import javax.annotation.Nonnull;
/**
* Zipkin context emitter for use with http client transports.
*
* @see ContextEmitter
*/
public class ZipkinHttpContextEmitter<HR> implements ContextEmitter<HR, List<Header>> {
public ZipkinHttpContextEmitter(CompoundContextEmitter<HR, List<Header>> compoundContextEmitter) {
compoundContextEmitter.addEmitter(this);
}
@Override
public void emit(ClientCallContext ctx, HR request, List<Header> result) {
RequestUUID requestUUID = ctx.getRequestUUID();
if (requestUUID instanceof ZipkinRequestUUID) {
ZipkinRequestUUID zipkinRequestUUID = (ZipkinRequestUUID) requestUUID;
if (zipkinRequestUUID.isZipkinTracingEnabled()) {
ZipkinData zipkinData = zipkinRequestUUID.getZipkinData();
appendZipkinHeaders(result, zipkinData);
} else {
// disabling sampling for the entire request chain
appendHeader(result, ZipkinKeys.SAMPLED, ZipkinKeys.DO_NOT_SAMPLE_VALUE);
}
} // else ignore
}
private static void appendZipkinHeaders(@Nonnull List<Header> result, @Nonnull ZipkinData zipkinData) {
// enabling sampling for the entire request chain
appendHeader(result, ZipkinKeys.SAMPLED, ZipkinKeys.DO_SAMPLE_VALUE);
appendHeader(result, ZipkinKeys.TRACE_ID, Long.toHexString(zipkinData.getTraceId()));
appendHeader(result, ZipkinKeys.SPAN_ID, Long.toHexString(zipkinData.getSpanId()));
if (zipkinData.getParentSpanId() != null) {
appendHeader(result, ZipkinKeys.PARENT_SPAN_ID, Long.toHexString(zipkinData.getParentSpanId()));
}
if (zipkinData.getFlags() != null) {
appendHeader(result, ZipkinKeys.FLAGS, zipkinData.getFlags().toString());
}
}
private static void appendHeader(@Nonnull List<Header> result, String key, String value) {
result.add(new BasicHeader(key, value));
}
}