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

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

There is a newer version: 4.0.9
Show newest version
/*
 * Copyright (c) 2008-2015 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.Map;

/**
 * 

The Bayeux protocol exchange information by means of messages.

*

This interface represents the API of a Bayeux message, and consists * mainly of convenience methods to access the known fields of the message map.

*

This interface comes in both an immutable and {@link Mutable mutable} versions. * Mutability may be deeply enforced by an implementation, so that it is not correct * to cast a passed Message, to a Message.Mutable, even if the implementation * allows this.

*/ public interface Message extends Map { public static final String CLIENT_ID_FIELD = "clientId"; public static final String DATA_FIELD = "data"; public static final String CHANNEL_FIELD = "channel"; public static final String ID_FIELD = "id"; public static final String ERROR_FIELD = "error"; public static final String TIMESTAMP_FIELD = "timestamp"; public static final String TRANSPORT_FIELD = "transport"; public static final String ADVICE_FIELD = "advice"; public static final String SUCCESSFUL_FIELD = "successful"; public static final String SUBSCRIPTION_FIELD = "subscription"; public static final String EXT_FIELD = "ext"; public static final String CONNECTION_TYPE_FIELD = "connectionType"; public static final String VERSION_FIELD = "version"; public static final String MIN_VERSION_FIELD = "minimumVersion"; public static final String SUPPORTED_CONNECTION_TYPES_FIELD = "supportedConnectionTypes"; public static final String RECONNECT_FIELD = "reconnect"; public static final String INTERVAL_FIELD = "interval"; public static final String TIMEOUT_FIELD = "timeout"; public static final String RECONNECT_RETRY_VALUE = "retry"; public static final String RECONNECT_HANDSHAKE_VALUE = "handshake"; public static final String RECONNECT_NONE_VALUE = "none"; /** * Convenience method to retrieve the {@link #ADVICE_FIELD} * @return the advice of the message */ Map getAdvice(); /** * Convenience method to retrieve the {@link #CHANNEL_FIELD}. * Bayeux message always have a non null channel. * @return the channel of the message */ String getChannel(); /** * Convenience method to retrieve the {@link #CHANNEL_FIELD}. * Bayeux message always have a non null channel. * @return the channel of the message */ ChannelId getChannelId(); /** * Convenience method to retrieve the {@link #CLIENT_ID_FIELD} * @return the client id of the message */ String getClientId(); /** * Convenience method to retrieve the {@link #DATA_FIELD} * @return the data of the message * @see #getDataAsMap() */ Object getData(); /** * A messages that has a meta channel is dubbed a "meta message". * @return whether the channel's message is a meta channel */ boolean isMeta(); /** * Publish message replies contain the "successful" field * @return whether this message is a publish reply (as opposed to a published message) */ boolean isPublishReply(); /** * Convenience method to retrieve the {@link #SUCCESSFUL_FIELD} * @return whether the message is successful */ boolean isSuccessful(); /** * @return the data of the message as a map * @see #getData() */ Map getDataAsMap(); /** * Convenience method to retrieve the {@link #EXT_FIELD} * @return the ext of the message */ Map getExt(); /** * Convenience method to retrieve the {@link #ID_FIELD} * @return the id of the message */ String getId(); /** * @return this message as a JSON string */ String getJSON(); /** * The mutable version of a {@link Message} */ interface Mutable extends Message { /** * Convenience method to retrieve the {@link #ADVICE_FIELD} and create it if it does not exist * @param create whether to create the advice field if it does not exist * @return the advice of the message */ Map getAdvice(boolean create); /** * Convenience method to retrieve the {@link #DATA_FIELD} and create it if it does not exist * @param create whether to create the data field if it does not exist * @return the data of the message */ Map getDataAsMap(boolean create); /** * Convenience method to retrieve the {@link #EXT_FIELD} and create it if it does not exist * @param create whether to create the ext field if it does not exist * @return the ext of the message */ Map getExt(boolean create); /** * @param channel the channel of this message */ void setChannel(String channel); /** * @param clientId the client id of this message */ void setClientId(String clientId); /** * @param data the data of this message */ void setData(Object data); /** * @param id the id of this message */ void setId(String id); /** * @param successful the successfulness of this message */ void setSuccessful(boolean successful); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy