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

io.vertx.httpproxy.HttpProxy Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR3
Show newest version
/*
 * Copyright (c) 2011-2020 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */
package io.vertx.httpproxy;

import io.vertx.codegen.annotations.Fluent;
import io.vertx.codegen.annotations.GenIgnore;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.Future;
import io.vertx.core.Handler;
import io.vertx.core.http.HttpClient;
import io.vertx.core.http.HttpClientRequest;
import io.vertx.core.http.HttpServerRequest;
import io.vertx.core.http.RequestOptions;
import io.vertx.core.net.SocketAddress;
import io.vertx.httpproxy.impl.ReverseProxy;

import java.util.function.BiFunction;
import java.util.function.Function;

/**
 * Handles the HTTP reverse proxy logic between the user agent and the origin.
 * 

* @author Julien Viet */ @VertxGen public interface HttpProxy extends Handler { /** * Create a new {@code HttpProxy} instance. * * @param client the {@code HttpClient} that forwards outbound requests to the origin. * @return a reference to this, so the API can be used fluently. */ static HttpProxy reverseProxy(HttpClient client) { return new ReverseProxy(new ProxyOptions(), client); } /** * Create a new {@code HttpProxy} instance. * * @param client the {@code HttpClient} that forwards outbound requests to the origin. * @return a reference to this, so the API can be used fluently. */ static HttpProxy reverseProxy(ProxyOptions options, HttpClient client) { return new ReverseProxy(options, client); } /** * Set the {@code SocketAddress} of the origin. * * @param address the {@code SocketAddress} of the origin * @return a reference to this, so the API can be used fluently */ @Fluent default HttpProxy origin(SocketAddress address) { return originSelector(req -> Future.succeededFuture(address)); } /** * Set the host name and port number of the origin. * * @param port the port number of the origin server * @param host the host name of the origin server * @return a reference to this, so the API can be used fluently */ @Fluent default HttpProxy origin(int port, String host) { return origin(SocketAddress.inetSocketAddress(port, host)); } /** * Set a selector that resolves the origin address based on the incoming HTTP request. * * @param selector the selector * @return a reference to this, so the API can be used fluently */ @Fluent default HttpProxy originSelector(Function> selector) { return originRequestProvider((req, client) -> selector .apply(req) .flatMap(server -> client.request(new RequestOptions().setServer(server)))); } /** * Set a provider that creates the request to the origin server based the incoming HTTP request. * Setting a provider overrides any origin selector previously set. * * @param provider the provider * @return a reference to this, so the API can be used fluently */ @GenIgnore() @Fluent HttpProxy originRequestProvider(BiFunction> provider); /** * Add an interceptor to the interceptor chain. *

* Interceptors are invoked in order of configuration. * When added with this method, it is considered the interceptor doesn't support WebSocket upgrades. * * @param interceptor the {@link ProxyInterceptor} to add * @return a reference to this, so the API can be used fluently */ @Fluent default HttpProxy addInterceptor(ProxyInterceptor interceptor) { return addInterceptor(interceptor, false); } /** * Add an interceptor to the interceptor chain. *

* Interceptors are invoked in order of configuration. * * @param interceptor the {@link ProxyInterceptor} to add * @param supportsWebSocketUpgrade whether the interceptor supports WebSocket upgrades * @return a reference to this, so the API can be used fluently */ @Fluent HttpProxy addInterceptor(ProxyInterceptor interceptor, boolean supportsWebSocketUpgrade); /** * Handle the outbound {@code HttpServerRequest}. * * @param request the outbound {@code HttpServerRequest} */ void handle(HttpServerRequest request); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy