/**
* Copyright 2015-2016 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 zipkin.storage;
import java.util.List;
import java.util.concurrent.Executor;
import zipkin.DependencyLink;
import zipkin.Span;
import zipkin.internal.Nullable;
import zipkin.internal.Util;
import static zipkin.internal.Util.checkNotNull;
final class InternalBlockingToAsyncSpanStoreAdapter implements AsyncSpanStore {
final SpanStore delegate;
final Executor executor;
InternalBlockingToAsyncSpanStoreAdapter(SpanStore delegate, Executor executor) {
this.delegate = checkNotNull(delegate, "delegate");
this.executor = checkNotNull(executor, "executor");
}
@Override public void getTraces(final QueryRequest request, Callback<List<List<Span>>> callback) {
executor.execute(new InternalCallbackRunnable<List<List<Span>>>(callback) {
@Override List<List<Span>> complete() {
return delegate.getTraces(request);
}
@Override public String toString() {
return "GetTraces(" + request + ")";
}
});
}
@Override public void getTrace(final long id, Callback<List<Span>> callback) {
getTrace(0L, id, callback);
}
@Override public void getTrace(final long traceIdHigh, final long traceIdLow,
Callback<List<Span>> callback) {
executor.execute(new InternalCallbackRunnable<List<Span>>(callback) {
@Override List<Span> complete() {
return delegate.getTrace(traceIdHigh, traceIdLow);
}
@Override public String toString() {
return "getTrace(" + Util.toLowerHex(traceIdHigh, traceIdLow) + ")";
}
});
}
@Override public void getRawTrace(final long traceId, Callback<List<Span>> callback) {
getRawTrace(0L, traceId, callback);
}
@Override
public void getRawTrace(final long traceIdHigh, final long traceIdLow,
Callback<List<Span>> callback) {
executor.execute(new InternalCallbackRunnable<List<Span>>(callback) {
@Override List<Span> complete() {
return delegate.getRawTrace(traceIdHigh, traceIdLow);
}
@Override public String toString() {
return "getRawTrace(" + Util.toLowerHex(traceIdHigh, traceIdLow) + ")";
}
});
}
@Override public void getServiceNames(Callback<List<String>> callback) {
executor.execute(new InternalCallbackRunnable<List<String>>(callback) {
@Override List<String> complete() {
return delegate.getServiceNames();
}
@Override public String toString() {
return "getServiceNames()";
}
});
}
@Override public void getSpanNames(final String serviceName, Callback<List<String>> callback) {
executor.execute(new InternalCallbackRunnable<List<String>>(callback) {
@Override List<String> complete() {
return delegate.getSpanNames(serviceName);
}
@Override public String toString() {
return "getSpanNames(" + serviceName + ")";
}
});
}
@Override public void getDependencies(final long endTs, final @Nullable Long lookback,
Callback<List<DependencyLink>> callback) {
executor.execute(new InternalCallbackRunnable<List<DependencyLink>>(callback) {
@Override List<DependencyLink> complete() {
return delegate.getDependencies(endTs, lookback);
}
@Override public String toString() {
return "getDependencies(" + endTs + lookback == null ? ")" : ", " + lookback + ")";
}
});
}
@Override public String toString() {
return delegate.toString();
}
}