All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.arangodb.shaded.vertx.ext.web.client.HttpRequest Maven / Gradle / Ivy

There is a newer version: 7.13.0
Show newest version
/*
 * Copyright (c) 2011-2013 The original author or authors
 * ------------------------------------------------------
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Apache License v2.0 which accompanies this distribution.
 *
 *     The Eclipse Public License is available at
 *     http://www.eclipse.org/legal/epl-v10.html
 *
 *     The Apache License v2.0 is available at
 *     http://www.opensource.org/licenses/apache2.0.php
 *
 * You may elect to redistribute this code under either of these licenses.
 */
package com.arangodb.shaded.vertx.ext.web.client;

import com.arangodb.shaded.vertx.codegen.annotations.*;
import com.arangodb.shaded.vertx.core.*;
import com.arangodb.shaded.vertx.core.buffer.Buffer;
import com.arangodb.shaded.vertx.core.http.HttpMethod;
import com.arangodb.shaded.vertx.core.json.JsonObject;
import com.arangodb.shaded.vertx.core.net.ProxyOptions;
import com.arangodb.shaded.vertx.core.streams.ReadStream;
import com.arangodb.shaded.vertx.ext.auth.authentication.Credentials;
import com.arangodb.shaded.vertx.ext.auth.authentication.TokenCredentials;
import com.arangodb.shaded.vertx.ext.auth.authentication.UsernamePasswordCredentials;
import com.arangodb.shaded.vertx.ext.web.client.predicate.ResponsePredicate;
import com.arangodb.shaded.vertx.ext.web.client.predicate.ResponsePredicateResult;
import com.arangodb.shaded.vertx.ext.web.codec.BodyCodec;
import com.arangodb.shaded.vertx.ext.web.multipart.MultipartForm;
import com.arangodb.shaded.vertx.uritemplate.Variables;
import com.arangodb.shaded.vertx.uritemplate.UriTemplate;

import java.util.List;
import java.util.Map;
import java.util.function.Function;

