Merge pull request #94 from Shabirmean/IoTS-1.0.0-M1

Configured a check for configs before starting XMPP or MQTT
Ruwan 9 years ago
commit 77c32c84d5

@ -37,6 +37,7 @@ import org.wso2.carbon.device.mgt.iot.arduino.plugin.constants.ArduinoConstants;
import org.wso2.carbon.device.mgt.iot.arduino.service.dto.DeviceJSON; import org.wso2.carbon.device.mgt.iot.arduino.service.dto.DeviceJSON;
import org.wso2.carbon.device.mgt.iot.arduino.service.transport.ArduinoMQTTSubscriber; import org.wso2.carbon.device.mgt.iot.arduino.service.transport.ArduinoMQTTSubscriber;
import org.wso2.carbon.device.mgt.iot.arduino.service.util.ArduinoServiceUtils; import org.wso2.carbon.device.mgt.iot.arduino.service.util.ArduinoServiceUtils;
import org.wso2.carbon.device.mgt.iot.controlqueue.mqtt.MqttConfig;
import org.wso2.carbon.device.mgt.iot.exception.AccessTokenException; import org.wso2.carbon.device.mgt.iot.exception.AccessTokenException;
import org.wso2.carbon.device.mgt.iot.exception.DeviceControllerException; import org.wso2.carbon.device.mgt.iot.exception.DeviceControllerException;
import org.wso2.carbon.device.mgt.iot.sensormgt.SensorDataManager; import org.wso2.carbon.device.mgt.iot.sensormgt.SensorDataManager;
@ -99,6 +100,7 @@ public class ArduinoService {
final ArduinoMQTTSubscriber arduinoMQTTSubscriber) { final ArduinoMQTTSubscriber arduinoMQTTSubscriber) {
this.arduinoMQTTSubscriber = arduinoMQTTSubscriber; this.arduinoMQTTSubscriber = arduinoMQTTSubscriber;
if (MqttConfig.getInstance().isEnabled()) {
Runnable xmppStarter = new Runnable() { Runnable xmppStarter = new Runnable() {
@Override @Override
public void run() { public void run() {
@ -110,6 +112,9 @@ public class ArduinoService {
Thread xmppStarterThread = new Thread(xmppStarter); Thread xmppStarterThread = new Thread(xmppStarter);
xmppStarterThread.setDaemon(true); xmppStarterThread.setDaemon(true);
xmppStarterThread.start(); xmppStarterThread.start();
} else {
log.warn("MQTT disabled in 'devicemgt-config.xml'. Hence, ArduinoMQTTSubscriber not started.");
}
} }
/** /**

@ -24,6 +24,7 @@ import org.wso2.carbon.apimgt.annotations.api.API;
import org.wso2.carbon.apimgt.annotations.device.DeviceType; import org.wso2.carbon.apimgt.annotations.device.DeviceType;
import org.wso2.carbon.apimgt.annotations.device.feature.Feature; import org.wso2.carbon.apimgt.annotations.device.feature.Feature;
import org.wso2.carbon.device.mgt.common.DeviceManagementException; import org.wso2.carbon.device.mgt.common.DeviceManagementException;
import org.wso2.carbon.device.mgt.iot.controlqueue.mqtt.MqttConfig;
import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.exception.DigitalDisplayException; import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.exception.DigitalDisplayException;
import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.transport.CommunicationHandlerException; import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.transport.CommunicationHandlerException;
import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.util.DigitalDisplayMqttCommunicationHandler; import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.util.DigitalDisplayMqttCommunicationHandler;
@ -54,9 +55,12 @@ public class DigitalDisplayControllerService {
public void setDigitalDisplayMqttCommunicationHandler( public void setDigitalDisplayMqttCommunicationHandler(
DigitalDisplayMqttCommunicationHandler digitalDisplayMqttCommunicationHandler) { DigitalDisplayMqttCommunicationHandler digitalDisplayMqttCommunicationHandler) {
DigitalDisplayControllerService.digitalDisplayMqttCommunicationHandler = digitalDisplayMqttCommunicationHandler; DigitalDisplayControllerService.digitalDisplayMqttCommunicationHandler = digitalDisplayMqttCommunicationHandler;
if (MqttConfig.getInstance().isEnabled()) {
digitalDisplayMqttCommunicationHandler.connect(); digitalDisplayMqttCommunicationHandler.connect();
} else {
log.warn("MQTT disabled in 'devicemgt-config.xml'. " +
"Hence, DigitalDisplayMqttCommunicationHandler not started.");
}
} }
/** /**

@ -15,10 +15,6 @@ import java.util.UUID;
import java.util.concurrent.ScheduledFuture; import java.util.concurrent.ScheduledFuture;
/**
* Created by nuwan on 11/16/15.
*/
public class DigitalDisplayMqttCommunicationHandler extends MQTTCommunicationHandler { public class DigitalDisplayMqttCommunicationHandler extends MQTTCommunicationHandler {
private static Log log = LogFactory.getLog(DigitalDisplayMqttCommunicationHandler.class); private static Log log = LogFactory.getLog(DigitalDisplayMqttCommunicationHandler.class);

@ -19,6 +19,8 @@ package org.wso2.carbon.device.mgt.iot.droneanalyzer.service;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.wso2.carbon.device.mgt.iot.controlqueue.mqtt.MqttConfig;
import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppConfig;
import org.wso2.carbon.device.mgt.iot.droneanalyzer.plugin.constants.DroneConstants; import org.wso2.carbon.device.mgt.iot.droneanalyzer.plugin.constants.DroneConstants;
import org.wso2.carbon.device.mgt.iot.droneanalyzer.service.transport.DroneAnalyzerXMPPConnector; import org.wso2.carbon.device.mgt.iot.droneanalyzer.service.transport.DroneAnalyzerXMPPConnector;
import org.wso2.carbon.device.mgt.iot.droneanalyzer.service.trasformer.MessageTransformer; import org.wso2.carbon.device.mgt.iot.droneanalyzer.service.trasformer.MessageTransformer;
@ -37,7 +39,12 @@ public class DroneRealTimeService {
public DroneRealTimeService() { public DroneRealTimeService() {
messageController = new MessageTransformer(); messageController = new MessageTransformer();
xmppConnector = new DroneAnalyzerXMPPConnector(messageController); xmppConnector = new DroneAnalyzerXMPPConnector(messageController);
if (XmppConfig.getInstance().isEnabled()){
xmppConnector.connectLoginAndSetFilterOnReceiver(); xmppConnector.connectLoginAndSetFilterOnReceiver();
} else {
log.warn("XMPP disabled in 'devicemgt-config.xml'. Hence, VirtualFireAlarmXMPPConnector not started.");
}
} }

@ -33,6 +33,7 @@ import org.wso2.carbon.device.mgt.iot.DeviceManagement;
import org.wso2.carbon.device.mgt.iot.DeviceValidator; import org.wso2.carbon.device.mgt.iot.DeviceValidator;
import org.wso2.carbon.device.mgt.iot.apimgt.AccessTokenInfo; import org.wso2.carbon.device.mgt.iot.apimgt.AccessTokenInfo;
import org.wso2.carbon.device.mgt.iot.apimgt.TokenClient; import org.wso2.carbon.device.mgt.iot.apimgt.TokenClient;
import org.wso2.carbon.device.mgt.iot.controlqueue.mqtt.MqttConfig;
import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppAccount; import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppAccount;
import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppConfig; import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppConfig;
import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppServerClient; import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppServerClient;
@ -88,6 +89,7 @@ public class RaspberryPiService {
final RaspberryPiMQTTSubscriber raspberryPiMQTTSubscriber) { final RaspberryPiMQTTSubscriber raspberryPiMQTTSubscriber) {
this.raspberryPiMQTTSubscriber = raspberryPiMQTTSubscriber; this.raspberryPiMQTTSubscriber = raspberryPiMQTTSubscriber;
if (MqttConfig.getInstance().isEnabled()) {
Runnable xmppStarter = new Runnable() { Runnable xmppStarter = new Runnable() {
@Override @Override
public void run() { public void run() {
@ -99,6 +101,9 @@ public class RaspberryPiService {
Thread xmppStarterThread = new Thread(xmppStarter); Thread xmppStarterThread = new Thread(xmppStarter);
xmppStarterThread.setDaemon(true); xmppStarterThread.setDaemon(true);
xmppStarterThread.start(); xmppStarterThread.start();
} else {
log.warn("MQTT disabled in 'devicemgt-config.xml'. Hence, VirtualFireAlarmMQTTConnector not started.");
}
} }
/** /**

@ -71,7 +71,7 @@ public class FireAlarmXMPPCommunicator extends XMPPTransportHandler {
resource = agentManager.getAgentConfigs().getDeviceOwner(); resource = agentManager.getAgentConfigs().getDeviceOwner();
xmppDeviceJID = username + "@" + server; xmppDeviceJID = username + "@" + server;
xmppAdminJID = AgentConstants.XMPP_ADMIN_ACCOUNT_UNAME + "@" + server; xmppAdminJID = agentManager.getAgentConfigs().getServerName() + "_" + AgentConstants.DEVICE_TYPE + "@" + server;
Runnable connect = new Runnable() { Runnable connect = new Runnable() {
@ -187,19 +187,26 @@ public class FireAlarmXMPPCommunicator extends XMPPTransportHandler {
Runnable pushDataRunnable = new Runnable() { Runnable pushDataRunnable = new Runnable() {
@Override @Override
public void run() { public void run() {
Message xmppMessage = new Message();
try {
int currentTemperature = agentManager.getTemperature(); int currentTemperature = agentManager.getTemperature();
String payLoad = AgentConstants.TEMPERATURE_CONTROL + ":" + currentTemperature;
Message xmppMessage = new Message(); String message = AgentConstants.TEMPERATURE_CONTROL + ":" + currentTemperature;
String payLoad = AgentUtilOperations.prepareSecurePayLoad(message);
xmppMessage.setTo(xmppAdminJID); xmppMessage.setTo(xmppAdminJID);
xmppMessage.setSubject("PUBLISHER"); xmppMessage.setSubject("PUBLISHER");
xmppMessage.setBody(payLoad); xmppMessage.setBody(payLoad);
xmppMessage.setType(Message.Type.chat); xmppMessage.setType(Message.Type.chat);
sendXMPPMessage(xmppAdminJID, xmppMessage); sendXMPPMessage(xmppAdminJID, xmppMessage);
log.info(AgentConstants.LOG_APPENDER + "Message: '" + xmppMessage.getBody() + log.info(AgentConstants.LOG_APPENDER + "Message: '" + message + "' sent to XMPP JID - " +
"' sent to XMPP JID [" + xmppAdminJID + "] under subject [" + "[" + xmppAdminJID + "] under subject [" + xmppMessage.getSubject() + "].");
xmppMessage.getSubject() + "]"); } catch (AgentCoreOperationException e) {
log.warn(AgentConstants.LOG_APPENDER + "Preparing Secure payload failed for XMPP JID - " +
"[" + xmppAdminJID + "] with subject - [" + xmppMessage.getSubject() + "].");
}
} }
}; };

@ -36,6 +36,7 @@ import org.wso2.carbon.device.mgt.iot.DeviceManagement;
import org.wso2.carbon.device.mgt.iot.DeviceValidator; import org.wso2.carbon.device.mgt.iot.DeviceValidator;
import org.wso2.carbon.device.mgt.iot.apimgt.AccessTokenInfo; import org.wso2.carbon.device.mgt.iot.apimgt.AccessTokenInfo;
import org.wso2.carbon.device.mgt.iot.apimgt.TokenClient; import org.wso2.carbon.device.mgt.iot.apimgt.TokenClient;
import org.wso2.carbon.device.mgt.iot.controlqueue.mqtt.MqttConfig;
import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppAccount; import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppAccount;
import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppConfig; import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppConfig;
import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppServerClient; import org.wso2.carbon.device.mgt.iot.controlqueue.xmpp.XmppServerClient;
@ -104,9 +105,7 @@ public class VirtualFireAlarmService {
private VirtualFireAlarmXMPPConnector virtualFireAlarmXMPPConnector; private VirtualFireAlarmXMPPConnector virtualFireAlarmXMPPConnector;
private ConcurrentHashMap<String, String> deviceToIpMap = new ConcurrentHashMap<>(); private ConcurrentHashMap<String, String> deviceToIpMap = new ConcurrentHashMap<>();
/** /**
*
* @param verificationManager * @param verificationManager
*/ */
public void setVerificationManager( public void setVerificationManager(
@ -116,13 +115,13 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param virtualFireAlarmXMPPConnector * @param virtualFireAlarmXMPPConnector
*/ */
public void setVirtualFireAlarmXMPPConnector( public void setVirtualFireAlarmXMPPConnector(
final VirtualFireAlarmXMPPConnector virtualFireAlarmXMPPConnector) { final VirtualFireAlarmXMPPConnector virtualFireAlarmXMPPConnector) {
this.virtualFireAlarmXMPPConnector = virtualFireAlarmXMPPConnector; this.virtualFireAlarmXMPPConnector = virtualFireAlarmXMPPConnector;
if (MqttConfig.getInstance().isEnabled()) {
Runnable mqttStarter = new Runnable() { Runnable mqttStarter = new Runnable() {
@Override @Override
public void run() { public void run() {
@ -134,30 +133,25 @@ public class VirtualFireAlarmService {
Thread mqttStarterThread = new Thread(mqttStarter); Thread mqttStarterThread = new Thread(mqttStarter);
mqttStarterThread.setDaemon(true); mqttStarterThread.setDaemon(true);
mqttStarterThread.start(); mqttStarterThread.start();
} else {
log.warn("MQTT disabled in 'devicemgt-config.xml'. Hence, VirtualFireAlarmMQTTConnector not started.");
}
} }
/** /**
*
* @param virtualFireAlarmMQTTConnector * @param virtualFireAlarmMQTTConnector
*/ */
public void setVirtualFireAlarmMQTTConnector( public void setVirtualFireAlarmMQTTConnector(
final VirtualFireAlarmMQTTConnector virtualFireAlarmMQTTConnector) { final VirtualFireAlarmMQTTConnector virtualFireAlarmMQTTConnector) {
this.virtualFireAlarmMQTTConnector = virtualFireAlarmMQTTConnector; this.virtualFireAlarmMQTTConnector = virtualFireAlarmMQTTConnector;
if (XmppConfig.getInstance().isEnabled()) {
// Runnable xmppStarter = new Runnable() {
// @Override
// public void run() {
virtualFireAlarmMQTTConnector.connect(); virtualFireAlarmMQTTConnector.connect();
// } } else {
// }; log.warn("XMPP disabled in 'devicemgt-config.xml'. Hence, VirtualFireAlarmXMPPConnector not started.");
// }
// Thread xmppStarterThread = new Thread(xmppStarter);
// xmppStarterThread.setDaemon(true);
// xmppStarterThread.start();
} }
/** /**
*
* @return * @return
*/ */
public VerificationManager getVerificationManager() { public VerificationManager getVerificationManager() {
@ -165,7 +159,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @return * @return
*/ */
public VirtualFireAlarmXMPPConnector getVirtualFireAlarmXMPPConnector() { public VirtualFireAlarmXMPPConnector getVirtualFireAlarmXMPPConnector() {
@ -173,7 +166,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @return * @return
*/ */
public VirtualFireAlarmMQTTConnector getVirtualFireAlarmMQTTConnector() { public VirtualFireAlarmMQTTConnector getVirtualFireAlarmMQTTConnector() {
@ -186,7 +178,6 @@ public class VirtualFireAlarmService {
--------------------------------------------------------------------------------------- */ --------------------------------------------------------------------------------------- */
/** /**
*
* @param deviceId * @param deviceId
* @param name * @param name
* @param owner * @param owner
@ -238,7 +229,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param deviceId * @param deviceId
* @param response * @param response
*/ */
@ -267,7 +257,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param deviceId * @param deviceId
* @param name * @param name
* @param response * @param response
@ -312,7 +301,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param deviceId * @param deviceId
* @return * @return
*/ */
@ -340,7 +328,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param username * @param username
* @return * @return
*/ */
@ -377,7 +364,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param owner * @param owner
* @param customDeviceName * @param customDeviceName
* @param sketchType * @param sketchType
@ -411,7 +397,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param owner * @param owner
* @param customDeviceName * @param customDeviceName
* @param sketchType * @param sketchType
@ -439,7 +424,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param owner * @param owner
* @param customDeviceName * @param customDeviceName
* @param sketchType * @param sketchType
@ -507,7 +491,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @return * @return
*/ */
private static String shortUUID() { private static String shortUUID() {
@ -522,7 +505,6 @@ public class VirtualFireAlarmService {
--------------------------------------------------------------------------------------- */ --------------------------------------------------------------------------------------- */
/** /**
*
* @param owner * @param owner
* @param deviceId * @param deviceId
* @param deviceIP * @param deviceIP
@ -563,7 +545,6 @@ public class VirtualFireAlarmService {
Called by an external client intended to control the Virtual FireAlarm bulb */ Called by an external client intended to control the Virtual FireAlarm bulb */
/** /**
*
* @param owner * @param owner
* @param deviceId * @param deviceId
* @param protocol * @param protocol
@ -722,7 +703,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param owner * @param owner
* @param deviceId * @param deviceId
* @param protocol * @param protocol
@ -801,7 +781,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param dataMsg * @param dataMsg
* @param response * @param response
*/ */
@ -839,7 +818,6 @@ public class VirtualFireAlarmService {
/** /**
*
* @param operation * @param operation
* @param message * @param message
* @return * @return
@ -922,7 +900,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param operation * @param operation
* @param inputStream * @param inputStream
* @return * @return

@ -73,6 +73,7 @@ public class VirtualFireAlarmXMPPConnector extends XMPPTransportHandler {
public void createXMPPAccountForDeviceType() { public void createXMPPAccountForDeviceType() {
boolean accountExists = false; boolean accountExists = false;
XmppServerClient xmppServerClient = new XmppServerClient(); XmppServerClient xmppServerClient = new XmppServerClient();
xmppServerClient.initControlQueue();
try { try {
accountExists = xmppServerClient.doesXMPPUserAccountExist(xmppVFireAlarmAdminUsername); accountExists = xmppServerClient.doesXMPPUserAccountExist(xmppVFireAlarmAdminUsername);

@ -203,7 +203,10 @@ public abstract class MqttSubscriber implements MqttCallback {
*/ */
@Override @Override
public void connectionLost(Throwable throwable) { public void connectionLost(Throwable throwable) {
log.warn("Lost Connection for client: " + this.clientId + " to " + this.mqttBrokerEndPoint + ".\nThis was due to - " + throwable.getMessage()); if (log.isDebugEnabled()) {
log.warn("Lost Connection for client: " + this.clientId + " to " + this.mqttBrokerEndPoint +
".\nThis was due to - " + throwable.getMessage());
}
Runnable reSubscriber = new Runnable() { Runnable reSubscriber = new Runnable() {
@Override @Override
@ -219,8 +222,6 @@ public abstract class MqttSubscriber implements MqttCallback {
log.debug("Could not reconnect and subscribe to ControlQueue."); log.debug("Could not reconnect and subscribe to ControlQueue.");
} }
} }
} else {
return;
} }
} }
}; };
@ -263,7 +264,11 @@ public abstract class MqttSubscriber implements MqttCallback {
} }
String topic = iMqttDeliveryToken.getTopics()[0]; String topic = iMqttDeliveryToken.getTopics()[0];
String client = iMqttDeliveryToken.getClient().getClientId(); String client = iMqttDeliveryToken.getClient().getClientId();
log.info("Message - '" + message + "' of client [" + client + "] for the topic (" + topic + ") was delivered successfully.");
if (log.isDebugEnabled()) {
log.debug("Message - '" + message + "' of client [" + client + "] for the topic (" + topic +
") was delivered successfully.");
}
} }
/** /**

@ -62,7 +62,7 @@ public class XmppServerClient implements ControlQueueConnector {
} }
@Override @Override
public void initControlQueue() throws DeviceControllerException { public void initControlQueue() {
xmppEndpoint = XmppConfig.getInstance().getXmppEndpoint(); xmppEndpoint = XmppConfig.getInstance().getXmppEndpoint();
xmppUsername = XmppConfig.getInstance().getXmppUsername(); xmppUsername = XmppConfig.getInstance().getXmppUsername();
xmppPassword = XmppConfig.getInstance().getXmppPassword(); xmppPassword = XmppConfig.getInstance().getXmppPassword();

@ -285,9 +285,10 @@ public abstract class MQTTTransportHandler
*/ */
@Override @Override
public void connectionLost(Throwable throwable) { public void connectionLost(Throwable throwable) {
log.warn("Lost Connection for client: " + this.clientId + if (log.isDebugEnabled()) {
" to " + this.mqttBrokerEndPoint + ".\nThis was due to - " + log.warn("Lost Connection for client: " + this.clientId + " to " + this.mqttBrokerEndPoint + "." +
throwable.getMessage()); "\nThis was due to - " + throwable.getMessage());
}
Thread reconnectThread = new Thread() { Thread reconnectThread = new Thread() {
public void run() { public void run() {

Loading…
Cancel
Save