/*
* 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.socket;
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 javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.Map;
/**
* Zipkin context emitter for use with socket client transports (based on ZipkinHttpContextEmitter)
*/
public class ZipkinSocketContextEmitter<C> implements ContextEmitter<Map<String, String>, C> {
public ZipkinSocketContextEmitter(CompoundContextEmitter<Map<String, String>, C> compoundContextEmitter) {
compoundContextEmitter.addEmitter(this);
}
@Override
public void emit(ClientCallContext ctx, @Nonnull Map<String, String> additionalData, @Nullable C ignore) {
RequestUUID requestUUID = ctx.getRequestUUID();
if (requestUUID instanceof ZipkinRequestUUID) {
ZipkinRequestUUID zipkinRequestUUID = (ZipkinRequestUUID) requestUUID;
if (zipkinRequestUUID.isZipkinTracingEnabled()) {
ZipkinData zipkinData = zipkinRequestUUID.getZipkinData();
appendZipkinHeaders(additionalData, zipkinData);
} else {
// disabling sampling for the entire request chain
additionalData.put(ZipkinKeys.SAMPLED, ZipkinKeys.DO_NOT_SAMPLE_VALUE);
}
} // else ignore
}
private static void appendZipkinHeaders(@Nonnull Map<String, String> additionalData,
@Nonnull ZipkinData zipkinData) {
// enabling sampling for the entire request chain
additionalData.put(ZipkinKeys.SAMPLED, ZipkinKeys.DO_SAMPLE_VALUE);
additionalData.put(ZipkinKeys.TRACE_ID, Long.toHexString(zipkinData.getTraceId()));
additionalData.put(ZipkinKeys.SPAN_ID, Long.toHexString(zipkinData.getSpanId()));
if (zipkinData.getParentSpanId() != null) {
additionalData.put(ZipkinKeys.PARENT_SPAN_ID, Long.toHexString(zipkinData.getParentSpanId()));
}
if (zipkinData.getFlags() != null) {
additionalData.put(ZipkinKeys.FLAGS, zipkinData.getFlags().toString());
}
}
}