/**
 * A client-side HTTP request.
 * 

* Instances are created by an {@link WebClient} instance, via one of the methods corresponding to the specific * HTTP methods such as {@link WebClient#get}, etc... *

* The request shall be configured prior sending, the request is immutable and when a mutator method * is called, a new request is returned allowing to expose the request in a public API and apply further customization. *

* After the request has been configured, the methods *

    *
  • {@link #send(Handler)}
  • *
  • {@link #sendStream(ReadStream, Handler)}
  • *
  • {@link #sendJson(Object, Handler)} ()}
  • *
  • {@link #sendForm(MultiMap, Handler)}
  • *
* can be called. * The {@code sendXXX} methods perform the actual request, they can be called multiple times to perform the same HTTP * request at different points in time. *

* The handler is called back with *

    *
  • an {@link HttpResponse} instance when the HTTP response has been received
  • *
  • a failure when the HTTP request failed (like a connection error) or when the HTTP response could * not be obtained (like connection or unmarshalling errors)
  • *
*

* Most of the time, this client will buffer the HTTP response fully unless a specific {@link BodyCodec} is used * such as {@link BodyCodec#create(Handler)}. * * @param the type of response body * @author Julien Viet */ @VertxGen public interface HttpRequest { /** * Configure the request to use a new method {@code value}. * * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest method(HttpMethod value); /** * @return the request method */ HttpMethod method(); /** * Configure the request to use a new port {@code value}. *

This overrides the port set by absolute URI requests * * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest port(int value); /** * @return the request port or {@code 0} when none is set for absolute URI templates */ int port(); /** * Configure the request to decode the response with the {@code responseCodec}. * * @param responseCodec the response codec * @return a reference to this, so the API can be used fluently */ HttpRequest as(BodyCodec responseCodec); /** * @return the request body codec */ BodyCodec bodyCodec(); /** * Configure the request to use a new host {@code value}. *

This overrides the host set by absolute URI requests * * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest host(String value); /** * @return the request host or {@code null} when none is set for absolute URI templates */ String host(); /** * Configure the request to use a virtual host {@code value}. *

* Usually the header host (:authority pseudo header for HTTP/2) is set from the request host value * since this host value resolves to the server IP address. *

* Sometimes you need to set a host header for an address that does not resolve to the server IP address. * The virtual host value overrides the value of the actual host header (:authority pseudo header * for HTTP/2). *

* The virtual host is also be used for SNI. * * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest virtualHost(String value); /** * @return the request virtual host if any or {@code null} */ String virtualHost(); /** * Configure the request to use a new request URI {@code value}. *

This overrides the port set by absolute URI requests *

When the uri has query parameters, they are set in the {@link #queryParams()}, overwriting * any parameters previously set * * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest uri(String value); /** * @return the request uri or {@code null} when none is set for absolute URI templates */ String uri(); /** * Configure the request to add multiple HTTP headers . * * @param headers The HTTP headers * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest putHeaders(MultiMap headers); /** * Configure the request to set a new HTTP header. * * @param name the header name * @param value the header value * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest putHeader(String name, String value); /** * Configure the request to set a new HTTP header with multiple values. * * @param name the header name * @param value the header value * @return a reference to this, so the API can be used fluently */ @Fluent @GenIgnore(GenIgnore.PERMITTED_TYPE) HttpRequest putHeader(String name, Iterable value); /** * @return The HTTP headers */ @CacheReturn MultiMap headers(); /** * Configure the request to perform HTTP Authentication. *

* Performs a generic authentication using the credentials provided by the user. For the sake of validation safety * it is recommended that {@link Credentials#applyHttpChallenge(String)} is called to ensure that the credentials * are applicable to the HTTP Challenged received on a previous request that returned a 401 response code. * * @param credentials the credentials to use. * @return a reference to this, so the API can be used fluently */ @Fluent @GenIgnore(GenIgnore.PERMITTED_TYPE) HttpRequest authentication(Credentials credentials); /** * Configure the request to perform basic access authentication. *

* In basic HTTP authentication, a request contains a header field of the form 'Authorization: Basic <credentials>', * where credentials is the base64 encoding of id and password joined by a colon. *

* In practical terms the arguments are converted to a {@link UsernamePasswordCredentials} object. * * @param id the id * @param password the password * @return a reference to this, so the API can be used fluently */ @Fluent default HttpRequest basicAuthentication(String id, String password) { return authentication(new UsernamePasswordCredentials(id, password).applyHttpChallenge(null)); } /** * Configure the request to perform basic access authentication. *

* In basic HTTP authentication, a request contains a header field of the form 'Authorization: Basic <credentials>', * where credentials is the base64 encoding of id and password joined by a colon. *

* In practical terms the arguments are converted to a {@link UsernamePasswordCredentials} object. * * @param id the id * @param password the password * @return a reference to this, so the API can be used fluently */ @Fluent default HttpRequest basicAuthentication(Buffer id, Buffer password) { return basicAuthentication(id.toString(), password.toString()); } /** * Configure the request to perform bearer token authentication. *

* In OAuth 2.0, a request contains a header field of the form 'Authorization: Bearer <bearerToken>', * where bearerToken is the bearer token issued by an authorization server to access protected resources. *

* In practical terms the arguments are converted to a {@link TokenCredentials} object. * * @param bearerToken the bearer token * @return a reference to this, so the API can be used fluently */ @Fluent default HttpRequest bearerTokenAuthentication(String bearerToken) { return authentication(new TokenCredentials(bearerToken).applyHttpChallenge(null)); } /** * Configure the request whether to use SSL. *

This overrides the SSL value set by absolute URI requests * * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest ssl(Boolean value); /** * @return whether the request uses SSL or {@code null} when none is set for absolute URI templates */ Boolean ssl(); /** * Configures the amount of time in milliseconds after which if the request does not return any data within the timeout * period an {@link java.util.concurrent.TimeoutException} fails the request. *

* Setting zero or a negative {@code value} disables the timeout. * * @param value The quantity of time in milliseconds. * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest timeout(long value); /** * @return the current timeout in milliseconds */ long timeout(); /** * Add a query parameter to the request. * * @param paramName the param name * @param paramValue the param value * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest addQueryParam(String paramName, String paramValue); /** * Set a query parameter to the request. * * @param paramName the param name * @param paramValue the param value * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest setQueryParam(String paramName, String paramValue); /** * Set a request URI template string parameter to the request, expanded when the request URI is a {@link UriTemplate}. * * @param paramName the param name * @param paramValue the param value * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest setTemplateParam(String paramName, String paramValue); /** * Set a request URI template list parameter to the request, expanded when the request URI is a {@link UriTemplate}. * * @param paramName the param name * @param paramValue the param value * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest setTemplateParam(String paramName, List paramValue); /** * Set a request URI template map parameter to the request, expanded when the request URI is a {@link UriTemplate}. * * @param paramName the param name * @param paramValue the param value * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest setTemplateParam(String paramName, Map paramValue); /** * Set whether to follow request redirections * * @param value true if redirections should be followed * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest followRedirects(boolean value); /** * @return whether to follow request redirections */ boolean followRedirects(); /** * Configure the request to set a proxy for this request. * * Setting proxy here supersedes the proxy set on the client itself * * @param proxyOptions The proxy options * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest proxy(ProxyOptions proxyOptions); /** * @return the proxy for this request */ ProxyOptions proxy(); /** * Add an expectation that the response is valid according to the provided {@code predicate}. *

* Multiple predicates can be added. * * @param predicate the predicate * @return a reference to this, so the API can be used fluently */ @Fluent default HttpRequest expect(Function, ResponsePredicateResult> predicate) { return expect(predicate::apply); } /** * Add an expectation that the response is valid according to the provided {@code predicate}. *

* Multiple predicates can be added. * * @param predicate the predicate * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest expect(ResponsePredicate predicate); /** * @return a read-only list of the response predicate expectations */ List expectations(); /** * Return the current query parameters. * * @return the current query parameters */ MultiMap queryParams(); /** * Return the current request URI template parameters. * * @return the current request URI template parameters */ Variables templateParams(); /** * Copy this request * * @return a copy of this request */ HttpRequest copy(); /** * Allow or disallow multipart mixed encoding when sending {@link MultipartForm} having files sharing the same * file name. *
* The default value is {@code true}. *
* Set to {@code false} if you want to achieve the behavior for HTML5. * * @param allow {@code true} allows use of multipart mixed encoding * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest multipartMixed(boolean allow); /** * @return whether multipart mixed encoding is allowed */ boolean multipartMixed(); /** * Trace operation name override. * * @param traceOperation Name of operation to use in traces * @return a reference to this, so the API can be used fluently */ @Fluent HttpRequest traceOperation(String traceOperation); /** * @return the trace operation name override */ String traceOperation(); /** * Like {@link #send(Handler)} but with an HTTP request {@code body} stream. * * @param body the body */ void sendStream(ReadStream body, Handler>> handler); /** * @param body the body * @see HttpRequest#sendStream(ReadStream, Handler) */ default Future> sendStream(ReadStream body) { Promise> promise = Promise.promise(); sendStream(body, promise); return promise.future(); } /** * Like {@link #send(Handler)} but with an HTTP request {@code body} buffer. * * @param body the body */ void sendBuffer(Buffer body, Handler>> handler); /** * @param body the body * @see HttpRequest#sendBuffer(Buffer, Handler) */ default Future> sendBuffer(Buffer body) { Promise> promise = Promise.promise(); sendBuffer(body, promise); return promise.future(); } /** * Like {@link #send(Handler)} but with an HTTP request {@code body} object encoded as json and the content type * set to {@code application/json}. * * @param body the body */ void sendJsonObject(JsonObject body, Handler>> handler); /** * @param body the body * @see HttpRequest#sendJsonObject(JsonObject, Handler) */ default Future> sendJsonObject(JsonObject body) { Promise> promise = Promise.promise(); sendJsonObject(body, promise); return promise.future(); } /** * Like {@link #send(Handler)} but with an HTTP request {@code body} object encoded as json and the content type * set to {@code application/json}. * * @param body the body */ void sendJson(@Nullable Object body, Handler>> handler); /** * @param body the body * @see HttpRequest#sendJson(Object, Handler) */ default Future> sendJson(@Nullable Object body) { Promise> promise = Promise.promise(); sendJson(body, promise); return promise.future(); } /** * Like {@link #send(Handler)} but with an HTTP request {@code body} multimap encoded as form and the content type * set to {@code application/x-www-form-urlencoded}. *

* When the content type header is previously set to {@code multipart/form-data} it will be used instead. * * @param body the body */ void sendForm(MultiMap body, Handler>> handler); /** * @param body the body * @see HttpRequest#sendForm(MultiMap, Handler) */ default Future> sendForm(MultiMap body) { Promise> promise = Promise.promise(); sendForm(body, promise); return promise.future(); } /** * Like {@link #send(Handler)} but with an HTTP request {@code body} multimap encoded as form and the content type * set to {@code application/x-www-form-urlencoded}. *

* When the content type header is previously set to {@code multipart/form-data} it will be used instead. * * NOTE: the use of this method is strongly discouraged to use when the form is a {@code application/x-www-form-urlencoded} * encoded form since the charset to use must be UTF-8. * * @param body the body */ void sendForm(MultiMap body, String charset, Handler>> handler); /** * @param body the body * @param charset the charset * @see HttpRequest#sendForm(MultiMap, String, Handler) */ default Future> sendForm(MultiMap body, String charset) { Promise> promise = Promise.promise(); sendForm(body, charset, promise); return promise.future(); } /** * Like {@link #send(Handler)} but with an HTTP request {@code body} multimap encoded as form and the content type * set to {@code multipart/form-data}. You may use this method to send attributes and upload files. * * @param body the body */ void sendMultipartForm(MultipartForm body, Handler>> handler); /** * @param body the body * @see HttpRequest#sendMultipartForm(MultipartForm, Handler) */ default Future> sendMultipartForm(MultipartForm body) { Promise> promise = Promise.promise(); sendMultipartForm(body, promise); return promise.future(); } /** * Send a request, the {@code handler} will receive the response as an {@link HttpResponse}. */ void send(Handler>> handler); /** * @see HttpRequest#send(Handler) */ default Future> send() { Promise> promise = Promise.promise(); send(promise); return promise.future(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy