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

org.atmosphere.cpr.AtmosphereResource Maven / Gradle / Ivy

/*
 * Copyright 2008-2020 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.cpr;

import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.List;
import java.util.concurrent.TimeUnit;

/**
 * An {@link AtmosphereResource} encapsulates the mechanism to {@link #suspend()}, {@link #resume()} and
 * broadcast ({@link #getBroadcaster()}) messages among suspended resources. {@link AtmosphereResource}s are passed to
 * an instance of {@link AtmosphereHandler} at runtime.
 *
 * @author Jeanfrancois Arcand
 */
public interface AtmosphereResource {

    enum TRANSPORT {POLLING, LONG_POLLING, STREAMING, WEBSOCKET, JSONP, UNDEFINED, SSE, AJAX, HTMLFILE, CLOSE}

    /**
     * Return the current {@link TRANSPORT}. The transport value is retrieved using the {@link HeaderConfig#X_ATMOSPHERE_TRANSPORT}
     * header value.
     */
    TRANSPORT transport();

    /**
     * Set to true to resume the response after the first broadcast. False by default.
     *
     * @param resumeOnBroadcast
     */
    AtmosphereResource resumeOnBroadcast(boolean resumeOnBroadcast);

    /**
     * Return true if the {@link org.atmosphere.cpr.AtmosphereResource#suspend()} has been invoked.
     *
     * @return true if the {@link org.atmosphere.cpr.AtmosphereResource#suspend()} has been invoked
     */
    boolean isSuspended();

    /**
     * Return true if this AtmosphereResource is resumed after the first broadcast.
     *
     * @see org.atmosphere.cpr.AtmosphereResource#resumeOnBroadcast()
     */
    boolean resumeOnBroadcast();

    /**
     * Return true if this object has been resumed.
     *
     * @return true if this object has been resumed
     */
    boolean isResumed();

    /**
     * Return true if this object has been cancelled.
     *
     * @return true if this object has been cancelled
     */
    boolean isCancelled();

    /**
     * Complete the {@link AtmosphereResponse} and finish/commit it. If the {@link AtmosphereResponse} is in the
     * process of being resumed, invoking this method has no effect.
     */
    AtmosphereResource resume();

    /**
     * Suspend the {@link AtmosphereResponse} indefinitely.
     * Suspending a {@link AtmosphereResponse} will tell the underlying container to avoid recycling objects associated
     * with the current instance, and also to avoid committing a response.
     * 

* The Framework will output some HTML comments when suspending the response in order to make sure all browsers * work well with suspended responses. */ AtmosphereResource suspend(); /** * Suspend the {@link AtmosphereResponse}. Suspending a {@link AtmosphereResponse} will tell the underlying * container to avoid recycling objects associated with the current instance, and also to avoid committing response. * Invoking this method when a request is being timed out (e.g. {@link AtmosphereResourceEvent#isResumedOnTimeout} * returns true) has no effect. *

* * @param timeout The maximum amount of time, in milliseconds, a {@link AtmosphereResponse} can be suspended. When * the timeout expires, the {@link AtmosphereResponse} will be automatically resumed and committed. * Usage of any methods of a {@link AtmosphereResponse} that times out will throw an {@link IllegalStateException}. */ AtmosphereResource suspend(long timeout); /** * Suspend the {@link AtmosphereResponse}. Suspending a {@link AtmosphereResponse} will tell the underlying * container to avoid recycling objects associated with the current instance, and also to avoid committing response. * Invoking this method when a request is being timed out (e.g. {@link AtmosphereResourceEvent#isResumedOnTimeout} * returns true) has no effect. *

* * @param timeout The maximum amount of time a {@link AtmosphereResponse} can be suspended. When the timeout * expires, the {@link AtmosphereResponse} will be automatically resumed and committed. Usage of any * methods of a {@link AtmosphereResponse} that times out will throw an {@link IllegalStateException}. * @param timeunit The time unit of the timeout value */ AtmosphereResource suspend(long timeout, TimeUnit timeunit); /** * Return the underlying {@link AtmosphereRequest} request. * * @return {@link AtmosphereRequest} the underlying request. */ AtmosphereRequest getRequest(); /** * Return the {@link AtmosphereResponse}. * * @return {@link AtmosphereResponse} the underlying response. */ AtmosphereResponse getResponse(); /** * Return the {@link AtmosphereConfig}. * * @return the {@link AtmosphereConfig} */ AtmosphereConfig getAtmosphereConfig(); /** * Return the first added {@link Broadcaster}. * * @return the current {@link Broadcaster} */ Broadcaster getBroadcaster(); /** * Return an unmodifiable list of {@link Broadcaster}s associated with this resource * * @return an unmodifiable list of {@link Broadcaster} */ List broadcasters(); /** * Remove this {@link org.atmosphere.cpr.AtmosphereResource} from all {@link org.atmosphere.cpr.Broadcaster} * * @return this */ public AtmosphereResource removeFromAllBroadcasters(); /** * Set the first {@link Broadcaster} associated with this resource. This {@link org.atmosphere.cpr.Broadcaster} * will be returned when {@link #getBroadcaster()} is invoked. * * @param broadcaster * @return this */ AtmosphereResource setBroadcaster(Broadcaster broadcaster); /** * Add/Associate a {@link org.atmosphere.cpr.Broadcaster} with this resource. * * @param broadcaster * @return this */ AtmosphereResource addBroadcaster(Broadcaster broadcaster); /** * Remove a {@link org.atmosphere.cpr.Broadcaster} with this resource. * * @param broadcaster * @return this */ AtmosphereResource removeBroadcaster(Broadcaster broadcaster); /** * Set the {@link Serializer} to use when {@link AtmosphereResource#write} execute the operation. * By default, the {@link Serializer} is null. * * @param s the {@link Serializer} * @return this */ AtmosphereResource setSerializer(Serializer s); /** * Write the String. If {@link #resumeOnBroadcast()} is true, the underlying connection will be resumed (@link #resume()); * * @param s * @return this */ AtmosphereResource write(String s); /** * Write the bytes If {@link #resumeOnBroadcast()} is true, the underlying connection will be resumed (@link #resume()); * * @param s * @return this */ AtmosphereResource write(byte[] s); /** * Get the {@link Serializer} or null if not defined. * * @return the {@link Serializer} or null if not defined */ Serializer getSerializer(); /** * Return the current {@link AtmosphereResourceEvent}. */ AtmosphereResourceEvent getAtmosphereResourceEvent(); /** * Return the associated {@link AtmosphereHandler} associated with this resource. * * @return the associated {@link AtmosphereHandler} associated with this resource */ AtmosphereHandler getAtmosphereHandler(); /** * Set a message that will be written when the resource times out. Can be an {@link Object} or {@link java.util.concurrent.Callable}. * * @return this */ AtmosphereResource writeOnTimeout(Object o); /** * Return the object that will be written when the resource times out. */ Object writeOnTimeout(); /** * Return the unique ID associated with this AtmosphereResource. * * @return the unique ID associated with this AtmosphereResource */ String uuid(); /** * Add a {@link AtmosphereResourceEventListener}. * * @param e an instance of AtmosphereResourceEventListener * @return this */ AtmosphereResource addEventListener(AtmosphereResourceEventListener e); /** * Remove a {@link AtmosphereResourceEventListener}. * * @param e * @return this */ AtmosphereResource removeEventListener(AtmosphereResourceEventListener e); /** * Remove all {@link AtmosphereResourceEventListener}s. * * @return this */ AtmosphereResource removeEventListeners(); /** * Notify all {@link AtmosphereResourceEventListener}. * * @param e an instance of AtmosphereResourceEvent * @return this */ AtmosphereResource notifyListeners(AtmosphereResourceEvent e); /** * Notify all {@link AtmosphereResourceEventListener}s. * * @return this */ AtmosphereResource notifyListeners(); /** * Return the {@link HttpSession} if supported, null if not * * @return the {@link HttpSession} if supported, null if not */ HttpSession session(); /** * Return the {@link HttpSession} if supported, and creates it if not already created. * * @return the {@link HttpSession} if supported, and creates it if not already created */ HttpSession session(boolean create); /** * Close the underlying connection. Invoking this method will close the underlying connection and resume the * {@link AtmosphereResource}}. */ void close() throws IOException; /** * Force binary write and never write String value. * return this */ AtmosphereResource forceBinaryWrite(boolean force); /** * Return true when binary write is forced. * * @return true when binary write is forced. */ boolean forceBinaryWrite(); /** * Initialize an {@link AtmosphereResource}. * * @param config The {@link org.atmosphere.cpr.AtmosphereConfig} * @param broadcaster The {@link org.atmosphere.cpr.Broadcaster}. * @param req The {@link AtmosphereRequest} * @param response The {@link AtmosphereResource} * @param asyncSupport The {@link AsyncSupport} * @param atmosphereHandler The {@link AtmosphereHandler} * @return this */ public AtmosphereResource initialize(AtmosphereConfig config, Broadcaster broadcaster, AtmosphereRequest req, AtmosphereResponse response, AsyncSupport asyncSupport, AtmosphereHandler atmosphereHandler); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy