Configured a check for configs before starting XMPP or MQTT

Shabirmean 9 years ago
parent a392dd799b
commit d2afed15f0

@ -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,17 +100,21 @@ public class ArduinoService {
final ArduinoMQTTSubscriber arduinoMQTTSubscriber) { final ArduinoMQTTSubscriber arduinoMQTTSubscriber) {
this.arduinoMQTTSubscriber = arduinoMQTTSubscriber; this.arduinoMQTTSubscriber = arduinoMQTTSubscriber;
Runnable xmppStarter = new Runnable() { if (MqttConfig.getInstance().isEnabled()) {
@Override Runnable xmppStarter = new Runnable() {
public void run() { @Override
arduinoMQTTSubscriber.initConnector(); public void run() {
arduinoMQTTSubscriber.connectAndSubscribe(); arduinoMQTTSubscriber.initConnector();
} arduinoMQTTSubscriber.connectAndSubscribe();
}; }
};
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;
@ -34,10 +36,15 @@ public class DroneRealTimeService {
private MessageTransformer messageController; private MessageTransformer messageController;
private DroneAnalyzerXMPPConnector xmppConnector; private DroneAnalyzerXMPPConnector xmppConnector;
public DroneRealTimeService(){ public DroneRealTimeService() {
messageController = new MessageTransformer(); messageController = new MessageTransformer();
xmppConnector = new DroneAnalyzerXMPPConnector(messageController); xmppConnector = new DroneAnalyzerXMPPConnector(messageController);
xmppConnector.connectLoginAndSetFilterOnReceiver();
if (XmppConfig.getInstance().isEnabled()){
xmppConnector.connectLoginAndSetFilterOnReceiver();
} else {
log.warn("XMPP disabled in 'devicemgt-config.xml'. Hence, VirtualFireAlarmXMPPConnector not started.");
}
} }

@ -32,6 +32,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;
@ -71,8 +72,8 @@ import java.util.List;
import java.util.UUID; import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
@API( name="raspberrypi", version="1.0.0", context="/raspberrypi") @API(name = "raspberrypi", version = "1.0.0", context = "/raspberrypi")
@DeviceType( value = "raspberrypi") @DeviceType(value = "raspberrypi")
public class RaspberryPiService { public class RaspberryPiService {
private static Log log = LogFactory.getLog(RaspberryPiService.class); private static Log log = LogFactory.getLog(RaspberryPiService.class);
@ -96,17 +97,21 @@ public class RaspberryPiService {
final RaspberryPiMQTTSubscriber raspberryPiMQTTSubscriber) { final RaspberryPiMQTTSubscriber raspberryPiMQTTSubscriber) {
this.raspberryPiMQTTSubscriber = raspberryPiMQTTSubscriber; this.raspberryPiMQTTSubscriber = raspberryPiMQTTSubscriber;
Runnable xmppStarter = new Runnable() { if (MqttConfig.getInstance().isEnabled()) {
@Override Runnable xmppStarter = new Runnable() {
public void run() { @Override
raspberryPiMQTTSubscriber.initConnector(); public void run() {
raspberryPiMQTTSubscriber.connectAndSubscribe(); raspberryPiMQTTSubscriber.initConnector();
} raspberryPiMQTTSubscriber.connectAndSubscribe();
}; }
};
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.");
}
} }
/** /**

@ -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;
@ -83,8 +84,8 @@ import java.util.List;
import java.util.UUID; import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
@API( name="virtual_firealarm", version="1.0.0", context="/virtual_firealarm") @API(name = "virtual_firealarm", version = "1.0.0", context = "/virtual_firealarm")
@DeviceType( value = "virtual_firealarm") @DeviceType(value = "virtual_firealarm")
public class VirtualFireAlarmService { public class VirtualFireAlarmService {
private static Log log = LogFactory.getLog(VirtualFireAlarmService.class); private static Log log = LogFactory.getLog(VirtualFireAlarmService.class);
@ -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,48 +115,43 @@ 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;
Runnable mqttStarter = new Runnable() { if (MqttConfig.getInstance().isEnabled()) {
@Override Runnable mqttStarter = new Runnable() {
public void run() { @Override
virtualFireAlarmXMPPConnector.initConnector(); public void run() {
virtualFireAlarmXMPPConnector.connect(); virtualFireAlarmXMPPConnector.initConnector();
} virtualFireAlarmXMPPConnector.connect();
}; }
};
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() { virtualFireAlarmMQTTConnector.connect();
// @Override } else {
// public void run() { log.warn("XMPP disabled in 'devicemgt-config.xml'. Hence, VirtualFireAlarmXMPPConnector not started.");
virtualFireAlarmMQTTConnector.connect(); }
// }
// };
//
// 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
@ -648,7 +629,6 @@ public class VirtualFireAlarmService {
/** /**
*
* @param owner * @param owner
* @param deviceId * @param deviceId
* @param protocol * @param protocol
@ -657,8 +637,8 @@ public class VirtualFireAlarmService {
*/ */
@Path("controller/readhumidity") @Path("controller/readhumidity")
@GET @GET
@Feature( code="VIRTUALFIREALARM_READHUMIDITY", name="Read Humidity", type = "monitor", @Feature(code = "VIRTUALFIREALARM_READHUMIDITY", name = "Read Humidity", type = "monitor",
description="Read Humidity Readings from Virtual Fire Alarm") description = "Read Humidity Readings from Virtual Fire Alarm")
public String requestHumidity(@HeaderParam("owner") String owner, public String requestHumidity(@HeaderParam("owner") String owner,
@HeaderParam("deviceId") String deviceId, @HeaderParam("deviceId") String deviceId,
@HeaderParam("protocol") String protocol, @HeaderParam("protocol") String protocol,
@ -695,7 +675,8 @@ public class VirtualFireAlarmService {
} }
replyMsg = VirtualFireAlarmServiceUtils.sendCommandViaHTTP(deviceHTTPEndpoint, replyMsg = VirtualFireAlarmServiceUtils.sendCommandViaHTTP(deviceHTTPEndpoint,
VirtualFireAlarmConstants.HUMIDITY_CONTEXT, VirtualFireAlarmConstants
.HUMIDITY_CONTEXT,
false); false);
break; break;
@ -727,7 +708,6 @@ public class VirtualFireAlarmService {
/** /**
*
* @param owner * @param owner
* @param deviceId * @param deviceId
* @param protocol * @param protocol
@ -738,8 +718,8 @@ public class VirtualFireAlarmService {
@GET @GET
@Consumes(MediaType.APPLICATION_JSON) @Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON) @Produces(MediaType.APPLICATION_JSON)
@Feature( code="VIRTUALFIREALARM_REQTEMP", name="Request Tempreature", type = "monitor", @Feature(code = "VIRTUALFIREALARM_REQTEMP", name = "Request Tempreature", type = "monitor",
description="Request Tempreature reading from Virtual Fire Alarm") description = "Request Tempreature reading from Virtual Fire Alarm")
public SensorRecord requestTemperature(@HeaderParam("owner") String owner, public SensorRecord requestTemperature(@HeaderParam("owner") String owner,
@HeaderParam("deviceId") String deviceId, @HeaderParam("deviceId") String deviceId,
@HeaderParam("protocol") String protocol, @HeaderParam("protocol") String protocol,
@ -760,7 +740,7 @@ public class VirtualFireAlarmService {
if (log.isDebugEnabled()) { if (log.isDebugEnabled()) {
log.debug("Sending request to read virtual-firealarm-temperature of device " + log.debug("Sending request to read virtual-firealarm-temperature of device " +
"[" + deviceId + "] via " + protocolString); "[" + deviceId + "] via " + protocolString);
} }
try { try {
@ -772,9 +752,9 @@ public class VirtualFireAlarmService {
} }
String temperatureValue = VirtualFireAlarmServiceUtils.sendCommandViaHTTP( String temperatureValue = VirtualFireAlarmServiceUtils.sendCommandViaHTTP(
deviceHTTPEndpoint, deviceHTTPEndpoint,
VirtualFireAlarmConstants.TEMPERATURE_CONTEXT, VirtualFireAlarmConstants.TEMPERATURE_CONTEXT,
false); false);
SensorDataManager.getInstance().setSensorRecord(deviceId, SensorDataManager.getInstance().setSensorRecord(deviceId,
VirtualFireAlarmConstants.SENSOR_TEMP, VirtualFireAlarmConstants.SENSOR_TEMP,
@ -806,7 +786,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param dataMsg * @param dataMsg
* @param response * @param response
*/ */
@ -823,12 +802,12 @@ public class VirtualFireAlarmService {
if (registeredIp == null) { if (registeredIp == null) {
log.warn("Unregistered IP: Temperature Data Received from an un-registered IP " + log.warn("Unregistered IP: Temperature Data Received from an un-registered IP " +
deviceIp + " for device ID - " + deviceId); deviceIp + " for device ID - " + deviceId);
response.setStatus(Response.Status.PRECONDITION_FAILED.getStatusCode()); response.setStatus(Response.Status.PRECONDITION_FAILED.getStatusCode());
return; return;
} else if (!registeredIp.equals(deviceIp)) { } else if (!registeredIp.equals(deviceIp)) {
log.warn("Conflicting IP: Received IP is " + deviceIp + ". Device with ID " + deviceId + log.warn("Conflicting IP: Received IP is " + deviceIp + ". Device with ID " + deviceId +
" is already registered under some other IP. Re-registration required"); " is already registered under some other IP. Re-registration required");
response.setStatus(Response.Status.CONFLICT.getStatusCode()); response.setStatus(Response.Status.CONFLICT.getStatusCode());
return; return;
} }
@ -844,7 +823,6 @@ public class VirtualFireAlarmService {
/** /**
*
* @param operation * @param operation
* @param message * @param message
* @return * @return
@ -927,7 +905,6 @@ public class VirtualFireAlarmService {
} }
/** /**
*
* @param operation * @param operation
* @param inputStream * @param inputStream
* @return * @return

@ -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