
com.chavaillaz.client.common.java.AbstractJavaHttpClient Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of common-client Show documentation
Show all versions of common-client Show documentation
Library for the creation of asynchronous clients supporting multiple HTTP clients
package com.chavaillaz.client.common.java;
import static com.chavaillaz.client.common.utility.Utils.getCookieHeader;
import java.io.InputStream;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpRequest.BodyPublisher;
import java.net.http.HttpRequest.BodyPublishers;
import java.net.http.HttpResponse;
import java.net.http.HttpResponse.BodyHandlers;
import java.util.Objects;
import java.util.concurrent.CompletableFuture;
import com.chavaillaz.client.common.AbstractHttpClient;
import com.chavaillaz.client.common.security.Authentication;
import com.fasterxml.jackson.databind.JavaType;
/**
* Abstract class implementing common parts for Java HTTP.
*/
public abstract class AbstractJavaHttpClient extends AbstractHttpClient implements AutoCloseable {
protected final HttpClient client;
/**
* Creates a new abstract client based on Java HTTP client.
*
* @param client The Java HTTP client to use
* @param baseUrl The base URL of service API
* @param authentication The authentication information
*/
protected AbstractJavaHttpClient(HttpClient client, String baseUrl, Authentication authentication) {
super(baseUrl, authentication);
this.client = client;
}
/**
* Creates a new request builder based on the given URL and replaces the parameters in it by the given ones.
*
* @param url The URL with possible parameters in it (using braces)
* @param parameters The parameters value to replace in the URL (in the right order)
* @return The request builder having the URL and authentication set
*/
protected HttpRequest.Builder requestBuilder(String url, Object... parameters) {
var builder = HttpRequest.newBuilder()
.uri(url(url, parameters))
.header(HEADER_CONTENT_TYPE, HEADER_CONTENT_JSON);
getAuthentication().fillHeaders(builder::setHeader);
getCookieHeader(getAuthentication()).ifPresent(value -> builder.setHeader(HEADER_COOKIE, value));
return builder;
}
/**
* Creates the body publisher that is serializing the given object.
*
* @param object The object to serialize
* @return The corresponding body publisher
*/
protected BodyPublisher body(Object object) {
return BodyPublishers.ofString(serialize(object));
}
/**
* Checks the response and throws an exception in case of unsuccessful call (not 2xx or 3xx status code).
*
* @param response The HTTP response received
* @param The response body type
* @return The same HTTP response as in parameter
*/
protected HttpResponse checkResponse(HttpResponse response) {
if (response.statusCode() >= 400) {
throw responseException(response.statusCode(), Objects.toString(response.body(), null));
}
return response;
}
/**
* Sends a request and returns a domain object.
*
* @param requestBuilder The request builder
* @param returnType The content type of the content received
* @param The content type
* @return A {@link CompletableFuture} with the deserialized response body
*/
protected CompletableFuture sendAsync(HttpRequest.Builder requestBuilder, Class returnType) {
return sendAsync(requestBuilder, objectMapper.constructType(returnType));
}
/**
* Sends a request and returns a domain object.
*
* @param requestBuilder The request builder
* @param returnType The content type of the content received
* @param The content type
* @return A {@link CompletableFuture} with the deserialized response body
*/
protected CompletableFuture sendAsync(HttpRequest.Builder requestBuilder, JavaType returnType) {
return client.sendAsync(requestBuilder.build(), BodyHandlers.ofString())
.thenApply(this::checkResponse)
.thenApply(response -> deserialize(response.body(), returnType));
}
/**
* Sends a request and returns an input stream.
*
* @param requestBuilder The request builder
* @return A {@link CompletableFuture} with the input stream
*/
protected CompletableFuture sendAsync(HttpRequest.Builder requestBuilder) {
return client.sendAsync(requestBuilder.build(), BodyHandlers.ofInputStream())
.thenApply(this::checkResponse)
.thenApply(HttpResponse::body);
}
@Override
public void close() {
// Java client does not need to be closed
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy