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

org.atmosphere.websocket.WebSocketProtocolStream Maven / Gradle / Ivy

/*
* Copyright 2015 Async-IO.org
*
* 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 org.atmosphere.websocket;

import org.atmosphere.cpr.AtmosphereRequest;

import java.io.InputStream;
import java.io.Reader;
import java.util.List;

/**
 * A streaming API for WebServer that support WebSocket streaming. When a {@link WebSocketProtocol} implements this interface,
 * bytes/text will ve streamed instead of read in memory.
 *
 * @author Jeanfrancois Arcand
 */
public interface WebSocketProtocolStream extends WebSocketProtocol {

    /**
     * Parse the WebSocket stream, and delegate the processing to the {@link org.atmosphere.cpr.AtmosphereFramework#asyncSupport} or
     * to any existing technology. Invoking  {@link org.atmosphere.cpr.AtmosphereFramework#asyncSupport} will delegate the request processing
     * to the {@link org.atmosphere.cpr.AtmosphereHandler} implementation. Returning null means this implementation will
     * handle itself the processing/dispatching of the WebSocket's request;
     * 
* As an example, this is how Websocket messages are delegated to the * Jersey runtime. *
* * @param webSocket The {@link org.atmosphere.websocket.WebSocket} connection * @param r a {@link java.io.Reader} * @return a List of {@link org.atmosphere.cpr.AtmosphereRequest} */ List onTextStream(WebSocket webSocket, Reader r); /** * Parse the WebSocket stream, and delegate the processing to the {@link org.atmosphere.cpr.AtmosphereFramework#asyncSupport} or * to any existing technology. Invoking {@link org.atmosphere.cpr.AtmosphereFramework#asyncSupport} will delegate the request processing * to the {@link org.atmosphere.cpr.AtmosphereHandler} implementation. Returning null means this implementation will * handle itself the processing/dispatching of the WebSocket's request; *
* As an example, this is how Websocket messages are delegated to the * Jersey runtime. *
* * @param webSocket The {@link WebSocket} connection * @param stream a {@link Reader} * @return a List of {@link AtmosphereRequest} */ List onBinaryStream(WebSocket webSocket, InputStream stream); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy