public class org.apache.drill.exec.store.druid.rest.DruidQueryClient extends java.lang.Object
{
private static final org.slf4j.Logger logger;
private static final java.lang.String QUERY_BASE_URI;
private static final com.fasterxml.jackson.databind.ObjectMapper mapper;
private final org.apache.drill.exec.store.druid.rest.RestClient restClient;
private final java.lang.String queryUrl;
public void <init>(java.lang.String, org.apache.drill.exec.store.druid.rest.RestClient)
{
org.apache.drill.exec.store.druid.rest.DruidQueryClient v;
org.slf4j.Logger v;
org.apache.drill.exec.store.druid.rest.RestClient v;
java.lang.String v, v, v;
v := @this: org.apache.drill.exec.store.druid.rest.DruidQueryClient;
v := @parameter: java.lang.String;
v := @parameter: org.apache.drill.exec.store.druid.rest.RestClient;
specialinvoke v.<java.lang.Object: void <init>()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001/druid/v2");
v.<org.apache.drill.exec.store.druid.rest.DruidQueryClient: java.lang.String queryUrl> = v;
v.<org.apache.drill.exec.store.druid.rest.DruidQueryClient: org.apache.drill.exec.store.druid.rest.RestClient restClient> = v;
v = <org.apache.drill.exec.store.druid.rest.DruidQueryClient: org.slf4j.Logger logger>;
v = v.<org.apache.drill.exec.store.druid.rest.DruidQueryClient: java.lang.String queryUrl>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Initialized DruidQueryClient with druidURL - {}", v);
return;
}
public org.apache.drill.exec.store.druid.druid.DruidScanResponse executeQuery(java.lang.String) throws java.lang.Exception
{
java.lang.Throwable v;
java.lang.Object[] v;
org.apache.drill.common.exceptions.UserException$Builder v, v, v, v;
org.apache.drill.common.exceptions.UserException v;
org.apache.drill.exec.store.druid.druid.DruidScanResponse v;
org.apache.drill.exec.store.druid.rest.RestClient v;
int v;
okhttp.Response v;
java.lang.String v, v, v;
okhttp.ResponseBody v;
boolean v;
org.apache.drill.exec.store.druid.rest.DruidQueryClient v;
org.slf4j.Logger v, v;
com.fasterxml.jackson.databind.ObjectMapper v;
java.lang.Object v;
java.io.InputStream v;
v := @this: org.apache.drill.exec.store.druid.rest.DruidQueryClient;
v := @parameter: java.lang.String;
v = <org.apache.drill.exec.store.druid.rest.DruidQueryClient: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Executing Query - {}", v);
v = v.<org.apache.drill.exec.store.druid.rest.DruidQueryClient: org.apache.drill.exec.store.druid.rest.RestClient restClient>;
v = v.<org.apache.drill.exec.store.druid.rest.DruidQueryClient: java.lang.String queryUrl>;
v = interfaceinvoke v.<org.apache.drill.exec.store.druid.rest.RestClient: okhttp.Response post(java.lang.String,java.lang.String)>(v, v);
label:
v = virtualinvoke v.<okhttp.Response: boolean isSuccessful()>();
if v != 0 goto label;
v = staticinvoke <org.apache.drill.common.exceptions.UserException: org.apache.drill.common.exceptions.UserException$Builder dataReadError()>();
v = newarray (java.lang.Object)[0];
v = virtualinvoke v.<org.apache.drill.common.exceptions.UserException$Builder: org.apache.drill.common.exceptions.UserException$Builder message(java.lang.String,java.lang.Object[])>("Error executing druid query. HTTP request failed", v);
v = virtualinvoke v.<okhttp.Response: int code()>();
v = virtualinvoke v.<org.apache.drill.common.exceptions.UserException$Builder: org.apache.drill.common.exceptions.UserException$Builder addContext(java.lang.String,long)>("Response code", v);
v = virtualinvoke v.<okhttp.Response: java.lang.String message()>();
v = virtualinvoke v.<org.apache.drill.common.exceptions.UserException$Builder: org.apache.drill.common.exceptions.UserException$Builder addContext(java.lang.String,java.lang.String)>("Response message", v);
v = <org.apache.drill.exec.store.druid.rest.DruidQueryClient: org.slf4j.Logger logger>;
v = virtualinvoke v.<org.apache.drill.common.exceptions.UserException$Builder: org.apache.drill.common.exceptions.UserException build(org.slf4j.Logger)>(v);
throw v;
label:
v = virtualinvoke v.<okhttp.Response: okhttp.ResponseBody body()>();
v = virtualinvoke v.<okhttp.ResponseBody: java.io.InputStream byteStream()>();
v = <org.apache.drill.exec.store.druid.rest.DruidQueryClient: com.fasterxml.jackson.databind.ObjectMapper mapper>;
v = virtualinvoke v.<com.fasterxml.jackson.databind.ObjectMapper: java.lang.Object readValue(java.io.InputStream,java.lang.Class)>(v, class "Lcom/fasterxml/jackson/databind/node/ArrayNode;");
v = specialinvoke v.<org.apache.drill.exec.store.druid.rest.DruidQueryClient: org.apache.drill.exec.store.druid.druid.DruidScanResponse parseResponse(com.fasterxml.jackson.databind.node.ArrayNode)>(v);
label:
virtualinvoke v.<okhttp.Response: void close()>();
return v;
label:
v := @caughtexception;
throw v;
catch java.lang.Throwable from label to label with label;
}
private org.apache.drill.exec.store.druid.druid.DruidScanResponse parseResponse(com.fasterxml.jackson.databind.node.ArrayNode)
{
org.apache.drill.exec.store.druid.druid.DruidScanResponse v;
java.util.ArrayList v, v;
int v, v, v, v, v;
com.fasterxml.jackson.databind.JsonNode v, v, v, v, v, v;
java.lang.String v, v;
org.apache.drill.exec.store.druid.rest.DruidQueryClient v;
com.fasterxml.jackson.databind.node.ArrayNode v;
v := @this: org.apache.drill.exec.store.druid.rest.DruidQueryClient;
v := @parameter: com.fasterxml.jackson.databind.node.ArrayNode;
v = "empty";
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ArrayNode: int size()>();
if v <= 0 goto label;
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ArrayNode: com.fasterxml.jackson.databind.JsonNode get(int)>(0);
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ObjectNode: com.fasterxml.jackson.databind.JsonNode get(java.lang.String)>("segmentId");
v = virtualinvoke v.<com.fasterxml.jackson.databind.JsonNode: java.lang.String textValue()>();
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ObjectNode: com.fasterxml.jackson.databind.JsonNode get(java.lang.String)>("columns");
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ObjectNode: com.fasterxml.jackson.databind.JsonNode get(java.lang.String)>("events");
v = 0;
label:
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ArrayNode: int size()>();
if v >= v goto label;
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ArrayNode: com.fasterxml.jackson.databind.JsonNode get(int)>(v);
v = virtualinvoke v.<com.fasterxml.jackson.databind.JsonNode: java.lang.String textValue()>();
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = 0;
label:
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ArrayNode: int size()>();
if v >= v goto label;
v = virtualinvoke v.<com.fasterxml.jackson.databind.node.ArrayNode: com.fasterxml.jackson.databind.JsonNode get(int)>(v);
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = new org.apache.drill.exec.store.druid.druid.DruidScanResponse;
specialinvoke v.<org.apache.drill.exec.store.druid.druid.DruidScanResponse: void <init>(java.lang.String,java.util.ArrayList,java.util.ArrayList)>(v, v, v);
return v;
}
static void <clinit>()
{
com.fasterxml.jackson.databind.ObjectMapper v;
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/drill/exec/store/druid/rest/DruidQueryClient;");
<org.apache.drill.exec.store.druid.rest.DruidQueryClient: org.slf4j.Logger logger> = v;
v = new com.fasterxml.jackson.databind.ObjectMapper;
specialinvoke v.<com.fasterxml.jackson.databind.ObjectMapper: void <init>()>();
<org.apache.drill.exec.store.druid.rest.DruidQueryClient: com.fasterxml.jackson.databind.ObjectMapper mapper> = v;
return;
}
}