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

com.clearlydecoded.messenger.MessageProcessor Maven / Gradle / Ivy

/*
 * Copyright 2018 Yaakov Chaikin ([email protected]). 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 com.clearlydecoded.messenger;

/**
 * {@link MessageProcessor} interface defines methods which allow its implementations to do the
 * actual work of processing a concrete type of {@link Message} implementation and produce a
 * response that is a concrete implementation of {@link MessageResponse}.
 * 

* Clients of this framework should implement a concrete implementation of this interface for each * distinct type of {@link Message}/{@link MessageResponse} pair. *

*

* Warning! Implementations of this interface must account for the fact that the * execution of its code might happen in a multi-threaded environment. Do NOT assume that * a new instance of this processor will be created for each thread. In other words, * multiple threads might share the same instance of the processor. * *

* * @author Yaakov Chaikin ([email protected]) */ public interface MessageProcessor , MessageResponseT extends MessageResponse> { /** * Executes the message, producing message response of class type which is embedded * in the type of message. * * @param message Message object containing data which is needed for processing this message. * @return Message response object that represents a processed response to the * message. */ MessageResponseT process(MessageT message); /** * Retrieves message type identifier that this processor is able to process. * *

The type identifier must be unique system-wide and be identical to the value returned by * the {@link Message#getType()} method which is generically typed in the concrete implementation * of this processor.

* * @return Message type identifier that is unique system-wide and identical to the type identifier * of the concrete {@link Message} this processor is typed with. */ String getCompatibleMessageType(); /** * Retrieves class type of the message this processor is to able to process. * * @return Class type of the message this processor is able to process. */ Class getCompatibleMessage(); /** * Retrieves class type of the message response this processor is set to return. * * @return Class type of the message response this processor is set to return. */ Class getCompatibleMessageResponseClassType(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy