ratpack.http.client.HttpClient Maven / Gradle / Ivy
/*
* Copyright 2014 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package ratpack.http.client;
import io.netty.buffer.ByteBufAllocator;
import ratpack.exec.ExecController;
import ratpack.exec.Promise;
import ratpack.func.Action;
import ratpack.http.client.internal.DefaultHttpClient;
import ratpack.registry.Registry;
import ratpack.server.ServerConfig;
import java.net.URI;
/**
* A http client that makes all HTTP requests asynchronously and returns a {@link ratpack.exec.Promise}.
*
* All details of the request are configured by the {@link ratpack.func.Action} acting on the {@link ratpack.http.client.RequestSpec}.
*
* Example of a simple GET and POST request.
*
*
{@code
*
* import ratpack.http.HttpUrlBuilder;
* import ratpack.http.client.HttpClient;
* import ratpack.server.PublicAddress;
* import ratpack.test.embed.EmbeddedApp;
*
* import java.net.URI;
* import static org.junit.Assert.*;
*
* public class ExampleHttpClient {
*
* public static void main(String[] args) throws Exception {
* EmbeddedApp.fromHandlers(chain -> {
* chain
* .get("simpleGet", context -> {
* PublicAddress address = context.get(PublicAddress.class); //find local ip address
* HttpClient httpClient = context.get(HttpClient.class); //get httpClient
*
* httpClient.get(HttpUrlBuilder.base(address.getAddress(context)).segment("httpClientGet").build()).then(response -> {
* context.render(response.getBody().getText()); //Render the response from the httpClient GET request
* }
* );
* })
* .get("simplePost", context -> {
* PublicAddress address = context.get(PublicAddress.class); //find local ip address
* HttpClient httpClient = context.get(HttpClient.class); //get httpClient
*
* httpClient.post(HttpUrlBuilder.base(address.getAddress(context)).segment("httpClientPost").build(), action ->
* action.body(body ->
* body.text("foo") //Configure the POST body
* )
* ).then(response -> {
* context.render(response.getBody().getText()); //Render the response from the httpClient POST request
* });
* })
* .get("httpClientGet", context -> {
* context.render("httpClientGet");
* })
* .post("httpClientPost", context -> {
* context.render(context.getRequest().getBody().getText().toUpperCase());
* });
* }
* ).test(testHttpClient -> {
* assertEquals("httpClientGet", testHttpClient.getText("/simpleGet"));
* assertEquals("FOO", testHttpClient.getText("/simplePost"));
* });
* }
* }
*
* }
*/
public interface HttpClient {
/**
* A method to create an instance of the default implementation of HttpClient.
*
* @param serverConfig The {@link ratpack.server.ServerConfig} used to provide the max content length of a response.
* @param registry The {@link ratpack.registry.Registry} used to provide the {@link ratpack.exec.ExecController} and {@link io.netty.buffer.ByteBufAllocator} needed for DefaultHttpClient
* @return An instance of a HttpClient
*/
static HttpClient httpClient(ServerConfig serverConfig, Registry registry) {
return new DefaultHttpClient(registry.get(ExecController.class), registry.get(ByteBufAllocator.class), serverConfig.getMaxContentLength());
}
/**
* A method to create an instance of the default implementation of HttpClient.
*
* @param execController The ExecController used while making the requests.
* @param byteBufAllocator What ByteBufAllocator to use with the underlying Netty request.
* @param maxContentLengthBytes The max content length of a response to support.
* @return An instance of a HttpClient
*/
static HttpClient httpClient(ExecController execController, ByteBufAllocator byteBufAllocator, int maxContentLengthBytes) {
return new DefaultHttpClient(execController, byteBufAllocator, maxContentLengthBytes);
}
/**
* An asynchronous method to do a GET HTTP request, the URL and all details of the request are configured by the Action acting on the RequestSpec, but the method will be defaulted to a GET.
*
* @param uri the request URL (as a URI), must be of the {@code http} or {@code https} protocol
* @param action An action that will act on the {@link RequestSpec}
* @return A promise for a {@link ratpack.http.client.ReceivedResponse}
*/
Promise get(URI uri, Action super RequestSpec> action);
default Promise get(URI uri) {
return get(uri, Action.noop());
}
/**
* An asynchronous method to do a POST HTTP request, the URL and all details of the request are configured by the Action acting on the RequestSpec, but the method will be defaulted to a POST.
*
* @param uri the request URL (as a URI), must be of the {@code http} or {@code https} protocol
* @param action An action that will act on the {@link RequestSpec}
* @return A promise for a {@link ratpack.http.client.ReceivedResponse}
*/
Promise post(URI uri, Action super RequestSpec> action);
/**
* An asynchronous method to do a HTTP request, the URL and all details of the request are configured by the Action acting on the RequestSpec.
*
* @param uri the request URL (as a URI), must be of the {@code http} or {@code https} protocol
* @param action An action that will act on the {@link RequestSpec}
* @return A promise for a {@link ratpack.http.client.ReceivedResponse}
*/
Promise request(URI uri, Action super RequestSpec> action);
/**
* An asynchronous method to do a HTTP request, the URL and all details of the request are configured by the Action acting on the RequestSpec,
* the received response content will be streamed.
*
* In order to access the response content stream either subscribe to the {@link org.reactivestreams.Publisher} returned from {@link StreamedResponse#getBody()}
* or use {@link ratpack.http.client.StreamedResponse#send(ratpack.http.Response, ratpack.func.Action)} to directly stream the content as a server response.
*
* @param uri the request URL (as a URI), must be of the {@code http} or {@code https} protocol
* @param requestConfigurer an action that will act on the {@link RequestSpec}
* @return a promise for a {@link ratpack.http.client.StreamedResponse}
*
* @see ratpack.http.client.StreamedResponse
*/
Promise requestStream(URI uri, final Action super RequestSpec> requestConfigurer);
}