import org.argeo.slc.runtime.SlcAgentDescriptor;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.InitializingBean;
+import org.springframework.jms.JmsException;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessagePostProcessor;
}
public void afterPropertiesSet() throws Exception {
- jmsTemplate.convertAndSend(agentRegister, agentDescriptor);
- log.info("Agent #" + agentDescriptor.getUuid() + " registered to "
- + agentRegister);
+ try {
+ jmsTemplate.convertAndSend(agentRegister, agentDescriptor);
+ log.info("Agent #" + agentDescriptor.getUuid() + " registered to "
+ + agentRegister);
+ } catch (JmsException e) {
+ log
+ .warn("Could not register agent "
+ + agentDescriptor.getUuid()
+ + " to server: "
+ + e.getMessage()
+ + ". The agent will stay offline but will keep listening for a ping all sent by server.");
+ if (log.isTraceEnabled())
+ log.debug("Original error.", e);
+ }
}
public void destroy() throws Exception {
- jmsTemplate.convertAndSend(agentUnregister, agentDescriptor);
- log.info("Agent #" + agentDescriptor.getUuid() + " unregistered from "
- + agentUnregister);
+ try {
+ jmsTemplate.convertAndSend(agentUnregister, agentDescriptor);
+ log.info("Agent #" + agentDescriptor.getUuid()
+ + " unregistered from " + agentUnregister);
+ } catch (JmsException e) {
+ log.warn("Could not unregister agent " + agentDescriptor.getUuid()
+ + ": " + e.getMessage());
+ if (log.isTraceEnabled())
+ log.debug("Original error.", e);
+ }
}
public void setAgentRegister(Destination agentRegister) {
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Session;
+import javax.jms.TextMessage;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
msg.setStringProperty(JmsAgent.PROPERTY_QUERY, query);
msg.setJMSCorrelationID(correlationId);
setArguments(msg);
+ if (msg instanceof TextMessage) {
+ TextMessage textMessage = (TextMessage) msg;
+ if (textMessage.getText() == null) {
+ // TODO: remove workaround when upgrading to ActiveMQ 5.3
+ // Workaround for
+ // https://issues.apache.org/activemq/browse/AMQ-2046
+ textMessage.setText("");
+ }
+ }
return msg;
}