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

net.roboconf.dm.management.api.IMessagingMngr Maven / Gradle / Ivy

There is a newer version: 0.9.1
Show newest version
/**
 * Copyright 2015-2016 Linagora, Université Joseph Fourier, Floralis
 *
 * The present code is developed in the scope of the joint LINAGORA -
 * Université Joseph Fourier - Floralis research program and is designated
 * as a "Result" pursuant to the terms and conditions of the LINAGORA
 * - Université Joseph Fourier - Floralis research program. Each copyright
 * holder of Results enumerated here above fully & independently holds complete
 * ownership of the complete Intellectual Property rights applicable to the whole
 * of said Results, and may freely exploit it in any manner which does not infringe
 * the moral rights of the other copyright holders.
 *
 * 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 net.roboconf.dm.management.api;

import java.io.IOException;

import net.roboconf.core.model.beans.Instance;
import net.roboconf.dm.management.ManagedApplication;
import net.roboconf.messaging.api.business.IDmClient;
import net.roboconf.messaging.api.messages.Message;

/**
 * @author Vincent Zurczak - Linagora
 */
public interface IMessagingMngr {

	/**
	 * Sends a message to the DM.
	 * @param message the message to send
	 * @throws IOException if an error occurred with the messaging
	 */
	void sendMessageToTheDm( Message message ) throws IOException;


	/**
	 * Sends a message to an agent in safe mode.
	 * 

* This method is the safest in terms of reliability. * Indeed, if the instance's machine is not marked as available, the message is cached * until the machine is online. Same thing is the messaging is not available at the moment. *

* * @param ma the managed application * @param message the message to send (or store) * @param instance the target instance * @throws IOException if an error occurred with the messaging */ void sendMessageSafely( ManagedApplication ma, Instance instance, Message message ) throws IOException; /** * Sends a message directly to an agent. *

* Unlike {@link #sendMessageSafely(ManagedApplication, Instance, Message)}, * this method does not perform any check when sending a message. It directly * uses the Roboconf messaging API to send a message. *

* * @param ma the managed application * @param message the message to send (or store) * @param instance the target instance * @throws IOException if an error occurred with the messaging */ void sendMessageDirectly( ManagedApplication ma, Instance scopedInstance, Message message ) throws IOException; /** * A convenience method that sends/flushes messages that were stored for a given application/instance. *

* This method checks a messaging client is available. It also verifies the target scoped * instance is deployed and started. Eventually, if a message fails to be sent, it is reinserted * into the storage queue, which means a further invocation will try to send this message again. * This guarantees no message is lost due to messaging issues on the DM side. *

*

* This method is based upon the Roboconf messaging implementations, which means it relies on * them to determiner if a message was correctly sent. Besides, the messaging API only verifies * a message left correctly, not that the agent received it. *

* * @param ma the managed application * @param instance the target instance */ void sendStoredMessages( ManagedApplication ma, Instance instance ); /** * @return the messaging client (can be null or not connected) */ IDmClient getMessagingClient(); /** * Checks the messaging configuration. * @throws IOException if the configuration is invalid */ void checkMessagingConfiguration() throws IOException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy