package com.datastax.oss.driver.internal.core.cql;
import com.datastax.oss.driver.api.core.cql.QueryTrace;
import com.datastax.oss.driver.api.core.cql.TraceEvent;
import edu.umd.cs.findbugs.annotations.NonNull;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import net.jcip.annotations.Immutable;
@Immutable
public class DefaultQueryTrace implements QueryTrace {
private final UUID tracingId;
private final String requestType;
private final int durationMicros;
private final InetSocketAddress coordinator;
private final Map<String, String> parameters;
private final long startedAt;
private final List<TraceEvent> events;
public DefaultQueryTrace(
UUID tracingId,
String requestType,
int durationMicros,
InetSocketAddress coordinator,
Map<String, String> parameters,
long startedAt,
List<TraceEvent> events) {
this.tracingId = tracingId;
this.requestType = requestType;
this.durationMicros = durationMicros;
this.coordinator = coordinator;
this.parameters = parameters;
this.startedAt = startedAt;
this.events = events;
}
@NonNull
@Override
public UUID getTracingId() {
return tracingId;
}
@NonNull
@Override
public String getRequestType() {
return requestType;
}
@Override
public int getDurationMicros() {
return durationMicros;
}
@NonNull
@Override
@Deprecated
public InetAddress getCoordinator() {
return coordinator.getAddress();
}
@NonNull
@Override
public InetSocketAddress getCoordinatorAddress() {
return coordinator;
}
@NonNull
@Override
public Map<String, String> getParameters() {
return parameters;
}
@Override
public long getStartedAt() {
return startedAt;
}
@NonNull
@Override
public List<TraceEvent> getEvents() {
return events;
}
@Override
public String toString() {
return String.format("%s [%s] - %dµs", requestType, tracingId, durationMicros);
}
}