org.cometd.bayeux.Session Maven / Gradle / Ivy
/*
* Copyright (c) 2008-2016 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();
}