
com.github.segmentio.request.BlockingRequester Maven / Gradle / Ivy
package com.github.segmentio.request;
import java.io.*;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.config.CookieSpecs;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.ByteArrayEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.joda.time.DateTime;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.github.segmentio.AnalyticsClient;
import com.github.segmentio.Constants;
import com.github.segmentio.models.*;
import com.github.segmentio.stats.AnalyticsStatistics;
import com.github.segmentio.utils.GSONUtils;
import com.google.gson.Gson;
public class BlockingRequester implements IRequester {
private static final Logger logger = LoggerFactory
.getLogger(Constants.LOGGER);
protected AnalyticsClient client;
private Gson gson;
private CloseableHttpClient httpClient;
private RequestConfig defaultRequestConfig;
public BlockingRequester(AnalyticsClient client) {
this.client = client;
httpClient = HttpClients.createDefault();
int requestTimeout = client.getOptions().getTimeout();
defaultRequestConfig =
RequestConfig.custom()
.setCookieSpec(CookieSpecs.BEST_MATCH)
.setExpectContinueEnabled(true)
.setStaleConnectionCheckEnabled(true)
.setSocketTimeout(requestTimeout)
.setConnectTimeout(requestTimeout)
.setConnectionRequestTimeout(requestTimeout).build();
this.gson = GSONUtils.BUILDER.create();
}
public boolean send(Batch batch) {
AnalyticsStatistics statistics = client.getStatistics();
try {
long start = System.currentTimeMillis();
batch.setRequestTimestamp(DateTime.now());
String json = gson.toJson(batch);
HttpResponse response = executeRequest(json);
String responseBody = readResponseBody(response);
int statusCode = response.getStatusLine().getStatusCode();
long duration = System.currentTimeMillis() - start;
statistics.updateRequestTime(duration);
if (statusCode == 200) {
String message = "Successful analytics request. [code = "
+ statusCode + "]. Response = " + responseBody;
logger.info(message);
report(statistics, batch, true, message);
return true;
} else {
String message = "Failed analytics response [code = " + statusCode +
"]. Response = " + responseBody;
logger.error(message);
report(statistics, batch, false, message);
}
} catch (IOException e) {
String message = "Failed analytics response." + e.getMessage();
logger.error(message, e);
report(statistics, batch, false, message);
}
return false;
}
public String readResponseBody(HttpResponse response) throws IOException {
BufferedReader rd
= new BufferedReader(
new InputStreamReader(
response.getEntity().getContent()));
StringBuilder responseBuilder = new StringBuilder();
String line;
while ((line = rd.readLine()) != null) {
responseBuilder.append(line);
}
String responseBody = responseBuilder.toString();
return responseBody;
}
public HttpResponse executeRequest(String json) throws ClientProtocolException, IOException {
HttpPost post =
new HttpPost(client.getOptions().getHost() + "/v1/import");
post.setConfig(defaultRequestConfig);
post.addHeader("Content-Type", "application/json; charset=utf-8");
post.setEntity(new ByteArrayEntity(json.getBytes("UTF-8")));
if (logger.isTraceEnabled()) {
logger.trace("Posting analytics data");
}
return httpClient.execute(post);
}
private void report(AnalyticsStatistics statistics, Batch batch, boolean success, String message) {
for (BasePayload payload : batch.getBatch()) {
Callback callback = payload.getCallback();
if (success) {
statistics.updateSuccessful(1);
} else {
statistics.updateFailed(1);
}
if (callback != null) {
callback.onResponse(success, message);
}
}
}
public void close() {
try {
httpClient.close();
} catch (IOException e) {
logger.error("Error while closing", e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy