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

io.vertx.core.http.HttpConnection Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright (c) 2011-2019 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.core.http;

import io.vertx.codegen.annotations.*;
import io.vertx.core.AsyncResult;
import io.vertx.core.Future;
import io.vertx.core.Handler;
import io.vertx.core.buffer.Buffer;
import io.vertx.core.net.SocketAddress;

import javax.net.ssl.SSLPeerUnverifiedException;
import javax.net.ssl.SSLSession;
import javax.security.cert.X509Certificate;
import java.security.cert.Certificate;
import java.util.List;
import java.util.concurrent.TimeUnit;

/**
 * Represents an HTTP connection.
 * 

* HTTP/1.x connection provides an limited implementation, the following methods are implemented: *

    *
  • {@link #close}
  • *
  • {@link #closeHandler}
  • *
  • {@link #exceptionHandler}
  • *
* * @author Julien Viet */ @VertxGen public interface HttpConnection { /** * @return the current connection window size or {@code -1} for HTTP/1.x */ default int getWindowSize() { return -1; } /** * Update the current connection wide window size to a new size. *

* Increasing this value, gives better performance when several data streams are multiplexed *

* This is not implemented for HTTP/1.x. * * @param windowSize the new window size * @return a reference to this, so the API can be used fluently */ @Fluent default HttpConnection setWindowSize(int windowSize) { return this; } /** * Like {@link #goAway(long, int)} with a last stream id {@code -1} which means to disallow any new stream creation. */ @Fluent default HttpConnection goAway(long errorCode) { return goAway(errorCode, -1); } /** * Like {@link #goAway(long, int, Buffer)} with no buffer. */ @Fluent default HttpConnection goAway(long errorCode, int lastStreamId) { return goAway(errorCode, lastStreamId, null); } /** * Send a go away frame to the remote endpoint of the connection. *

*

    *
  • a {@literal GOAWAY} frame is sent to the to the remote endpoint with the {@code errorCode} and {@code debugData}
  • *
  • any stream created after the stream identified by {@code lastStreamId} will be closed
  • *
  • for an {@literal errorCode} is different than {@code 0} when all the remaining streams are closed this connection will be closed automatically
  • *
*

* This is not implemented for HTTP/1.x. * * @param errorCode the {@literal GOAWAY} error code * @param lastStreamId the last stream id * @param debugData additional debug data sent to the remote endpoint * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection goAway(long errorCode, int lastStreamId, Buffer debugData); /** * Set an handler called when a {@literal GOAWAY} frame is received. *

* This is not implemented for HTTP/1.x. * * @param handler the handler * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection goAwayHandler(@Nullable Handler handler); /** * Set an handler called when a {@literal GOAWAY} frame has been sent or received and all connections are closed. *

* This is not implemented for HTTP/1.x. * * @param handler the handler * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection shutdownHandler(@Nullable Handler handler); /** * Shutdown a 30 seconds timeout ({@code shutdown(30, TimeUnit.SECONDS)}). */ default void shutdown(Handler> handler) { shutdown(30, TimeUnit.SECONDS, handler); } /** * Like {@link #shutdown(Handler)} but returns a {@code Future} of the asynchronous result */ default Future shutdown() { return shutdown(30, TimeUnit.SECONDS); } /** * Like {@link #shutdown(long, TimeUnit, Handler)}, in milliseconds. * * @deprecated instead use {@link #shutdown(long, TimeUnit, Handler)} */ @Deprecated default void shutdown(long timeout, Handler> handler) { shutdown(timeout, TimeUnit.MILLISECONDS, handler); } /** * Like {@link #shutdown(long, Handler)} but returns a {@code Future} of the asynchronous result * * @deprecated instead use {@link #shutdown(long, TimeUnit)} */ @Deprecated default Future shutdown(long timeoutMs) { return shutdown(timeoutMs, TimeUnit.MILLISECONDS); } /** * Initiate a graceful connection shutdown, the connection is taken out of service and closed when all the inflight requests * are processed, otherwise after a {@code timeout} the connection will be closed. Client connection are immediately removed * from the pool. * *

    *
  • HTTP/2 connections will send a go away frame immediately to signal the other side the connection will close.
  • *
  • HTTP/1.x connection will be closed.
  • *
* * @param timeout the amount of time after which all resources are forcibly closed * @param unit the of the timeout * @param handler the handler notified with the result */ default void shutdown(long timeout, TimeUnit unit, Handler> handler) { Future fut = shutdown(timeout, unit); if (handler != null) { fut.onComplete(handler); } } /** * Like {@link #shutdown(long, TimeUnit, Handler)} but returns a {@code Future} of the asynchronous result */ Future shutdown(long timeout, TimeUnit unit); /** * Set a close handler. The handler will get notified when the connection is closed. * * @param handler the handler to be notified * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection closeHandler(Handler handler); /** * Like {@link #close(Handler)} but returns a {@code Future} of the asynchronous result */ Future close(); /** * Close the connection and all the currently active streams. *

* An HTTP/2 connection will send a {@literal GOAWAY} frame before. * * @param handler the handler to be completed when the connection is closed */ default void close(Handler> handler) { close().onComplete(handler); } /** * @return the latest server settings acknowledged by the remote endpoint - this is not implemented for HTTP/1.x */ Http2Settings settings(); /** * Send to the remote endpoint an update of the server settings. *

* This is not implemented for HTTP/1.x. * * @param settings the new settings * @return a future completed with the result */ Future updateSettings(Http2Settings settings); /** * Send to the remote endpoint an update of this endpoint settings *

* The {@code completionHandler} will be notified when the remote endpoint has acknowledged the settings. *

* This is not implemented for HTTP/1.x. * * @param settings the new settings * @param completionHandler the handler notified when the settings have been acknowledged by the remote endpoint * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection updateSettings(Http2Settings settings, Handler> completionHandler); /** * @return the current remote endpoint settings for this connection - this is not implemented for HTTP/1.x */ Http2Settings remoteSettings(); /** * Set an handler that is called when remote endpoint {@link Http2Settings} are updated. *

* This is not implemented for HTTP/1.x. * * @param handler the handler for remote endpoint settings * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection remoteSettingsHandler(Handler handler); /** * Send a {@literal PING} frame to the remote endpoint. *

* This is not implemented for HTTP/1.x. * * @param data the 8 bytes data of the frame * @param pongHandler an async result handler notified with pong reply or the failure * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection ping(Buffer data, Handler> pongHandler); /** * Same as {@link #ping(Buffer, Handler)} but returns a {@code Future} of the asynchronous result */ Future ping(Buffer data); /** * Set an handler notified when a {@literal PING} frame is received from the remote endpoint. *

* This is not implemented for HTTP/1.x. * * @param handler the handler to be called when a {@literal PING} is received * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection pingHandler(@Nullable Handler handler); /** * Set an handler called when a connection error happens * * @param handler the handler * @return a reference to this, so the API can be used fluently */ @Fluent HttpConnection exceptionHandler(Handler handler); /** * @return the remote address for this connection, possibly {@code null} (e.g a server bound on a domain socket). * If {@code useProxyProtocol} is set to {@code true}, the address returned will be of the actual connecting client. */ @CacheReturn SocketAddress remoteAddress(); /** * Like {@link #remoteAddress()} but returns the proxy remote address when {@code real} is {@code true} */ SocketAddress remoteAddress(boolean real); /** * @return the local address for this connection, possibly {@code null} (e.g a server bound on a domain socket) * If {@code useProxyProtocol} is set to {@code true}, the address returned will be of the proxy. */ @CacheReturn SocketAddress localAddress(); /** * Like {@link #localAddress()} ()} but returns the server local address when {@code real} is {@code true} */ SocketAddress localAddress(boolean real); /** * @return true if this {@link io.vertx.core.http.HttpConnection} is encrypted via SSL/TLS. */ boolean isSsl(); /** * @return SSLSession associated with the underlying socket. Returns null if connection is * not SSL. * @see javax.net.ssl.SSLSession */ @GenIgnore(GenIgnore.PERMITTED_TYPE) SSLSession sslSession(); /** * Note: Java SE 5+ recommends to use javax.net.ssl.SSLSession#getPeerCertificates() instead of * of javax.net.ssl.SSLSession#getPeerCertificateChain() which this method is based on. Use {@link #sslSession()} to * access that method. * * @return an ordered array of the peer certificates. Returns null if connection is * not SSL. * @throws javax.net.ssl.SSLPeerUnverifiedException SSL peer's identity has not been verified. * @see javax.net.ssl.SSLSession#getPeerCertificateChain() * @see #sslSession() * @deprecated instead use {@link #peerCertificates()} or {@link #sslSession()} */ @Deprecated @GenIgnore X509Certificate[] peerCertificateChain() throws SSLPeerUnverifiedException; /** * @return an ordered list of the peer certificates. Returns null if connection is * not SSL. * @throws javax.net.ssl.SSLPeerUnverifiedException SSL peer's identity has not been verified. * @see javax.net.ssl.SSLSession#getPeerCertificateChain() * @see #sslSession() */ @GenIgnore() List peerCertificates() throws SSLPeerUnverifiedException; /** * Returns the SNI server name presented during the SSL handshake by the client. * * @return the indicated server name */ String indicatedServerName(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy