zipkin2.server.internal.brave.TracedCall Maven / Gradle / Ivy
/*
* Copyright 2015-2019 The OpenZipkin Authors
*
* 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 zipkin2.server.internal.brave;
import brave.ScopedSpan;
import brave.Span;
import brave.Tracer;
import java.io.IOException;
import zipkin2.Call;
import zipkin2.Callback;
public final class TracedCall extends Call {
final Tracer tracer;
final Call delegate;
final String name;
public TracedCall(Tracer tracer, Call delegate, String name) {
this.tracer = tracer;
this.delegate = delegate;
this.name = name;
}
@Override public V execute() throws IOException {
ScopedSpan span = tracer.startScopedSpan(name);
try {
return delegate.execute();
} catch (RuntimeException | IOException | Error e) {
span.error(e);
throw e;
} finally {
span.finish();
}
}
@Override public void enqueue(Callback callback) {
Span span = tracer.nextSpan().name(name).start();
try {
if (span.isNoop()) {
delegate.enqueue(callback);
} else {
delegate.enqueue(new SpanFinishingCallback<>(callback, span));
}
} catch (RuntimeException | Error e) {
span.error(e);
span.finish();
throw e;
}
}
@Override public void cancel() {
delegate.cancel();
}
@Override public boolean isCanceled() {
return delegate.isCanceled();
}
@Override public Call clone() {
return new TracedCall<>(tracer, delegate, name);
}
@Override public String toString() {
return "Traced(" + delegate + ")";
}
static final class SpanFinishingCallback implements Callback {
private final Callback delegate;
private final Span span;
SpanFinishingCallback(Callback delegate, Span span) {
this.delegate = delegate;
this.span = span;
}
@Override public void onSuccess(V value) {
delegate.onSuccess(value);
span.finish();
}
@Override public void onError(Throwable t) {
delegate.onError(t);
span.error(t).finish();
}
@Override public String toString() {
return "Traced(" + delegate + ")";
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy