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

org.cometd.bayeux.Session Maven / Gradle / Ivy

/*
 * Copyright (c) 2010 the original author or authors.
 *
 * 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.cometd.bayeux;

import java.util.Set;

/**
 * 

A Bayeux session represents a connection between a bayeux client and a bayeux server.

*

This interface is the common base interface for both the server side and the client side * representations of a session:

*
    *
  • if the remote client is not a Java client, then only a {@link org.cometd.bayeux.server.ServerSession} * instance will exist on the server and represents the remote client.
  • *
  • if the remote client is a Java client, then a {@link org.cometd.bayeux.client.ClientSession} * instance will exist on the client and a {@link org.cometd.bayeux.server.ServerSession} * instance will exist on the server, linked by the same clientId.
  • *
  • if the client is a Java client, but it is located in the server, then the * {@link org.cometd.bayeux.client.ClientSession} instance will be an instance * of {@link org.cometd.bayeux.server.LocalSession} and will be associated * with a {@link org.cometd.bayeux.server.ServerSession} instance.
  • *
*/ public interface Session { /** *

The clientId of the session.

*

This would more correctly be called a "sessionId", but for * backwards compatibility with the Bayeux protocol, it is a field called "clientId" * that identifies a session. * @return the id of this session */ String getId(); /** *

A connected session is a session where the link between the client and the server * has been established.

* @return whether the session is connected * @see #disconnect() */ boolean isConnected(); /** *

A handshook session is a session where the handshake has successfully completed> * @return whether the session is handshook */ boolean isHandshook(); /** * Disconnects this session, ending the link between the client and the server peers. * @see #isConnected() */ void disconnect(); /** *

Sets a named session attribute value.

*

Session attributes are convenience data that allows arbitrary * application data to be associated with a session.

* @param name the attribute name * @param value the attribute value */ void setAttribute(String name, Object value); /** *

Retrieves the value of named session attribute.

* @param name the name of the attribute * @return the attribute value or null if the attribute is not present */ Object getAttribute(String name); /** * @return the list of session attribute names. */ Set getAttributeNames(); /** *

Removes a named session attribute.

* @param name the name of the attribute * @return the value of the attribute */ Object removeAttribute(String name); /** *

Executes the given command in a batch so that any Bayeux message sent * by the command (via the Bayeux API) is queued up until the end of the * command and then all messages are sent at once.

* @param batch the Runnable to run as a batch */ void batch(Runnable batch); /** *

Starts a batch, to be ended with {@link #endBatch()}.

*

The {@link #batch(Runnable)} method should be preferred since it automatically * starts and ends a batch without relying on a try/finally block.

*

This method is to be used in the cases where the use of {@link #batch(Runnable)} * is not possible or would make the code more complex.

* @see #endBatch() * @see #batch(Runnable) */ void startBatch(); /** *

Ends a batch started with {@link #startBatch()}.

* @return true if the batch ended and there were messages to send. * @see #startBatch() */ boolean endBatch(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy