com.urbanairship.api.client.AsyncRequestClient Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java-client Show documentation
Show all versions of java-client Show documentation
The Urban Airship Java client library
package com.urbanairship.api.client;
import com.google.common.base.Preconditions;
import org.apache.http.entity.ContentType;
import org.asynchttpclient.AsyncHttpClient;
import org.asynchttpclient.BoundRequestBuilder;
import org.asynchttpclient.DefaultAsyncHttpClient;
import org.asynchttpclient.DefaultAsyncHttpClientConfig;
import org.asynchttpclient.filter.FilterContext;
import org.asynchttpclient.proxy.ProxyServer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.Future;
import java.util.function.Predicate;
import static com.urbanairship.api.client.UrbanAirshipClient.US_URI;
/**
* The AsyncRequestClient is the default request client used by the UrbanAirshipClient.
*/
public class AsyncRequestClient implements RequestClient {
private static final Logger log = LoggerFactory.getLogger(UrbanAirshipClient.class);
private final Optional proxyServer;
private final URI baseUri;
private final AsyncHttpClient client;
private final DefaultAsyncHttpClientConfig clientConfig;
private AsyncRequestClient(Builder builder) {
this.baseUri = URI.create(builder.baseUri);
DefaultAsyncHttpClientConfig.Builder clientConfigBuilder = builder.clientConfigBuilder;
clientConfigBuilder.addResponseFilter(new RequestRetryFilter(builder.maxRetries, Optional.ofNullable(builder.retryPredicate)));
if (Optional.ofNullable(builder.proxyServer).isPresent()) {
proxyServer = Optional.ofNullable(builder.proxyServer);
clientConfigBuilder.setProxyServer(proxyServer.get());
clientConfigBuilder.setRealm(proxyServer.get().getRealm());
} else {
proxyServer = Optional.empty();
}
this.clientConfig = clientConfigBuilder.build();
this.client = new DefaultAsyncHttpClient(clientConfig);
}
/**
* New AsyncRequestClient Builder.
*
* @return AsyncRequestClient Builder.
*/
public static Builder newBuilder() {
return new Builder();
}
/**
* Get the base URI used for the client.
*
* @return URI
*/
public URI getBaseUri() {
return baseUri;
}
/**
* Get the proxy server.
*
* @return Optional ProxyServer
*/
public Optional getProxyServer() {
return proxyServer;
}
/**
* Get the client config.
*
* @return DefaultAsyncHttpClientConfig
*/
public DefaultAsyncHttpClientConfig getClientConfig() {
return clientConfig;
}
@Override
/**
* Command for executing Urban Airship requests asynchronously with a ResponseCallback.
*
* @param request An Urban Airship request object.
* @param callback A ResponseCallback instance.
* @return A client response future.
*/
public Future executeAsync(final Request request, final ResponseCallback callback, Map headers) {
BoundRequestBuilder requestBuilder;
String uri;
try {
uri = request.getUri(baseUri).toString();
} catch (URISyntaxException e) {
log.error("Failed to generate a request URI from base URI " + baseUri.toString(), e);
throw new RuntimeException(e);
}
switch (request.getHttpMethod()) {
case GET:
requestBuilder = client.prepareGet(uri);
break;
case PUT:
requestBuilder = client.preparePut(uri);
break;
case POST:
requestBuilder = client.preparePost(uri);
break;
case DELETE:
requestBuilder = client.prepareDelete(uri);
break;
default:
requestBuilder = client.prepareGet(uri);
break;
}
//Headers
for (Map.Entry entry : headers.entrySet()) {
requestBuilder.addHeader(entry.getKey(), entry.getValue());
}
// Body
String body = request.getRequestBody();
ContentType contentType = request.getContentType();
if (body != null && contentType != null) {
requestBuilder.setBody(body.getBytes(contentType.getCharset()));
}
log.debug(String.format("Executing Urban Airship request to %s with body %s.", uri, request.getRequestBody()));
ResponseAsyncHandler handler = new ResponseAsyncHandler<>(Optional.ofNullable(callback), request.getResponseParser());
return requestBuilder.execute(handler);
}
/**
* Close the underlying HTTP client's thread pool.
*/
@Override
public void close() throws IOException {
log.info("Closing client");
client.close();
}
/**
* AsyncRequestClient Builder.
*/
public static class Builder {
private String baseUri;
private Integer maxRetries = 10;
private DefaultAsyncHttpClientConfig.Builder clientConfigBuilder = new DefaultAsyncHttpClientConfig.Builder();
private Predicate retryPredicate = null;
private ProxyServer proxyServer;
private Builder() {
baseUri = US_URI;
}
/**
* Set the base URI -- defaults to "https://go.urbanairship.com"
* @param URI String base URI
* @return Builder
*/
public Builder setBaseUri(String URI) {
this.baseUri = URI;
return this;
}
/**
* Set the maximum for non-POST request retries on 5xxs -- defaults to 10.
*
* @param maxRetries The maximum.
* @return Builder
*/
public Builder setMaxRetries(Integer maxRetries) {
this.maxRetries = maxRetries;
return this;
}
/**
* Set the client config builder -- defaults to a new builder. Available for custom settings.
*
* @param clientConfigBuilder The client config builder.
* @return Builder
*/
public Builder setClientConfigBuilder(DefaultAsyncHttpClientConfig.Builder clientConfigBuilder) {
this.clientConfigBuilder = clientConfigBuilder;
return this;
}
/**
* Set the proxy server builder.
*
* @param proxyServer ProxyServer
* @return Builder
*/
public Builder setProxyServer(ProxyServer proxyServer) {
this.proxyServer = proxyServer;
return this;
}
/**
* Set an optional predicate for allowing request retries on 5xxs.
*
* @param retryPredicate The retry predicate.
* @return Builder
*/
public Builder setRetryPredicate(Predicate retryPredicate) {
this.retryPredicate = retryPredicate;
return this;
}
/**
* Build an UrbanAirshipClient object. Will fail if any of the following
* preconditions are not met.
*
* 1. App key must be set.
* 2. App secret must be set.
* 3. The base URI has been overridden but not set.
* 4. Max for non-POST 5xx retries must be set, already defaults to 10.
* 5. HTTP client config builder must be set, already defaults to a new builder.
*
*
* @return UrbanAirshipClient
*/
public AsyncRequestClient build() {
Preconditions.checkNotNull(baseUri, "base URI needed to build APIClient");
Preconditions.checkNotNull(maxRetries, "max non-POST retries needed to build APIClient");
Preconditions.checkNotNull(clientConfigBuilder, "Async HTTP client config builder needed to build APIClient");
return new AsyncRequestClient(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy