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

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

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright (c) 2011-2023 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.Nullable;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.AsyncResult;
import io.vertx.core.Future;
import io.vertx.core.Handler;
import io.vertx.core.buffer.Buffer;

/**
 * Represents a client-side WebSocket initially not connected.
 *
 * @author Julien Viet
 */
@VertxGen
public interface ClientWebSocket extends WebSocket {

  /**
   * Connect a WebSocket to the specified port, host and relative request URI
   * @param port  the port
   * @param host  the host
   * @param requestURI  the relative URI
   * @param handler  handler that will be called with the WebSocket when connected
   */
  default void connect(int port, String host, String requestURI, Handler> handler) {
    connect(new WebSocketConnectOptions().setPort(port).setHost(host).setURI(requestURI), handler);
  }

  /**
   * Like {@link #connect(int, String, String, Handler)} but returns a {@code Future} of the asynchronous result
   */
  default Future connect(int port, String host, String requestURI) {
    return connect(new WebSocketConnectOptions().setPort(port).setHost(host).setURI(requestURI));
  }

  /**
   * Connect a WebSocket with the specified options.
   *
   * @param options  the request options
   * @param handler  handler that will be called with the WebSocket when connected
   */
  void connect(WebSocketConnectOptions options, Handler> handler);

  /**
   * Like {@link #connect(WebSocketConnectOptions, Handler)} but returns a {@code Future} of the asynchronous result
   */
  Future connect(WebSocketConnectOptions options);

  /**
   * Connect this WebSocket to the host and relative request URI and default port.
   *
   * @param host  the host
   * @param requestURI  the relative URI
   * @param handler  handler that will be called with the WebSocket when connected
   */
  default void connect(String host, String requestURI, Handler> handler) {
    connect(new WebSocketConnectOptions().setHost(host).setURI(requestURI), handler);
  }

  /**
   * Connect this WebSocket to the host and relative request URI and default port.
   *
   * @param host  the host
   * @param requestURI  the relative URI
   * @return a future notified when the WebSocket when connected
   */
  default Future connect(String host, String requestURI) {
    return connect(new WebSocketConnectOptions().setHost(host).setURI(requestURI));
  }

  /**
   * Connect this WebSocket at the relative request URI using the default host and port.
   *
   * @param requestURI  the relative URI
   * @param handler  handler that will be called with the WebSocket when connected
   */
  default void connect(String requestURI, Handler> handler) {
    connect(new WebSocketConnectOptions().setURI(requestURI), handler);
  }

  /**
   * Connect this WebSocket at the relative request URI using the default host and port.
   *
   * @param requestURI  the relative URI
   * @return a future notified when the WebSocket when connected
   */
  default Future connect(String requestURI) {
    return connect(new WebSocketConnectOptions().setURI(requestURI));
  }

  @Override
  ClientWebSocket handler(Handler handler);

  @Override
  ClientWebSocket endHandler(Handler endHandler);

  @Override
  ClientWebSocket drainHandler(Handler handler);

  @Override
  ClientWebSocket closeHandler(Handler handler);

  @Override
  ClientWebSocket frameHandler(Handler handler);

  @Override
  ClientWebSocket textMessageHandler(@Nullable Handler handler);

  @Override
  ClientWebSocket binaryMessageHandler(@Nullable Handler handler);

  @Override
  ClientWebSocket pongHandler(@Nullable Handler handler);

  @Override
  ClientWebSocket exceptionHandler(Handler handler);

  @Override
  ClientWebSocket writeFrame(WebSocketFrame frame, Handler> handler);

  @Override
  ClientWebSocket writeFinalTextFrame(String text, Handler> handler);

  @Override
  ClientWebSocket writeFinalBinaryFrame(Buffer data, Handler> handler);

  @Override
  ClientWebSocket writeBinaryMessage(Buffer data, Handler> handler);

  @Override
  ClientWebSocket writeTextMessage(String text, Handler> handler);

  @Override
  ClientWebSocket writePing(Buffer data, Handler> handler);

  @Override
  ClientWebSocket writePong(Buffer data, Handler> handler);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy