From 824c7005cc7d43bc861ab4228ff2434d25f95454 Mon Sep 17 00:00:00 2001
From: Nirothipan
Date: Tue, 4 Jul 2017 10:35:45 +0530
Subject: [PATCH] Removing Advance agent from virtual fire alarm
---
.../pom.xml | 253 ---
.../agent/advanced/Bootstrap.java | 36 -
.../http/FireAlarmHTTPCommunicator.java | 495 ------
.../mqtt/FireAlarmMQTTCommunicator.java | 300 ----
.../xmpp/FireAlarmXMPPCommunicator.java | 265 ---
.../advanced/core/AgentConfiguration.java | 156 --
.../agent/advanced/core/AgentConstants.java | 127 --
.../agent/advanced/core/AgentManager.java | 362 -----
.../advanced/core/AgentUtilOperations.java | 361 -----
.../enrollment/EnrollmentManager.java | 456 ------
.../AgentCoreOperationException.java | 57 -
.../agent/advanced/sidhdhi/SidhdhiQuery.java | 200 ---
.../transport/CommunicationUtils.java | 226 ---
.../advanced/transport/TransportHandler.java | 47 -
.../transport/TransportHandlerException.java | 56 -
.../advanced/transport/TransportUtils.java | 303 ----
.../transport/http/HTTPTransportHandler.java | 91 --
.../transport/mqtt/MQTTTransportHandler.java | 366 -----
.../transport/xmpp/XMPPTransportHandler.java | 366 -----
.../virtual/VirtualHardwareManager.java | 223 ---
.../agent/advanced/virtual/ui/AgentUI.java | 1034 ------------
.../src/main/resources/alarm-off.gif | Bin 4265 -> 0 bytes
.../src/main/resources/alarm-on.gif | Bin 12067 -> 0 bytes
.../src/main/resources/cep_query.txt | 11 -
.../main/resources/deviceConfig.properties | 35 -
.../src/main/resources/fireAlarmSound.mid | Bin 6719 -> 0 bytes
.../src/main/ui/build.xml | 73 -
.../src/main/ui/manifest.mf | 3 -
.../src/main/ui/nbproject/build-impl.xml | 1420 -----------------
.../src/main/ui/nbproject/genfiles.properties | 8 -
.../ui/nbproject/private/private.properties | 2 -
.../src/main/ui/nbproject/private/private.xml | 10 -
.../src/main/ui/nbproject/project.properties | 73 -
.../src/main/ui/nbproject/project.xml | 15 -
.../src/main/ui/src/bulb-on.jpg | Bin 6942 -> 0 bytes
.../mgt/iot/agent/virtual/VirtualAgentUI.java | 37 -
.../mgt/iot/agent/virtual/ui/AgentUI.form | 806 ----------
.../mgt/iot/agent/virtual/ui/AgentUI.java | 725 ---------
.../policy-edit.hbs | 18 -
.../policy-edit.json | 3 -
.../policy-view.hbs | 18 -
.../policy-view.json | 3 -
.../policy-wizard.hbs | 18 -
.../policy-wizard.json | 3 -
.../type-view.hbs | 60 +-
.../virtual-fire-alarm-plugin/pom.xml | 1 -
.../advanced_agent/deviceConfig.properties | 34 -
.../advanced_agent/sketch.properties | 2 -
.../resources/advanced_agent/start-device.bat | 7 -
.../resources/advanced_agent/start-device.sh | 190 ---
50 files changed, 25 insertions(+), 9330 deletions(-)
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/pom.xml
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/Bootstrap.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/http/FireAlarmHTTPCommunicator.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/mqtt/FireAlarmMQTTCommunicator.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/xmpp/FireAlarmXMPPCommunicator.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConfiguration.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConstants.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentManager.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentUtilOperations.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/enrollment/EnrollmentManager.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/exception/AgentCoreOperationException.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/sidhdhi/SidhdhiQuery.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/CommunicationUtils.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandler.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandlerException.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportUtils.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/http/HTTPTransportHandler.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/mqtt/MQTTTransportHandler.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/xmpp/XMPPTransportHandler.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/VirtualHardwareManager.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/ui/AgentUI.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/alarm-off.gif
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/alarm-on.gif
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/cep_query.txt
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/deviceConfig.properties
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/fireAlarmSound.mid
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/build.xml
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/manifest.mf
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/build-impl.xml
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/genfiles.properties
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.properties
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.xml
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.properties
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.xml
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/bulb-on.jpg
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/VirtualAgentUI.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.form
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.java
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.hbs
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.json
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.hbs
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.json
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.hbs
delete mode 100644 components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.json
delete mode 100644 features/device-types-feature/virtual-fire-alarm-plugin-feature/org.wso2.carbon.device.mgt.iot.virtualfirealarm.backend.feature/src/main/resources/advanced_agent/deviceConfig.properties
delete mode 100644 features/device-types-feature/virtual-fire-alarm-plugin-feature/org.wso2.carbon.device.mgt.iot.virtualfirealarm.backend.feature/src/main/resources/advanced_agent/sketch.properties
delete mode 100755 features/device-types-feature/virtual-fire-alarm-plugin-feature/org.wso2.carbon.device.mgt.iot.virtualfirealarm.backend.feature/src/main/resources/advanced_agent/start-device.bat
delete mode 100755 features/device-types-feature/virtual-fire-alarm-plugin-feature/org.wso2.carbon.device.mgt.iot.virtualfirealarm.backend.feature/src/main/resources/advanced_agent/start-device.sh
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/pom.xml b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/pom.xml
deleted file mode 100644
index 94520ad6d..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/pom.xml
+++ /dev/null
@@ -1,253 +0,0 @@
-
-
-
-
- 4.0.0
-
-
- virtual-fire-alarm-plugin
- org.wso2.carbon.devicemgt-plugins
- 4.0.17-SNAPSHOT
- ../pom.xml
-
-
- org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl
- WSO2 Carbon - IoT Server VirtualFireAlarm Advanced Agent
- WSO2 Carbon - VirtualFireAlarm Device Advanced Agent Implementation
- http://wso2.org
-
-
-
-
- org.apache.maven.plugins
- maven-compiler-plugin
-
- UTF-8
- ${wso2.maven.compiler.source}
- ${wso2.maven.compiler.target}
-
- 2.3.2
-
-
-
- org.apache.maven.plugins
- maven-assembly-plugin
-
-
-
-
- org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.Bootstrap
-
-
-
-
- jar-with-dependencies
-
- wso2-firealarm-virtual-agent-advanced
- false
-
-
-
- make-assembly
-
- package
-
-
- single
-
-
-
-
-
-
-
-
-
-
-
- org.eclipse.jetty
- jetty-server
- ${jetty.version}
-
-
-
-
- org.eclipse.paho
- org.eclipse.paho.client.mqttv3
- ${paho.mqtt.version}
-
-
-
-
- org.igniterealtime.smack.wso2
- smack
- ${smack.wso2.version}
-
-
- org.igniterealtime.smack.wso2
- smackx
- ${smackx.wso2.version}
-
-
-
-
- org.bouncycastle.wso2
- bcprov-jdk15on
- ${bcprov.wso2.version}
-
-
- org.bouncycastle.wso2
- bcpkix-jdk15on
- ${bcpkix.wso2.version}
-
-
-
-
- com.google.code.jscep.wso2
- jscep
- ${jscep.version}
-
-
-
- commons-codec
- commons-codec
-
-
-
- commons-lang
- commons-lang
- ${commons-lang.version}
-
-
-
- commons-logging
- commons-logging
- ${common-logging.version}
-
-
-
- commons-io
- commons-io
- ${commons.io}
-
-
-
-
- org.slf4j
- slf4j-api
- ${slf4j.version}
-
-
- org.slf4j
- slf4j-simple
- ${slf4j.version}
-
-
-
- org.json.wso2
- json
-
-
-
-
- org.wso2.siddhi
- siddhi-query
- ${sidhdhi.version}
-
-
- org.wso2.siddhi
- siddhi-core
- ${sidhdhi.version}
-
-
-
- org.apache.httpcomponents
- httpclient
- ${apache-httpclient.version}
-
-
-
- com.google.code.gson
- gson
- ${gson.version}
-
-
-
-
-
-
-
-
- wso2-nexus
- WSO2 internal Repository
- http://maven.wso2.org/nexus/content/groups/wso2-public/
-
- true
- daily
- ignore
-
-
-
- wso2-maven2-repository
- http://dist.wso2.org/maven2
-
-
-
-
-
- 1.7
- 1.7
-
-
- 8.1.3.v20120416
-
-
- 1.0.2
-
-
- 3.0.4.wso2v1
- 3.0.4.wso2v1
-
-
- 1.49.wso2v1
- 1.49.wso2v1
-
-
- 2.0.2.wso2v2
-
-
- 1.2.17
- 1.2
- 2.4
- 1.7
- 2.6
-
-
- 4.5
-
-
- 1.7.13
-
-
- 2.1.0-wso2v1
-
- 2.3.1
-
-
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/Bootstrap.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/Bootstrap.java
deleted file mode 100644
index 663a207f9..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/Bootstrap.java
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced;
-
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-
-public class Bootstrap {
-
- /**
- * @param args the command line arguments
- */
- public static void main(String[] args) {
- System.setProperty("org.apache.commons.logging.Log", "org.apache.commons.logging.impl.SimpleLog");
- System.setProperty("org.apache.commons.logging.simplelog.defaultlog", "info");
- System.setProperty("org.apache.commons.logging.simplelog.showdatetime", "true");
- System.setProperty("org.apache.commons.logging.simplelog.dateTimeFormat", "HH:mm:ss");
- AgentManager.getInstance().init();
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/http/FireAlarmHTTPCommunicator.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/http/FireAlarmHTTPCommunicator.java
deleted file mode 100644
index bc4a7bfb7..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/http/FireAlarmHTTPCommunicator.java
+++ /dev/null
@@ -1,495 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.communication.http;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.eclipse.jetty.http.HttpStatus;
-import org.eclipse.jetty.server.Request;
-import org.eclipse.jetty.server.handler.AbstractHandler;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentConstants;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.exception.AgentCoreOperationException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandlerException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportUtils;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.http.HTTPTransportHandler;
-
-import javax.servlet.ServletException;
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
-import java.io.DataOutputStream;
-import java.io.File;
-import java.io.IOException;
-import java.net.HttpURLConnection;
-import java.net.Inet4Address;
-import java.net.InetAddress;
-import java.net.NetworkInterface;
-import java.net.ProtocolException;
-import java.net.SocketException;
-import java.net.UnknownHostException;
-import java.util.Enumeration;
-import java.util.concurrent.Executors;
-import java.util.concurrent.ScheduledExecutorService;
-import java.util.concurrent.ScheduledFuture;
-import java.util.concurrent.TimeUnit;
-
-public class FireAlarmHTTPCommunicator extends HTTPTransportHandler {
- private static final Log log = LogFactory.getLog(FireAlarmHTTPCommunicator.class);
-
- private ScheduledExecutorService service = Executors.newScheduledThreadPool(2);
- private ScheduledFuture> dataPushServiceHandler;
- private ScheduledFuture> connectorServiceHandler;
-
- public FireAlarmHTTPCommunicator() {
- super();
- }
-
- public FireAlarmHTTPCommunicator(int port) {
- super(port);
- }
-
- public FireAlarmHTTPCommunicator(int port, int reconnectionInterval) {
- super(port, reconnectionInterval);
- }
-
- public ScheduledFuture> getDataPushServiceHandler() {
- return dataPushServiceHandler;
- }
-
- public void connect() {
- Runnable connect = new Runnable() {
- public void run() {
- if (!isConnected()) {
- try {
- processIncomingMessage();
- server.start();
- registerThisDevice();
- publishDeviceData();
- log.info("HTTP Server started at port: " + port);
-
- } catch (Exception e) {
- if (log.isDebugEnabled()) {
- log.warn("Unable to 'START' HTTP server. Will retry after " +
- timeoutInterval / 1000 + " seconds.");
- }
- }
- }
- }
- };
-
- connectorServiceHandler = service.scheduleAtFixedRate(connect, 0, timeoutInterval,
- TimeUnit.MILLISECONDS);
- }
-
-
- @Override
- public void processIncomingMessage() {
- server.setHandler(new AbstractHandler() {
- public void handle(String s, Request request, HttpServletRequest
- httpServletRequest,
- HttpServletResponse httpServletResponse)
- throws IOException, ServletException {
- httpServletResponse.setContentType("text/html;charset=utf-8");
- httpServletResponse.setStatus(HttpServletResponse.SC_OK);
- request.setHandled(true);
-
- AgentManager agentManager = AgentManager.getInstance();
- String pathContext = request.getPathInfo();
- String separator = (File.separatorChar == '\\') ? ("\\\\") : (File.separator);
-
- if (pathContext.toUpperCase().contains(
- separator + AgentConstants.TEMPERATURE_CONTROL)) {
- httpServletResponse.getWriter().println(
- agentManager.getTemperature());
-
- } else if (pathContext.toUpperCase().contains(
- separator + AgentConstants.HUMIDITY_CONTROL)) {
- httpServletResponse.getWriter().println(
- agentManager.getHumidity());
-
- } else if (pathContext.toUpperCase().contains(
- separator + AgentConstants.BULB_CONTROL)) {
- String[] pathVariables = pathContext.split(separator);
-
- if (pathVariables.length != 3) {
- httpServletResponse.getWriter().println(
- "Invalid BULB-control received by the device. Need to be in " +
- "'{host}:{port}/BULB/{ON|OFF}' format.");
- return;
- }
-
- String switchState = pathVariables[2];
-
- if (switchState == null) {
- httpServletResponse.getWriter().println(
- "Please specify switch-status of the BULB.");
- } else {
- boolean status = switchState.toUpperCase().equals(
- AgentConstants.CONTROL_ON);
- agentManager.changeAlarmStatus(status);
- httpServletResponse.getWriter().println("Bulb is " + (status ?
- AgentConstants.CONTROL_ON : AgentConstants.CONTROL_OFF));
- }
- } else {
- httpServletResponse.getWriter().println(
- "Invalid control command received by the device.");
- }
- }
- });
- }
-
- @Override
- public void publishDeviceData() {
- final AgentManager agentManager = AgentManager.getInstance();
- int publishInterval = agentManager.getPushInterval();
- final String deviceOwner = agentManager.getAgentConfigs().getDeviceOwner();
- final String deviceID = agentManager.getAgentConfigs().getDeviceId();
- boolean simulationMode = false;
- int duration = 2 * 60;
- int frequency = 5;
-
- Runnable pushDataRunnable = new Runnable() {
- @Override
- public void run() {
-
- String pushDataPayload = String.format(AgentConstants.PUSH_DATA_PAYLOAD, deviceOwner,
- deviceID, (agentManager.getDeviceIP() + ":" + port),
- agentManager.getTemperature());
- executeDataPush(pushDataPayload);
- }
- };
-
- if (!simulationMode) {
- dataPushServiceHandler = service.scheduleAtFixedRate(pushDataRunnable, publishInterval,
- publishInterval,
- TimeUnit.SECONDS);
- } else {
- String pushDataPayload = String.format(AgentConstants.PUSH_SIMULATION_DATA_PAYLOAD, deviceOwner,
- deviceID, (agentManager.getDeviceIP() + ":" + port),
- agentManager.getTemperature(), true, duration, frequency);
- executeDataPush(pushDataPayload);
-
- }
- }
-
-
- private void executeDataPush(String pushDataPayload) {
- AgentManager agentManager = AgentManager.getInstance();
- int responseCode = -1;
- String pushDataEndPointURL = agentManager.getPushDataAPIEP();
- HttpURLConnection httpConnection = null;
-
- try {
- httpConnection = TransportUtils.getHttpConnection(agentManager.getPushDataAPIEP());
- httpConnection.setRequestMethod(AgentConstants.HTTP_POST);
- httpConnection.setRequestProperty("Authorization", "Bearer " +
- agentManager.getAgentConfigs().getAuthToken());
- httpConnection.setRequestProperty("Content-Type",
- AgentConstants.APPLICATION_JSON_TYPE);
-
- httpConnection.setDoOutput(true);
- DataOutputStream dataOutPutWriter = new DataOutputStream(
- httpConnection.getOutputStream());
- dataOutPutWriter.writeBytes(pushDataPayload);
- dataOutPutWriter.flush();
- dataOutPutWriter.close();
-
- responseCode = httpConnection.getResponseCode();
- httpConnection.disconnect();
-
- log.info(AgentConstants.LOG_APPENDER + "Message - '" + pushDataPayload +
- "' was published to server at: " + httpConnection.getURL());
-
- } catch (ProtocolException exception) {
- String errorMsg =
- "Protocol specific error occurred when trying to set method to " +
- AgentConstants.HTTP_POST + " for:" + pushDataEndPointURL;
- log.error(AgentConstants.LOG_APPENDER + errorMsg);
-
- } catch (IOException exception) {
- String errorMsg =
- "An IO error occurred whilst trying to get the response code from: " +
- pushDataEndPointURL + " for a " + AgentConstants.HTTP_POST +
- " " + "method.";
- log.error(AgentConstants.LOG_APPENDER + errorMsg);
-
- } catch (TransportHandlerException exception) {
- log.error(AgentConstants.LOG_APPENDER +
- "Error encountered whilst trying to create HTTP-Connection " +
- "to IoT-Server EP at: " +
- pushDataEndPointURL);
- }
-
- if (responseCode == HttpStatus.CONFLICT_409 ||
- responseCode == HttpStatus.PRECONDITION_FAILED_412) {
- log.warn(AgentConstants.LOG_APPENDER +
- "DeviceIP is being Re-Registered due to Push-Data failure " +
- "with response code: " +
- responseCode);
- registerThisDevice();
-
- } else if (responseCode != HttpStatus.NO_CONTENT_204) {
- if (log.isDebugEnabled()) {
- log.error(AgentConstants.LOG_APPENDER + "Status Code: " + responseCode +
- " encountered whilst trying to Push-Device-Data to IoT " +
- "Server at: " +
- agentManager.getPushDataAPIEP());
- }
- agentManager.updateAgentStatus(AgentConstants.SERVER_NOT_RESPONDING);
- }
-
- if (log.isDebugEnabled()) {
- log.debug(AgentConstants.LOG_APPENDER + "Push-Data call with payload - " +
- pushDataPayload + ", to IoT Server returned status " +
- responseCode);
- }
- }
-
- @Override
- public void disconnect() {
- Runnable stopConnection = new Runnable() {
- public void run() {
- while (isConnected()) {
- try {
- dataPushServiceHandler.cancel(true);
- connectorServiceHandler.cancel(true);
- closeConnection();
- } catch (Exception e) {
- if (log.isDebugEnabled()) {
- log.warn(AgentConstants.LOG_APPENDER +
- "Unable to 'STOP' HTTP server at port: " + port);
- }
-
- try {
- Thread.sleep(timeoutInterval);
- } catch (InterruptedException e1) {
- log.error(AgentConstants.LOG_APPENDER +
- "HTTP-Termination: Thread Sleep Interrupt " +
- "Exception");
- }
- }
- }
- }
- };
-
- Thread terminatorThread = new Thread(stopConnection);
- terminatorThread.setDaemon(true);
- terminatorThread.start();
- }
-
- @Override
- public void processIncomingMessage(Object message, String... messageParams) {
-
- }
-
- @Override
- public void publishDeviceData(String... publishData) {
-
- }
-
- public void registerThisDevice() {
- final AgentManager agentManager = AgentManager.getInstance();
- agentManager.updateAgentStatus("Registering...");
-
- final Runnable ipRegistration = new Runnable() {
- @Override
- public void run() {
- while (isConnected()) {
- try {
- int responseCode = registerDeviceIP(
- agentManager.getAgentConfigs().getDeviceOwner(),
- agentManager.getAgentConfigs().getDeviceId());
-
- if (responseCode == HttpStatus.OK_200) {
- agentManager.updateAgentStatus(AgentConstants.REGISTERED);
- break;
- } else {
- log.error(AgentConstants.LOG_APPENDER +
- "Device Registration with IoT Server at:" + " " +
- agentManager.getIpRegistrationEP() +
- " failed with response - '" + responseCode + ":" +
- HttpStatus.getMessage(responseCode) + "'");
- agentManager.updateAgentStatus(AgentConstants.RETRYING_TO_REGISTER);
- }
- } catch (AgentCoreOperationException exception) {
- log.error(AgentConstants.LOG_APPENDER +
- "Error encountered whilst trying to register the " +
- "Device's IP at: " +
- agentManager.getIpRegistrationEP() +
- ".\nCheck whether the network-interface provided is " +
- "accurate");
- agentManager.updateAgentStatus(AgentConstants.REGISTRATION_FAILED);
- }
-
- try {
- Thread.sleep(timeoutInterval);
- } catch (InterruptedException e1) {
- log.error(AgentConstants.LOG_APPENDER +
- "Device Registration: Thread Sleep Interrupt Exception");
- }
- }
- }
- };
-
- Thread ipRegisterThread = new Thread(ipRegistration);
- ipRegisterThread.setDaemon(true);
- ipRegisterThread.start();
- }
-
-
- /**
- * This method calls the "Register-API" of the IoT Server in order to register the device's IP
- * against its ID.
- *
- * @param deviceOwner the owner of the device by whose name the agent was downloaded.
- * (Read from configuration file)
- * @param deviceID the deviceId that is auto-generated whilst downloading the agent.
- * (Read from configuration file)
- * @return the status code of the HTTP-Post call to the Register-API of the IoT-Server
- * @throws AgentCoreOperationException if any errors occur when an HTTPConnection session is
- * created
- */
- private int registerDeviceIP(String deviceOwner, String deviceID)
- throws AgentCoreOperationException {
- int responseCode = -1;
- final AgentManager agentManager = AgentManager.getInstance();
-
- String networkInterface = agentManager.getNetworkInterface();
- String deviceIPAddress = getDeviceIP(networkInterface);
-
- if (deviceIPAddress == null) {
- throw new AgentCoreOperationException(
- "An IP address could not be retrieved for the selected network interface - '" +
- networkInterface + ".");
- }
-
- agentManager.setDeviceIP(deviceIPAddress);
- log.info(AgentConstants.LOG_APPENDER + "Device IP Address: " + deviceIPAddress);
-
- String deviceIPRegistrationEP = agentManager.getIpRegistrationEP();
- String registerEndpointURLString =
- deviceIPRegistrationEP + File.separator + deviceOwner + File.separator + deviceID +
- File.separator + deviceIPAddress + File.separator + port;
-
- if (log.isDebugEnabled()) {
- log.debug(AgentConstants.LOG_APPENDER + "DeviceIP Registration EndPoint: " +
- registerEndpointURLString);
- }
-
- HttpURLConnection httpConnection;
- try {
- httpConnection = TransportUtils.getHttpConnection(registerEndpointURLString);
- } catch (TransportHandlerException e) {
- String errorMsg =
- "Protocol specific error occurred when trying to fetch an HTTPConnection to:" +
- " " +
- registerEndpointURLString;
- log.error(AgentConstants.LOG_APPENDER + errorMsg);
- throw new AgentCoreOperationException();
- }
-
- try {
- httpConnection.setRequestMethod(AgentConstants.HTTP_POST);
- httpConnection.setRequestProperty("Authorization", "Bearer " +
- agentManager.getAgentConfigs().getAuthToken());
- httpConnection.setDoOutput(true);
- responseCode = httpConnection.getResponseCode();
-
- } catch (ProtocolException exception) {
- String errorMsg = "Protocol specific error occurred when trying to set method to " +
- AgentConstants.HTTP_POST + " for:" + registerEndpointURLString;
- log.error(AgentConstants.LOG_APPENDER + errorMsg);
- throw new AgentCoreOperationException(errorMsg, exception);
-
- } catch (IOException exception) {
- String errorMsg = "An IO error occurred whilst trying to get the response code from:" +
- " " +
- registerEndpointURLString + " for a " + AgentConstants.HTTP_POST + " method.";
- log.error(AgentConstants.LOG_APPENDER + errorMsg);
- throw new AgentCoreOperationException(errorMsg, exception);
- }
-
- log.info(AgentConstants.LOG_APPENDER + "DeviceIP - " + deviceIPAddress +
- ", registration with IoT Server at : " +
- agentManager.getAgentConfigs().getHTTPS_ServerEndpoint() +
- " returned status " +
- responseCode);
-
- return responseCode;
- }
-
- /*------------------------------------------------------------------------------------------*/
- /* Utility methods relevant to creating and sending HTTP requests to the Iot-Server */
- /*------------------------------------------------------------------------------------------*/
-
- /**
- * This method is used to get the IP of the device in which the agent is run on.
- *
- * @return the IP Address of the device
- * @throws AgentCoreOperationException if any errors occur whilst trying to get the IP address
- */
- private String getDeviceIP() throws AgentCoreOperationException {
- try {
- return Inet4Address.getLocalHost().getHostAddress();
- } catch (UnknownHostException e) {
- String errorMsg = "Error encountered whilst trying to get the device IP address.";
- log.error(AgentConstants.LOG_APPENDER + errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
- }
-
- /**
- * This is an overloaded method that fetches the public IPv4 address of the given network
- * interface
- *
- * @param networkInterfaceName the network-interface of whose IPv4 address is to be retrieved
- * @return the IP Address iof the device
- * @throws AgentCoreOperationException if any errors occur whilst trying to get details of the
- * given network interface
- */
- private String getDeviceIP(String networkInterfaceName) throws
- AgentCoreOperationException {
- String ipAddress = null;
- try {
- Enumeration interfaceIPAddresses = NetworkInterface.getByName(
- networkInterfaceName).getInetAddresses();
- for (; interfaceIPAddresses.hasMoreElements(); ) {
- InetAddress ip = interfaceIPAddresses.nextElement();
- ipAddress = ip.getHostAddress();
- if (log.isDebugEnabled()) {
- log.debug(AgentConstants.LOG_APPENDER + "IP Address: " + ipAddress);
- }
-
- if (TransportUtils.validateIPv4(ipAddress)) {
- return ipAddress;
- }
- }
- } catch (SocketException | NullPointerException exception) {
- String errorMsg =
- "Error encountered whilst trying to get IP Addresses of the network interface: " +
- networkInterfaceName +
- ".\nPlease check whether the name of the network interface used is correct";
- log.error(AgentConstants.LOG_APPENDER + errorMsg);
- throw new AgentCoreOperationException(errorMsg, exception);
- }
-
- return ipAddress;
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/mqtt/FireAlarmMQTTCommunicator.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/mqtt/FireAlarmMQTTCommunicator.java
deleted file mode 100644
index aae520f8e..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/mqtt/FireAlarmMQTTCommunicator.java
+++ /dev/null
@@ -1,300 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.communication.mqtt;
-
-import com.google.gson.Gson;
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.eclipse.paho.client.mqttv3.MqttException;
-import org.eclipse.paho.client.mqttv3.MqttMessage;
-import org.json.JSONObject;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentConstants;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentUtilOperations;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.exception.AgentCoreOperationException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandlerException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.mqtt.MQTTTransportHandler;
-
-import java.nio.charset.StandardCharsets;
-import java.util.concurrent.Executors;
-import java.util.concurrent.ScheduledExecutorService;
-import java.util.concurrent.ScheduledFuture;
-import java.util.concurrent.TimeUnit;
-
-public class FireAlarmMQTTCommunicator extends MQTTTransportHandler {
-
- private static final Log log = LogFactory.getLog(FireAlarmMQTTCommunicator.class);
- private static final Gson gson = new Gson();
-
- private ScheduledExecutorService service = Executors.newScheduledThreadPool(2);
- private ScheduledFuture> dataPushServiceHandler;
-
- public FireAlarmMQTTCommunicator(String deviceOwner, String deviceType,
- String mqttBrokerEndPoint, String subscribeTopic) {
- super(deviceOwner, deviceType, mqttBrokerEndPoint, subscribeTopic);
- }
-
- @SuppressWarnings("unused")
- public FireAlarmMQTTCommunicator(String deviceOwner, String deviceType,
- String mqttBrokerEndPoint, String subscribeTopic,
- int intervalInMillis) {
- super(deviceOwner, deviceType, mqttBrokerEndPoint, subscribeTopic, intervalInMillis);
- }
-
- public ScheduledFuture> getDataPushServiceHandler() {
- return dataPushServiceHandler;
- }
-
- //TODO:: Terminate logs with a period
- //TODO: Need to print exceptions
- @Override
- public void connect() {
- final AgentManager agentManager = AgentManager.getInstance();
- Runnable connector = new Runnable() {
- public void run() {
- while (!isConnected()) {
- try {
-
- connectToQueue();
- agentManager.updateAgentStatus("Connected to MQTT Queue");
- } catch (TransportHandlerException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Connection to MQTT Broker at: " + mqttBrokerEndPoint +
- " failed.\n Will retry in " + timeoutInterval + " milli-seconds.");
- }
-
- try {
- subscribeToQueue();
- agentManager.updateAgentStatus("Subscribed to MQTT Queue");
- publishDeviceData();
-
- } catch (TransportHandlerException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Subscription to MQTT Broker at: " +
- mqttBrokerEndPoint + " failed");
- agentManager.updateAgentStatus("Subscription to broker failed.");
- }
-
- try {
- Thread.sleep(timeoutInterval);
- } catch (InterruptedException ex) {
- log.error(AgentConstants.LOG_APPENDER + "MQTT: Connect-Thread Sleep Interrupt Exception.");
- }
- }
- }
- };
-
- Thread connectorThread = new Thread(connector);
- connectorThread.setDaemon(true);
- connectorThread.start();
- }
-
-
- @Override
- public void processIncomingMessage(MqttMessage message, String... messageParams) {
- final AgentManager agentManager = AgentManager.getInstance();
- String tenantDomain = agentManager.getAgentConfigs().getTenantDomain();
- String deviceID = agentManager.getAgentConfigs().getDeviceId();
- String receivedMessage;
- String replyMessage;
- String securePayLoad;
-
- try {
- receivedMessage = message.toString();
- if (!receivedMessage.contains("policyDefinition")) {
- receivedMessage = AgentUtilOperations.extractMessageFromPayload(receivedMessage);
-
- String[] controlSignal = receivedMessage.split(":");
- // message- ":" format.(ex: "BULB:ON", "TEMPERATURE", "HUMIDITY")
-
- try {
- switch (controlSignal[0].toUpperCase()) {
- case AgentConstants.BULB_CONTROL:
- boolean stateToSwitch = controlSignal[1].equals(AgentConstants.CONTROL_ON);
- agentManager.changeAlarmStatus(stateToSwitch);
- log.info(
- AgentConstants.LOG_APPENDER + "Bulb was switched to state: '" + controlSignal[1] + "'");
- break;
-
- case AgentConstants.TEMPERATURE_CONTROL:
- int currentTemperature = agentManager.getTemperature();
-
- String replyTemperature = "Current temperature was read as: '" + currentTemperature + "C'";
- log.info(AgentConstants.LOG_APPENDER + replyTemperature);
-
- String tempPublishTopic = String.format(AgentConstants.MQTT_PUBLISH_TOPIC, tenantDomain, deviceID);
-
- replyMessage = AgentConstants.TEMPERATURE_CONTROL + ":" + currentTemperature;
- securePayLoad = AgentUtilOperations.prepareSecurePayLoad(replyMessage);
- publishToQueue(tempPublishTopic, securePayLoad);
- break;
-
- case AgentConstants.HUMIDITY_CONTROL:
- int currentHumidity = agentManager.getHumidity();
-
- String replyHumidity = "Current humidity was read as: '" + currentHumidity + "%'";
- log.info(AgentConstants.LOG_APPENDER + replyHumidity);
-
- String humidPublishTopic = String.format(
- AgentConstants.MQTT_PUBLISH_TOPIC, tenantDomain, deviceID);
-
- replyMessage = AgentConstants.HUMIDITY_CONTROL + ":" + currentHumidity;
- securePayLoad = AgentUtilOperations.prepareSecurePayLoad(replyMessage);
- publishToQueue(humidPublishTopic, securePayLoad);
- break;
-
- case AgentConstants.POLICY_REVOKE:
- break;
-
- default:
- log.warn(AgentConstants.LOG_APPENDER + "'" + controlSignal[0] +
- "' is invalid and not-supported for this device-type");
- break;
- }
- } catch (AgentCoreOperationException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Preparing Secure payload failed", e);
- } catch (TransportHandlerException e) {
- log.error(AgentConstants.LOG_APPENDER +
- "MQTT - Publishing, reply message to the MQTT Queue at: " +
- agentManager.getAgentConfigs().getMqttBrokerEndpoint() + " failed");
- }
-
- } else {
- JSONObject jsonMessage = new JSONObject(receivedMessage);
- updateCEPPolicy(jsonMessage.getString("policyDefinition"));
- }
- log.info(AgentConstants.LOG_APPENDER + "Message [" + receivedMessage + "] was received");
- } catch (AgentCoreOperationException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Could not extract message from payload.", e);
- return;
- }
-
-
- }
-
- @Override
- public void publishDeviceData() {
- final AgentManager agentManager = AgentManager.getInstance();
- int publishInterval = agentManager.getPushInterval();
- Runnable pushDataRunnable = new Runnable() {
- @Override
- public void run() {
- int currentTemperature = agentManager.getTemperature();
- String message = "{\"event\": {\"metaData\": {\"owner\": \"" + AgentManager
- .getInstance().getAgentConfigs().getDeviceOwner() + "\",\"deviceId\": \"" + AgentManager
- .getInstance().getAgentConfigs().getDeviceId() + "\",\"time\": " +
- "0},\"payloadData\": { \"temperature\": " + currentTemperature + "} }}";
-
- try {
- String payLoad = AgentUtilOperations.prepareSecurePayLoad(message);
-
- MqttMessage pushMessage = new MqttMessage();
- pushMessage.setPayload(payLoad.getBytes(StandardCharsets.UTF_8));
- pushMessage.setQos(DEFAULT_MQTT_QUALITY_OF_SERVICE);
- pushMessage.setRetained(false);
-
- String topic = String.format(AgentConstants.MQTT_PUBLISH_TOPIC,
- agentManager.getAgentConfigs().getTenantDomain(),
- agentManager.getAgentConfigs().getDeviceId());
-
- publishToQueue(topic, pushMessage);
- log.info(AgentConstants.LOG_APPENDER + "Message: '" + message + "' published to MQTT Queue at [" +
- agentManager.getAgentConfigs().getMqttBrokerEndpoint() + "] under topic [" +
- topic + "]");
-
- } catch (TransportHandlerException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Data Publish attempt to topic - [" +
- AgentConstants.MQTT_PUBLISH_TOPIC + "] failed for payload [" + message + "]");
- } catch (AgentCoreOperationException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Preparing Secure payload failed", e);
- }
- }
- };
-
- dataPushServiceHandler = service.scheduleAtFixedRate(pushDataRunnable, publishInterval, publishInterval,
- TimeUnit.SECONDS);
- }
-
-
- @Override
- public void disconnect() {
- Runnable stopConnection = new Runnable() {
- public void run() {
- while (isConnected()) {
-
- if (dataPushServiceHandler != null) {
- dataPushServiceHandler.cancel(true);
- }
-
- try {
- closeConnection();
-
- } catch (MqttException e) {
- if (log.isDebugEnabled()) {
- log.warn(AgentConstants.LOG_APPENDER +
- "Unable to 'STOP' MQTT connection at broker at: " +
- mqttBrokerEndPoint);
- }
-
- try {
- Thread.sleep(timeoutInterval);
- } catch (InterruptedException e1) {
- log.error(AgentConstants.LOG_APPENDER +
- "MQTT-Terminator: Thread Sleep Interrupt Exception");
- }
- }
- }
- }
- };
-
- Thread terminatorThread = new Thread(stopConnection);
- terminatorThread.setDaemon(true);
- terminatorThread.start();
- }
-
- @Override
- public void processIncomingMessage() {
-
- }
-
- @Override
- public void publishDeviceData(String... publishData) {
-
- }
-
- private boolean isJSONValid(String JSON_STRING) {
- try {
- gson.fromJson(JSON_STRING, Object.class);
- return true;
- } catch (com.google.gson.JsonSyntaxException ex) {
- return false;
- }
- }
-
-
- private void updateCEPPolicy(String message) {
- AgentManager agentManager = AgentManager.getInstance();
- System.out.println(" Message : " + message);
- String fileLocation = agentManager.getRootPath() + AgentConstants.CEP_FILE_NAME;
- message = AgentUtilOperations.formatMessage(message);
- AgentUtilOperations.writeToFile(message, fileLocation);
- AgentManager.setUpdated(true);
- agentManager.addToPolicyLog(message);
- }
-
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/xmpp/FireAlarmXMPPCommunicator.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/xmpp/FireAlarmXMPPCommunicator.java
deleted file mode 100644
index 8ba82906f..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/communication/xmpp/FireAlarmXMPPCommunicator.java
+++ /dev/null
@@ -1,265 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.communication.xmpp;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.jivesoftware.smack.packet.Message;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentConstants;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentUtilOperations;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.exception.AgentCoreOperationException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandlerException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.xmpp.XMPPTransportHandler;
-
-import java.util.concurrent.Executors;
-import java.util.concurrent.ScheduledExecutorService;
-import java.util.concurrent.ScheduledFuture;
-import java.util.concurrent.TimeUnit;
-
-public class FireAlarmXMPPCommunicator extends XMPPTransportHandler {
-
- private static final Log log = LogFactory.getLog(FireAlarmXMPPCommunicator.class);
-
- private ScheduledExecutorService service = Executors.newScheduledThreadPool(2);
- private ScheduledFuture> dataPushServiceHandler;
- private ScheduledFuture> connectorServiceHandler;
-
- private String username;
- private String password;
- private String resource;
- private String xmppAdminJID;
- private String xmppDeviceJID;
-
- public FireAlarmXMPPCommunicator(String server) {
- super(server);
- }
-
- public FireAlarmXMPPCommunicator(String server, int port) {
- super(server, port);
- }
-
- public FireAlarmXMPPCommunicator(String server, int port, int timeout) {
- super(server, port, timeout);
- }
-
- public ScheduledFuture> getDataPushServiceHandler() {
- return dataPushServiceHandler;
- }
-
- @Override
- public void connect() {
- final AgentManager agentManager = AgentManager.getInstance();
- username = agentManager.getAgentConfigs().getDeviceId();
- password = agentManager.getAgentConfigs().getAuthToken();
- xmppDeviceJID = username + "@" + agentManager.getAgentConfigs().getXmppServerName();
- xmppAdminJID = agentManager.getAgentConfigs().getServerJID();
-
- Runnable connect = new Runnable() {
- public void run() {
- if (!isConnected()) {
- try {
- connectToServer();
- } catch (TransportHandlerException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Connection to XMPP server at: " + server + " failed");
- }
-
- try {
- loginToServer(username, password, resource);
- agentManager.updateAgentStatus("Connected to XMPP Server");
- setMessageFilterAndListener(xmppAdminJID, xmppDeviceJID, true);
- publishDeviceData();
- } catch (TransportHandlerException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Login to XMPP server at: " + server + " failed");
- agentManager.updateAgentStatus("No XMPP Account for Device");
- }
- }
- }
- };
-
- connectorServiceHandler = service.scheduleAtFixedRate(connect, 0, timeoutInterval, TimeUnit.MILLISECONDS);
- }
-
- /**
- * This is an abstract method used for post processing the received XMPP-message. This
- * method will be implemented as per requirement at the time of creating an object of this
- * class.
- *
- * @param xmppMessage the xmpp message received by the listener.
- */
- @Override
- public void processIncomingMessage(Message xmppMessage, String... messageParams) {
- final AgentManager agentManager = AgentManager.getInstance();
- String from = xmppMessage.getFrom();
- String message = xmppMessage.getBody();
- String receivedMessage;
- String replyMessage;
- String securePayLoad;
-
- try {
- receivedMessage = AgentUtilOperations.extractMessageFromPayload(message);
- log.info(AgentConstants.LOG_APPENDER + "Message [" + receivedMessage + "] was received");
- } catch (AgentCoreOperationException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Could not extract message from payload.", e);
- return;
- }
-
- String[] controlSignal = receivedMessage.split(":");
- //message- ":" format. (ex: "BULB:ON", "TEMPERATURE", "HUMIDITY")
-
- try {
- switch (controlSignal[0].toUpperCase()) {
- case AgentConstants.BULB_CONTROL:
- if (controlSignal.length != 2) {
- replyMessage = "BULB controls need to be in the form - 'BULB:{ON|OFF}'";
- log.warn(replyMessage);
- securePayLoad = AgentUtilOperations.prepareSecurePayLoad(replyMessage);
- sendXMPPMessage(xmppAdminJID, securePayLoad, "CONTROL-REPLY");
- break;
- }
-
- agentManager.changeAlarmStatus(controlSignal[1].equals(AgentConstants.CONTROL_ON));
- log.info(AgentConstants.LOG_APPENDER + "Bulb was switched to state: '" + controlSignal[1] + "'");
- break;
-
- case AgentConstants.TEMPERATURE_CONTROL:
- int currentTemperature = agentManager.getTemperature();
-
- String replyTemperature =
- "The current temperature was read to be: '" + currentTemperature +
- "C'";
- log.info(AgentConstants.LOG_APPENDER + replyTemperature);
-
- replyMessage = AgentConstants.TEMPERATURE_CONTROL + ":" + currentTemperature;
- securePayLoad = AgentUtilOperations.prepareSecurePayLoad(replyMessage);
- sendXMPPMessage(xmppAdminJID, securePayLoad, "CONTROL-REPLY");
- break;
-
- case AgentConstants.HUMIDITY_CONTROL:
- int currentHumidity = agentManager.getHumidity();
-
- String replyHumidity = "The current humidity was read to be: '" + currentHumidity + "%'";
- log.info(AgentConstants.LOG_APPENDER + replyHumidity);
-
- replyMessage = AgentConstants.HUMIDITY_CONTROL + ":" + currentHumidity;
- securePayLoad = AgentUtilOperations.prepareSecurePayLoad(replyMessage);
- sendXMPPMessage(xmppAdminJID, securePayLoad, "CONTROL-REPLY");
- break;
-
- default:
- replyMessage = "'" + controlSignal[0] + "' is invalid and not-supported for this device-type";
- log.warn(replyMessage);
- securePayLoad = AgentUtilOperations.prepareSecurePayLoad(replyMessage);
- sendXMPPMessage(xmppAdminJID, securePayLoad, "CONTROL-ERROR");
- break;
- }
- } catch (AgentCoreOperationException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Preparing Secure payload failed", e);
- }
-
- }
-
-
- @Override
- public void publishDeviceData() {
- final AgentManager agentManager = AgentManager.getInstance();
- int publishInterval = agentManager.getPushInterval();
-
- Runnable pushDataRunnable = new Runnable() {
- @Override
- public void run() {
- Message xmppMessage = new Message();
-
- try {
- int currentTemperature = agentManager.getTemperature();
-
- String message = "{\"event\": {\"metaData\": {\"owner\": \"" + AgentManager
- .getInstance().getAgentConfigs().getDeviceOwner() + "\",\"deviceId\": \"" + AgentManager
- .getInstance().getAgentConfigs().getDeviceId() + "\",\"time\": " +
- "0},\"payloadData\": { \"temperature\": " + currentTemperature + "} }}";
- String payLoad = AgentUtilOperations.prepareSecurePayLoad(message);
-
- xmppMessage.setTo(xmppAdminJID);
- xmppMessage.setSubject(agentManager.getAgentConfigs().getTenantDomain());
- xmppMessage.setBody(payLoad);
- xmppMessage.setType(Message.Type.chat);
-
- sendXMPPMessage(xmppAdminJID, xmppMessage);
- log.info(AgentConstants.LOG_APPENDER + "Message: '" + message + "' sent to XMPP JID - " +
- "[" + xmppAdminJID + "] under subject [" + xmppMessage.getSubject() + "].");
- } catch (AgentCoreOperationException e) {
- log.warn(AgentConstants.LOG_APPENDER + "Preparing Secure payload failed for XMPP JID - " +
- "[" + xmppAdminJID + "] with subject - [" + xmppMessage.getSubject() + "].");
- }
- }
- };
-
- dataPushServiceHandler = service.scheduleAtFixedRate(pushDataRunnable, publishInterval,
- publishInterval, TimeUnit.SECONDS);
- }
-
-
- @Override
- public void disconnect() {
- Runnable stopConnection = new Runnable() {
- public void run() {
-
- if (dataPushServiceHandler != null) {
- dataPushServiceHandler.cancel(true);
- }
-
- if (connectorServiceHandler != null) {
- connectorServiceHandler.cancel(true);
- }
-
- while (isConnected()) {
- closeConnection();
-
- if (log.isDebugEnabled()) {
- log.warn(AgentConstants.LOG_APPENDER +
- "Unable to 'STOP' connection to XMPP server at: " + server);
- }
-
- try {
- Thread.sleep(timeoutInterval);
- } catch (InterruptedException e1) {
- log.error(AgentConstants.LOG_APPENDER + "XMPP-Terminator: Thread Sleep Interrupt Exception");
- }
-
- }
- }
- };
-
- Thread terminatorThread = new Thread(stopConnection);
- terminatorThread.setDaemon(true);
- terminatorThread.start();
- }
-
-
- @Override
- public void processIncomingMessage() {
-
- }
-
- @Override
- public void publishDeviceData(String... publishData) {
-
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConfiguration.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConfiguration.java
deleted file mode 100644
index 50c3c7015..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConfiguration.java
+++ /dev/null
@@ -1,156 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core;
-
-/**
- * A Configuration class that holds all the Agent specific details that are read from the
- * 'deviceConfig.properties' file. This file is generated by the IoT-Server at the time of
- * downloading the device agent from the IoT-Server.
- */
-public class AgentConfiguration {
- private String tenantDomain;
- private String deviceOwner;
- private String deviceId;
- private String deviceName;
- private String HTTPS_ServerEndpoint;
- private String HTTP_ServerEndpoint;
- private String apimGatewayEndpoint;
- private String mqttBrokerEndpoint;
- private String xmppServerEndpoint;
- private String authToken;
- private String refreshToken;
- private int dataPushInterval;
- private String xmppServerName;
- private String serverJID;
-
- public String getTenantDomain() {
- return tenantDomain;
- }
-
- public void setTenantDomain(String tenantDomain) {
- this.tenantDomain = tenantDomain;
- }
-
- public String getDeviceOwner() {
- return deviceOwner;
- }
-
- public void setDeviceOwner(String deviceOwner) {
- this.deviceOwner = deviceOwner;
- }
-
- public String getDeviceId() {
- return deviceId;
- }
-
- public String getServerJID() {
- return serverJID;
- }
-
- public void setServerJID(String serverJID) {
- this.serverJID = serverJID;
- }
-
- public void setDeviceId(String deviceId) {
- this.deviceId = deviceId;
- }
-
- public String getDeviceName() {
- return deviceName;
- }
-
- public void setDeviceName(String deviceName) {
- this.deviceName = deviceName;
- }
-
- public String getHTTPS_ServerEndpoint() {
- return HTTPS_ServerEndpoint;
- }
-
- public void setHTTPS_ServerEndpoint(String HTTPS_ServerEndpoint) {
- this.HTTPS_ServerEndpoint = HTTPS_ServerEndpoint;
- }
-
- public String getHTTP_ServerEndpoint() {
- return HTTP_ServerEndpoint;
- }
-
- public void setHTTP_ServerEndpoint(String HTTP_ServerEndpoint) {
- this.HTTP_ServerEndpoint = HTTP_ServerEndpoint;
- }
-
- public String getApimGatewayEndpoint() {
- return apimGatewayEndpoint;
- }
-
- public void setApimGatewayEndpoint(String apimGatewayEndpoint) {
- this.apimGatewayEndpoint = apimGatewayEndpoint;
- }
-
- public String getMqttBrokerEndpoint() {
- return mqttBrokerEndpoint;
- }
-
- public void setMqttBrokerEndpoint(String mqttBrokerEndpoint) {
- this.mqttBrokerEndpoint = mqttBrokerEndpoint;
- }
-
- public String getXmppServerEndpoint() {
- return xmppServerEndpoint;
- }
-
- public void setXmppServerEndpoint(String xmppServerEndpoint) {
- this.xmppServerEndpoint = xmppServerEndpoint;
- }
-
- public String getAuthToken() {
- return authToken;
- }
-
- public void setAuthToken(String authToken) {
- this.authToken = authToken;
- }
-
- public String getRefreshToken() {
- return refreshToken;
- }
-
- public void setRefreshToken(String refreshToken) {
- this.refreshToken = refreshToken;
- }
-
- public int getDataPushInterval() {
- return dataPushInterval;
- }
-
- public void setDataPushInterval(int dataPushInterval) {
- this.dataPushInterval = dataPushInterval;
- }
-
- public String getXmppServerName() {
- return xmppServerName;
- }
-
- public void setXmppServerName(String xmppServerName) {
- this.xmppServerName = xmppServerName;
- }
-
-}
-
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConstants.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConstants.java
deleted file mode 100644
index 81cb5ae00..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentConstants.java
+++ /dev/null
@@ -1,127 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core;
-
-public class AgentConstants {
- public static final String DEVICE_TYPE = "virtual_firealarm";
- public static final String LOG_APPENDER = "AGENT_LOG:: ";
- public static final String PROPERTIES_FILE_PATH = "";
- public static final int DEFAULT_RETRY_THREAD_INTERVAL = 5000; // time in millis
- /* ---------------------------------------------------------------------------------------
- IoT-Server specific information
- --------------------------------------------------------------------------------------- */
- public static final String DEVICE_CONTROLLER_API_EP = "/virtual_firealarm/device";
- public static final String DEVICE_SCEP_API_EP = "/virtual_firealarm_scep";
- public static final String DEVICE_ENROLLMENT_API_EP = "/scep";
- public static final String DEVICE_REGISTER_API_EP = "/register";
- public static final String DEVICE_PUSH_TEMPERATURE_API_EP = "/push_temperature";
- public static final String PUSH_DATA_PAYLOAD =
- "{\"owner\":\"%s\",\"deviceId\":\"%s\",\"reply\":\"%s\",\"value\":\"%s\"}";
-
- public static final String PUSH_SIMULATION_DATA_PAYLOAD =
- "{\"owner\":\"%s\",\"deviceId\":\"%s\",\"reply\":\"%s\",\"value\":\"%s\",\"isSimulated\":\"%s\",\"duration\":\"%s\",\"frequency\":\"%s\"}";
-
- public static final String AGENT_CONTROL_APP_EP = "/devicemgt/device/%s?id=%s";
- public static final String DEVICE_DETAILS_PAGE_EP = "/devicemgt/device/%s?id=%s";
- public static final String DEVICE_ANALYTICS_PAGE_URL = "/devicemgt/device/virtual_firealarm/analytics?deviceId=%s&deviceName=%s";
- /* ---------------------------------------------------------------------------------------
- HTTP Connection specific information for communicating with IoT-Server
- --------------------------------------------------------------------------------------- */
- public static final String HTTP_POST = "POST";
- public static final String HTTP_GET = "GET";
- public static final String APPLICATION_JSON_TYPE = "application/json";
- public static final String REGISTERED = "Registered";
- public static final String NOT_REGISTERED = "Not-Registered";
- public static final String REGISTRATION_FAILED = "Registration Failed";
- public static final String RETRYING_TO_REGISTER = "Registration Failed. Re-trying..";
- public static final String SERVER_NOT_RESPONDING = "Server not responding..";
-
- /* ---------------------------------------------------------------------------------------
- MQTT Connection specific information
- --------------------------------------------------------------------------------------- */
- public static final int DEFAULT_MQTT_RECONNECTION_INTERVAL = 2; // time in seconds
- public static final int DEFAULT_MQTT_QUALITY_OF_SERVICE = 0;
- //public static final String MQTT_SUBSCRIBE_TOPIC = "%s/" + DEVICE_TYPE + "/%s/#";
- public static final String MQTT_SUBSCRIBE_TOPIC = "%s/" + DEVICE_TYPE + "/%s/operation/#";
- public static final String MQTT_PUBLISH_TOPIC = "%s/" + DEVICE_TYPE + "/%s/temperature";
- /* ---------------------------------------------------------------------------------------
- XMPP Connection specific information
- --------------------------------------------------------------------------------------- */
- public static final String XMPP_ADMIN_ACCOUNT_UNAME = "admin";
- /* ---------------------------------------------------------------------------------------
- Device/Agent specific properties to be read from the 'deviceConfig.properties' file
- --------------------------------------------------------------------------------------- */
- public static final String AGENT_PROPERTIES_FILE_NAME = "deviceConfig.properties";
- public static final String TENANT_DOMAIN = "tenantDomain";
- public static final String DEVICE_OWNER_PROPERTY = "owner";
- public static final String DEVICE_ID_PROPERTY = "deviceId";
- public static final String SERVER_JID_PROPERTY = "server-jid";
- public static final String DEVICE_NAME_PROPERTY = "device-name";
- public static final String SERVER_HTTPS_EP_PROPERTY = "https-ep";
- public static final String SERVER_HTTP_EP_PROPERTY = "http-ep";
- public static final String APIM_GATEWAY_EP_PROPERTY = "apim-ep";
- public static final String MQTT_BROKER_EP_PROPERTY = "mqtt-ep";
- public static final String XMPP_SERVER_EP_PROPERTY = "xmpp-ep";
- public static final String AUTH_TOKEN_PROPERTY = "auth-token";
- public static final String REFRESH_TOKEN_PROPERTY = "refresh-token";
- public static final String NETWORK_INTERFACE_PROPERTY = "network-interface";
- public static final String PUSH_INTERVAL_PROPERTY = "push-interval";
- /* ---------------------------------------------------------------------------------------
- Default values for the Device/Agent specific configurations listed above
- --------------------------------------------------------------------------------------- */
- public static final String DEFAULT_SERVER_NAME = "WSO2IoTServer";
- public static final String DEFAULT_DEVICE_OWNER = "admin";
- public static final String DEFAULT_DEVICE_ID = "1234567890";
- public static final String DEFAULT_SERVER_JID = "admin@localhost";
- public static final String DEFAULT_DEVICE_NAME = "admin_1234567890";
- public static final String DEFAULT_HTTPS_SERVER_EP = "https://localhost:9443";
- public static final String DEFAULT_HTTP_SERVER_EP = "http://localhost:9763";
- public static final String DEFAULT_APIM_GATEWAY_EP = "http://127.0.0.1:8281";
- public static final String DEFAULT_MQTT_BROKER_EP = "tcp://127.0.0.1:1883";
- public static final String DEFAULT_XMPP_SERVER_EP = "http://127.0.0.1:9061";
- public static final String DEFAULT_AUTH_TOKEN = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0987654321";
- public static final String DEFAULT_REFRESH_TOKEN = "1234567890ZYXWVUTSRQPONMKLJIHGFEDCBA";
- public static final String DEFAULT_NETWORK_INTERFACE = "en0";
- public static final int DEFAULT_DATA_PUBLISH_INTERVAL = 15; // seconds
- public static final String DEFAULT_PROTOCOL = "MQTT";
- /* ---------------------------------------------------------------------------------------
- Control Signal specific constants to match the request context
- --------------------------------------------------------------------------------------- */
- public static final String BULB_CONTROL = "BULB";
- public static final String TEMPERATURE_CONTROL = "TEMPERATURE";
- public static final String POLICY_REVOKE = "POLICY_REVOKE";
- public static final String HUMIDITY_CONTROL = "HUMIDITY";
- public static final String CONTROL_ON = "ON";
- public static final String CONTROL_OFF = "OFF";
- public static final String AUDIO_FILE_NAME = "fireAlarmSound.mid";
- /* ---------------------------------------------------------------------------------------
- Communication protocol specific Strings
- --------------------------------------------------------------------------------------- */
- public static final String TCP_PREFIX = "tcp://";
- public static final String HTTP_PREFIX = "http://";
- public static final String HTTPS_PREFIX = "https://";
- public static final String HTTP_PROTOCOL = "HTTP";
- public static final String MQTT_PROTOCOL = "MQTT";
- public static final String XMPP_PROTOCOL = "XMPP";
-
- public static final String CEP_FILE_NAME = "cep_query.txt";
-
-
- public static final String XMPP_SERVER_NAME_PROPERTY = "xmpp-server-name";
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentManager.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentManager.java
deleted file mode 100644
index 79ba03500..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentManager.java
+++ /dev/null
@@ -1,362 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.communication.http.FireAlarmHTTPCommunicator;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.communication.mqtt.FireAlarmMQTTCommunicator;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.communication.xmpp.FireAlarmXMPPCommunicator;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.enrollment.EnrollmentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.exception.AgentCoreOperationException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.sidhdhi.SidhdhiQuery;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandler;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandlerException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportUtils;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.virtual.VirtualHardwareManager;
-
-import java.nio.charset.StandardCharsets;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-public class AgentManager {
-
- private static final Log log = LogFactory.getLog(AgentManager.class);
- private static final Object lock = new Object();
- private static AgentManager agentManager;
- private static Boolean policyUpdated = false;
- private String rootPath = "";
- private boolean deviceReady = false;
- private boolean isAlarmOn = false;
- private String initialPolicy;
-
- private String deviceName, agentStatus;
-
- private int pushInterval; // seconds
- private String prevProtocol, protocol;
-
- private String networkInterface;
- private List interfaceList, protocolList;
- private Map agentCommunicator;
-
- private AgentConfiguration agentConfigs;
-
- private String deviceIP;
- private String enrollmentEP;
- private String ipRegistrationEP;
- private String pushDataAPIEP;
-
- private AgentManager() {
- }
-
- public static synchronized AgentManager getInstance() {
- if (agentManager == null) {
- agentManager = new AgentManager();
- }
- return agentManager;
- }
-
- public static void setUpdated(Boolean isUpdated) {
- synchronized (lock) {
- policyUpdated = isUpdated;
- }
- }
-
- public static Boolean isUpdated() {
- synchronized (lock) {
- Boolean temp = policyUpdated;
- policyUpdated = false;
- return temp;
- }
- }
-
- public void init() {
-
- agentCommunicator = new HashMap<>();
-
- // Read IoT-Server specific configurations from the 'deviceConfig.properties' file
- this.agentConfigs = AgentUtilOperations.readIoTServerConfigs();
-
- // Initialise IoT-Server URL endpoints from the configuration read from file
- AgentUtilOperations.initializeServerEndPoints();
-
- String analyticsPageContext = String.format(AgentConstants.DEVICE_ANALYTICS_PAGE_URL,
- agentConfigs.getDeviceId(),
- agentConfigs.getDeviceName());
-
- String controlPageContext = String.format(AgentConstants.DEVICE_DETAILS_PAGE_EP,
- AgentConstants.DEVICE_TYPE,
- agentConfigs.getDeviceId());
-
- this.agentStatus = AgentConstants.NOT_REGISTERED;
- this.deviceName = this.agentConfigs.getDeviceName();
-
- this.pushInterval = this.agentConfigs.getDataPushInterval();
- this.networkInterface = AgentConstants.DEFAULT_NETWORK_INTERFACE;
-
- this.protocol = AgentConstants.DEFAULT_PROTOCOL;
- this.prevProtocol = protocol;
-
- Map xmppIPPortMap;
- try {
- xmppIPPortMap = TransportUtils.getHostAndPort(agentConfigs.getXmppServerEndpoint());
- String xmppServer = xmppIPPortMap.get("Host");
- int xmppPort = Integer.parseInt(xmppIPPortMap.get("Port"));
-
- TransportHandler xmppCommunicator = new FireAlarmXMPPCommunicator(xmppServer, xmppPort);
- agentCommunicator.put(AgentConstants.XMPP_PROTOCOL, xmppCommunicator);
-
- } catch (TransportHandlerException e) {
- log.info("XMPP Endpoint String - " + agentConfigs.getXmppServerEndpoint() +
- ", provided in the configuration file is invalid. XMPP is not configured.");
- }
- String mqttTopic = String.format(AgentConstants.MQTT_SUBSCRIBE_TOPIC, agentConfigs.getTenantDomain(),
- agentConfigs.getDeviceId());
-
-// TransportHandler httpCommunicator = new FireAlarmHTTPCommunicator();
- TransportHandler mqttCommunicator = new FireAlarmMQTTCommunicator(agentConfigs.getDeviceOwner(),
- agentConfigs.getDeviceId(),
- agentConfigs.getMqttBrokerEndpoint(),
- mqttTopic);
-
-// agentCommunicator.put(AgentConstants.HTTP_PROTOCOL, httpCommunicator);
- agentCommunicator.put(AgentConstants.MQTT_PROTOCOL, mqttCommunicator);
-
- try {
- interfaceList = new ArrayList<>(TransportUtils.getInterfaceIPMap().keySet());
- protocolList = new ArrayList<>(agentCommunicator.keySet());
- } catch (TransportHandlerException e) {
- log.error("An error occurred whilst retrieving all NetworkInterface-IP mappings");
- }
-
- String siddhiQueryFilePath = rootPath + AgentConstants.CEP_FILE_NAME;
- (new Thread(new SidhdhiQuery())).start();
- initialPolicy = SidhdhiQuery.readFile(siddhiQueryFilePath, StandardCharsets.UTF_8);
-
- //Initializing hardware at that point
- //AgentManger.setDeviceReady() method should invoked from hardware after initialization
- VirtualHardwareManager.getInstance().init();
-
- //Wait till hardware get ready
- while (!deviceReady) {
- try {
- Thread.sleep(500);
- } catch (InterruptedException e) {
- log.info(AgentConstants.LOG_APPENDER + "Sleep error in 'device ready-flag' checking thread");
- }
- }
-
-// try {
-// EnrollmentManager.getInstance().beginEnrollmentFlow();
-// } catch (AgentCoreOperationException e) {
-// log.error("Device Enrollment Failed:\n");
-// e.printStackTrace();
-// System.exit(0);
-// }
-
- //Start agent communication
- agentCommunicator.get(protocol).connect();
- }
-
- private void switchCommunicator(String stopProtocol, String startProtocol) {
- agentCommunicator.get(stopProtocol).disconnect();
-
- while (agentCommunicator.get(stopProtocol).isConnected()) {
- try {
- Thread.sleep(250);
- } catch (InterruptedException e) {
- log.info(AgentConstants.LOG_APPENDER +
- "Sleep error in 'Switch-Communicator' Thread's shutdown wait.");
- }
- }
-
- agentCommunicator.get(startProtocol).connect();
- }
-
- public void setInterface(int interfaceId) {
- if (interfaceId != -1) {
- String newInterface = interfaceList.get(interfaceId);
-
- if (!newInterface.equals(networkInterface)) {
- networkInterface = newInterface;
-
- if (protocol.equals(AgentConstants.HTTP_PROTOCOL) && !protocol.equals(
- prevProtocol)) {
- switchCommunicator(prevProtocol, protocol);
- }
- }
- }
- }
-
- public void setProtocol(int protocolId) {
- if (protocolId != -1) {
- String newProtocol = protocolList.get(protocolId);
-
- if (!protocol.equals(newProtocol)) {
- prevProtocol = protocol;
- protocol = newProtocol;
- switchCommunicator(prevProtocol, protocol);
- }
- }
- }
-
- public void changeAlarmStatus(boolean isOn) {
- VirtualHardwareManager.getInstance().changeAlarmStatus(isOn);
- isAlarmOn = isOn;
- }
-
- public void updateAgentStatus(String status) {
- this.agentStatus = status;
- }
-
- public void addToPolicyLog(String policy) {
- VirtualHardwareManager.getInstance().addToPolicyLog(policy);
- }
-
- public String getRootPath() {
- return rootPath;
- }
-
- /*------------------------------------------------------------------------------------------*/
- /* Getter and Setter Methods for the private variables */
- /*------------------------------------------------------------------------------------------*/
-
- public void setRootPath(String rootPath) {
- this.rootPath = rootPath;
- }
-
- public void setDeviceReady(boolean deviceReady) {
- this.deviceReady = deviceReady;
- }
-
- public String getInitialPolicy() {
- return initialPolicy;
- }
-
- public AgentConfiguration getAgentConfigs() {
- return agentConfigs;
- }
-
- public String getDeviceIP() {
- return deviceIP;
- }
-
- public void setDeviceIP(String deviceIP) {
- this.deviceIP = deviceIP;
- }
-
- public String getEnrollmentEP() {
- return enrollmentEP;
- }
-
- public void setEnrollmentEP(String enrollmentEP) {
- this.enrollmentEP = enrollmentEP;
- }
-
- public String getIpRegistrationEP() {
- return ipRegistrationEP;
- }
-
- public void setIpRegistrationEP(String ipRegistrationEP) {
- this.ipRegistrationEP = ipRegistrationEP;
- }
-
- public String getPushDataAPIEP() {
- return pushDataAPIEP;
- }
-
- public void setPushDataAPIEP(String pushDataAPIEP) {
- this.pushDataAPIEP = pushDataAPIEP;
- }
-
- public String getDeviceName() {
- return deviceName;
- }
-
- public String getNetworkInterface() {
- return networkInterface;
- }
-
- public String getAgentStatus() {
- return agentStatus;
- }
-
- public int getPushInterval() {
- return pushInterval;
- }
-
- public void setPushInterval(int pushInterval) {
- this.pushInterval = pushInterval;
- TransportHandler transportHandler = agentCommunicator.get(protocol);
-
- switch (protocol) {
- case AgentConstants.HTTP_PROTOCOL:
- ((FireAlarmHTTPCommunicator) transportHandler).getDataPushServiceHandler()
- .cancel(true);
- break;
- case AgentConstants.MQTT_PROTOCOL:
- ((FireAlarmMQTTCommunicator) transportHandler).getDataPushServiceHandler()
- .cancel(true);
- break;
- case AgentConstants.XMPP_PROTOCOL:
- ((FireAlarmXMPPCommunicator) transportHandler).getDataPushServiceHandler()
- .cancel(true);
- break;
- default:
- log.warn("Unknown protocol " + protocol);
- }
- transportHandler.publishDeviceData();
-
- if (log.isDebugEnabled()) {
- log.debug("The Data Publish Interval was changed to: " + pushInterval);
- }
- }
-
- public List getInterfaceList() {
- return interfaceList;
- }
-
- public List getProtocolList() {
- return protocolList;
- }
-
- /**
- * Get temperature reading from device
- *
- * @return Temperature
- */
- public int getTemperature() {
- return VirtualHardwareManager.getInstance().getTemperature();
- }
-
- /**
- * Get humidity reading from device
- *
- * @return Humidity
- */
- public int getHumidity() {
- return VirtualHardwareManager.getInstance().getHumidity();
- }
-
- public boolean isAlarmOn() {
- return isAlarmOn;
- }
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentUtilOperations.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentUtilOperations.java
deleted file mode 100644
index a2d9cfacf..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/core/AgentUtilOperations.java
+++ /dev/null
@@ -1,361 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core;
-
-import org.apache.commons.codec.binary.Base64;
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.json.JSONObject;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.enrollment.EnrollmentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.exception.AgentCoreOperationException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.CommunicationUtils;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandlerException;
-
-import java.io.*;
-import java.net.URL;
-import java.net.URLDecoder;
-import java.nio.charset.StandardCharsets;
-import java.security.PrivateKey;
-import java.security.PublicKey;
-import java.util.ArrayList;
-import java.util.Properties;
-
-/**
- * This class contains all the core operations of the FireAlarm agent that are common to both
- * Virtual and Real Scenarios. These operations include, connecting to and subscribing to an MQTT
- * queue and to a XMPP Server. Pushing temperature data to the IoT-Server at timely intervals.
- * Reading device specific configuration from a configs file etc....
- */
-public class AgentUtilOperations {
-
- private static final Log log = LogFactory.getLog(AgentUtilOperations.class);
- private static final String JSON_MESSAGE_KEY = "Msg";
- private static final String JSON_SIGNATURE_KEY = "Sig";
- private static final String JSON_SERIAL_KEY = "SerialNumber";
-
- /**
- * This method reads the agent specific configurations for the device from the
- * "deviceConfigs.properties" file found at /repository/conf folder.
- * If the properties file is not found in the specified path, then the configuration values
- * are set to the default ones in the 'AgentConstants' class.
- *
- * @return an object of type 'AgentConfiguration' which contains all the necessary
- * configuration attributes
- */
- public static AgentConfiguration readIoTServerConfigs() {
- AgentManager agentManager = AgentManager.getInstance();
- AgentConfiguration iotServerConfigs = new AgentConfiguration();
- Properties properties = new Properties();
- InputStream propertiesInputStream = null;
- String propertiesFileName = AgentConstants.AGENT_PROPERTIES_FILE_NAME;
-
- try {
- ClassLoader loader = AgentUtilOperations.class.getClassLoader();
- URL path = loader.getResource(propertiesFileName);
- log.info(AgentConstants.LOG_APPENDER + path);
- String rootPath = path.getPath().replace("wso2-firealarm-virtual-agent-advanced.jar!/deviceConfig"
- + ".properties", "").replace("jar:", "").replace("file:", "");
-
- rootPath = URLDecoder.decode(rootPath, StandardCharsets.UTF_8.toString());
- agentManager.setRootPath(rootPath);
- String deviceConfigFilePath = rootPath + AgentConstants.AGENT_PROPERTIES_FILE_NAME;
- propertiesInputStream = new FileInputStream(deviceConfigFilePath);
-
- //load a properties file from class path, inside static method
- properties.load(propertiesInputStream);
-
- iotServerConfigs.setTenantDomain(properties.getProperty(
- AgentConstants.TENANT_DOMAIN));
- iotServerConfigs.setDeviceOwner(properties.getProperty(
- AgentConstants.DEVICE_OWNER_PROPERTY));
- iotServerConfigs.setDeviceId(properties.getProperty(
- AgentConstants.DEVICE_ID_PROPERTY));
- iotServerConfigs.setServerJID(properties.getProperty(
- AgentConstants.SERVER_JID_PROPERTY));
- iotServerConfigs.setDeviceName(properties.getProperty(
- AgentConstants.DEVICE_NAME_PROPERTY));
- iotServerConfigs.setHTTPS_ServerEndpoint(properties.getProperty(
- AgentConstants.SERVER_HTTPS_EP_PROPERTY));
- iotServerConfigs.setHTTP_ServerEndpoint(properties.getProperty(
- AgentConstants.SERVER_HTTP_EP_PROPERTY));
- iotServerConfigs.setApimGatewayEndpoint(properties.getProperty(
- AgentConstants.APIM_GATEWAY_EP_PROPERTY));
- iotServerConfigs.setMqttBrokerEndpoint(properties.getProperty(
- AgentConstants.MQTT_BROKER_EP_PROPERTY));
- iotServerConfigs.setXmppServerEndpoint(properties.getProperty(
- AgentConstants.XMPP_SERVER_EP_PROPERTY));
- iotServerConfigs.setXmppServerName(properties.getProperty(
- AgentConstants.XMPP_SERVER_NAME_PROPERTY));
- iotServerConfigs.setAuthToken(properties.getProperty(
- AgentConstants.AUTH_TOKEN_PROPERTY));
- iotServerConfigs.setRefreshToken(properties.getProperty(
- AgentConstants.REFRESH_TOKEN_PROPERTY));
- iotServerConfigs.setDataPushInterval(Integer.parseInt(properties.getProperty(
- AgentConstants.PUSH_INTERVAL_PROPERTY)));
-
- log.info(AgentConstants.LOG_APPENDER + "Tenant Domain: " +
- iotServerConfigs.getTenantDomain());
- log.info(AgentConstants.LOG_APPENDER + "Device Owner: " +
- iotServerConfigs.getDeviceOwner());
- log.info(AgentConstants.LOG_APPENDER + "Device ID: " +
- iotServerConfigs.getDeviceId());
- log.info(AgentConstants.LOG_APPENDER + "Device Name: " +
- iotServerConfigs.getDeviceName());
- log.info(AgentConstants.LOG_APPENDER + "IoT Server HTTPS EndPoint: " +
- iotServerConfigs.getHTTPS_ServerEndpoint());
- log.info(AgentConstants.LOG_APPENDER + "IoT Server HTTP EndPoint: " +
- iotServerConfigs.getHTTP_ServerEndpoint());
- log.info(AgentConstants.LOG_APPENDER + "API-Manager Gateway EndPoint: " +
- iotServerConfigs.getApimGatewayEndpoint());
- log.info(AgentConstants.LOG_APPENDER + "MQTT Broker EndPoint: " +
- iotServerConfigs.getMqttBrokerEndpoint());
- log.info(AgentConstants.LOG_APPENDER + "XMPP Server EndPoint: " +
- iotServerConfigs.getXmppServerEndpoint());
- log.info(AgentConstants.LOG_APPENDER + "Authentication Token: " +
- iotServerConfigs.getAuthToken());
- log.info(AgentConstants.LOG_APPENDER + "Refresh Token: " +
- iotServerConfigs.getRefreshToken());
- log.info(AgentConstants.LOG_APPENDER + "Data Push Interval: " +
- iotServerConfigs.getDataPushInterval());
- log.info(AgentConstants.LOG_APPENDER + "XMPP Server Name: " +
- iotServerConfigs.getXmppServerName());
-
- } catch (FileNotFoundException ex) {
- log.error(AgentConstants.LOG_APPENDER + "Unable to find " + propertiesFileName +
- " file at: " + AgentConstants.PROPERTIES_FILE_PATH);
- iotServerConfigs = setDefaultDeviceConfigs();
-
- } catch (IOException ex) {
- log.error(AgentConstants.LOG_APPENDER + "Error occurred whilst trying to fetch '" +
- propertiesFileName + "' from: " +
- AgentConstants.PROPERTIES_FILE_PATH);
- iotServerConfigs = setDefaultDeviceConfigs();
-
- } finally {
- if (propertiesInputStream != null) {
- try {
- propertiesInputStream.close();
- } catch (IOException e) {
- log.error(AgentConstants.LOG_APPENDER +
- "Error occurred whilst trying to close InputStream resource used to read the '" +
- propertiesFileName + "' file");
- }
- }
- }
- return iotServerConfigs;
- }
-
- /**
- * Sets the default Device specific configurations listed in the 'AgentConstants' class.
- *
- * @return an object of AgentConfiguration class including all default device specific configs.
- */
- private static AgentConfiguration setDefaultDeviceConfigs() {
- log.warn(AgentConstants.LOG_APPENDER +
- "Default Values are being set to all Agent specific configurations");
-
- AgentConfiguration iotServerConfigs = new AgentConfiguration();
-
- iotServerConfigs.setDeviceOwner(AgentConstants.DEFAULT_SERVER_NAME);
- iotServerConfigs.setDeviceOwner(AgentConstants.DEFAULT_DEVICE_OWNER);
- iotServerConfigs.setDeviceId(AgentConstants.DEFAULT_DEVICE_ID);
- iotServerConfigs.setServerJID(AgentConstants.DEFAULT_SERVER_JID);
- iotServerConfigs.setDeviceName(AgentConstants.DEFAULT_DEVICE_NAME);
- iotServerConfigs.setHTTPS_ServerEndpoint(AgentConstants.DEFAULT_HTTPS_SERVER_EP);
- iotServerConfigs.setHTTP_ServerEndpoint(AgentConstants.DEFAULT_HTTP_SERVER_EP);
- iotServerConfigs.setApimGatewayEndpoint(AgentConstants.DEFAULT_APIM_GATEWAY_EP);
- iotServerConfigs.setMqttBrokerEndpoint(AgentConstants.DEFAULT_MQTT_BROKER_EP);
- iotServerConfigs.setXmppServerEndpoint(AgentConstants.DEFAULT_XMPP_SERVER_EP);
- iotServerConfigs.setAuthToken(AgentConstants.DEFAULT_AUTH_TOKEN);
- iotServerConfigs.setRefreshToken(AgentConstants.DEFAULT_REFRESH_TOKEN);
- iotServerConfigs.setDataPushInterval(AgentConstants.DEFAULT_DATA_PUBLISH_INTERVAL);
-
- return iotServerConfigs;
- }
-
-
- /**
- * This method constructs the URLs for each of the API Endpoints called by the device agent
- * Ex: Register API, Push-Data API
- *
- * @throws AgentCoreOperationException if any error occurs at socket level whilst trying to
- * retrieve the deviceIP of the network-interface read
- * from the configs file
- */
- public static void initializeServerEndPoints() {
- AgentManager agentManager = AgentManager.getInstance();
- String serverSecureEndpoint = agentManager.getAgentConfigs().getHTTPS_ServerEndpoint();
- String serverUnSecureEndpoint = agentManager.getAgentConfigs().getHTTP_ServerEndpoint();
- String backEndContext =AgentConstants.DEVICE_CONTROLLER_API_EP;
- String scepBackEndContext = AgentConstants.DEVICE_SCEP_API_EP;
- String deviceControllerAPIEndpoint = serverSecureEndpoint + backEndContext;
-
- String deviceEnrollmentEndpoint =
- serverUnSecureEndpoint + scepBackEndContext + AgentConstants.DEVICE_ENROLLMENT_API_EP;
- agentManager.setEnrollmentEP(deviceEnrollmentEndpoint);
-
- String registerEndpointURL =
- deviceControllerAPIEndpoint + AgentConstants.DEVICE_REGISTER_API_EP;
- agentManager.setIpRegistrationEP(registerEndpointURL);
-
- String pushDataEndPointURL =
- deviceControllerAPIEndpoint + AgentConstants.DEVICE_PUSH_TEMPERATURE_API_EP;
- agentManager.setPushDataAPIEP(pushDataEndPointURL);
-
- log.info(AgentConstants.LOG_APPENDER + "IoT Server's Device Controller API Endpoint: " +
- deviceControllerAPIEndpoint);
- log.info(AgentConstants.LOG_APPENDER + "Device Enrollment EndPoint: " +
- registerEndpointURL);
- log.info(AgentConstants.LOG_APPENDER + "DeviceIP Registration EndPoint: " +
- registerEndpointURL);
- log.info(AgentConstants.LOG_APPENDER + "Push-Data API EndPoint: " + pushDataEndPointURL);
- }
-
-
- public static String prepareSecurePayLoad(String message) throws AgentCoreOperationException {
- if (EnrollmentManager.getInstance().isEnrolled()) {
- PrivateKey devicePrivateKey = EnrollmentManager.getInstance().getPrivateKey();
- String encodedMessage = Base64.encodeBase64String(message.getBytes());
- String signedPayload;
- try {
- signedPayload = CommunicationUtils.signMessage(encodedMessage, devicePrivateKey);
- } catch (TransportHandlerException e) {
- String errorMsg = "Error occurred whilst trying to sign encrypted message of: [" + message + "]";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
-
- JSONObject jsonPayload = new JSONObject();
- jsonPayload.put(JSON_MESSAGE_KEY, encodedMessage);
- jsonPayload.put(JSON_SIGNATURE_KEY, signedPayload);
- //below statements are temporary fix.
- jsonPayload.put(JSON_SERIAL_KEY, EnrollmentManager.getInstance().getSCEPCertificate().getSerialNumber());
-
- return jsonPayload.toString();
- } else {
- return message;
- }
- }
-
-
- public static String extractMessageFromPayload(String message) throws AgentCoreOperationException {
- if (EnrollmentManager.getInstance().isEnrolled()) {
- String actualMessage;
-
- PublicKey serverPublicKey = EnrollmentManager.getInstance().getServerPublicKey();
- JSONObject jsonPayload = new JSONObject(message);
- Object encodedMessage = jsonPayload.get(JSON_MESSAGE_KEY);
- Object signedPayload = jsonPayload.get(JSON_SIGNATURE_KEY);
- boolean verification;
-
- if (encodedMessage != null && signedPayload != null) {
- try {
- verification = CommunicationUtils.verifySignature(
- encodedMessage.toString(), signedPayload.toString(), serverPublicKey);
- } catch (TransportHandlerException e) {
- String errorMsg =
- "Error occurred whilst trying to verify signature on received message: [" + message + "]";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
- } else {
- String errorMsg = "The received message is in an INVALID format. " +
- "Need to be JSON - {\"Msg\":\"\", \"Sig\":\"\"}.";
- throw new AgentCoreOperationException(errorMsg);
- }
- if (verification) {
- actualMessage = new String(Base64.decodeBase64(encodedMessage.toString()), StandardCharsets.UTF_8);
- } else {
- String errorMsg = "Could not verify payload signature. The message was not signed by a valid client";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg);
- }
- return actualMessage;
- } else {
- return message;
- }
- }
-
- public static String formatMessage(String message) {
- StringBuilder formattedMsg = new StringBuilder(message);
-
- ArrayList keyWordList = new ArrayList();
- keyWordList.add("define");
- keyWordList.add("from");
- keyWordList.add("select");
- keyWordList.add("group");
- keyWordList.add("insert");
- keyWordList.add(";");
-
-
- for (String keyWord : keyWordList) {
- int startIndex = 0;
-
- while (true) {
- int keyWordIndex = formattedMsg.indexOf(keyWord, startIndex);
-
- if (keyWordIndex == -1) {
- break;
- }
-
- if (keyWord.equals(";")) {
- if (keyWordIndex != 0 && (keyWordIndex + 1) != formattedMsg.length() &&
- formattedMsg.charAt(keyWordIndex + 1) == ' ') {
- formattedMsg.setCharAt((keyWordIndex + 1), '\n');
- }
- } else {
- if (keyWordIndex != 0 && formattedMsg.charAt(keyWordIndex - 1) == ' ') {
- formattedMsg.setCharAt((keyWordIndex - 1), '\n');
- }
- }
- startIndex = keyWordIndex + 1;
- }
- }
- return formattedMsg.toString();
- }
-
- public static boolean writeToFile(String content, String fileLocation) {
- File file = new File(fileLocation);
-
- try (FileOutputStream fop = new FileOutputStream(file)) {
-
- // if file doesn't exists, then create it
- if (!file.exists()) {
- file.createNewFile();
- }
-
- // get the content in bytes
- byte[] contentInBytes = content.getBytes(StandardCharsets.UTF_8);
-
- fop.write(contentInBytes);
- fop.flush();
- fop.close();
-
- System.out.println("Done");
- AgentManager.setUpdated(true);
- return true;
-
- } catch (IOException e) {
- e.printStackTrace();
- return false;
- }
- }
-
-}
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/enrollment/EnrollmentManager.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/enrollment/EnrollmentManager.java
deleted file mode 100644
index d6d6954d7..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/enrollment/EnrollmentManager.java
+++ /dev/null
@@ -1,456 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.enrollment;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.bouncycastle.asn1.x500.X500Name;
-import org.bouncycastle.asn1.x500.X500NameBuilder;
-import org.bouncycastle.asn1.x500.style.BCStyle;
-import org.bouncycastle.cert.X509v3CertificateBuilder;
-import org.bouncycastle.cert.jcajce.JcaX509CertificateConverter;
-import org.bouncycastle.jce.provider.BouncyCastleProvider;
-import org.bouncycastle.operator.ContentSigner;
-import org.bouncycastle.operator.OperatorCreationException;
-import org.bouncycastle.operator.jcajce.JcaContentSignerBuilder;
-import org.bouncycastle.pkcs.PKCS10CertificationRequest;
-import org.bouncycastle.pkcs.PKCS10CertificationRequestBuilder;
-import org.bouncycastle.pkcs.jcajce.JcaPKCS10CertificationRequestBuilder;
-import org.jscep.client.Client;
-import org.jscep.client.ClientException;
-import org.jscep.client.EnrollmentResponse;
-import org.jscep.client.verification.CertificateVerifier;
-import org.jscep.client.verification.OptimisticCertificateVerifier;
-import org.jscep.transaction.TransactionException;
-import org.jscep.transport.response.Capabilities;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentConstants;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.exception.AgentCoreOperationException;
-import sun.security.x509.X509CertImpl;
-
-import java.io.IOException;
-import java.math.BigInteger;
-import java.net.MalformedURLException;
-import java.net.URL;
-import java.security.KeyPair;
-import java.security.KeyPairGenerator;
-import java.security.NoSuchAlgorithmException;
-import java.security.NoSuchProviderException;
-import java.security.PrivateKey;
-import java.security.PublicKey;
-import java.security.SecureRandom;
-import java.security.Security;
-import java.security.cert.CertStore;
-import java.security.cert.CertStoreException;
-import java.security.cert.Certificate;
-import java.security.cert.CertificateException;
-import java.security.cert.X509Certificate;
-import java.util.Date;
-
-/**
- * This class controls the entire SCEP enrolment process of the client. It is a singleton for any single client which
- * has the agent code running in it. The main functionality of this class includes generating a Private-Public Key
- * Pair for the enrollment flow, creating the Certificate-Sign-Request using the generated Public-Key to send to the
- * SEP server, Contacting the SCEP server to receive the Signed Certificate and requesting for the server's public
- * key for encrypting the payloads.
- * The provider for all Cryptographic functions used in this class are "BouncyCastle" and the Asymmetric-Key pair
- * algorithm used is "RSA" with a key size of 2048. The signature algorithm used is "SHA1withRSA".
- * This class also holds the "SCEPUrl" (Server Url read from the configs file), the Private-Public Keys of the
- * client, Signed SCEP certificate and the server's public certificate.
- */
-
-//TODO: Need to save cert and keys to file after initial enrollment...
-public class EnrollmentManager {
- private static final Log log = LogFactory.getLog(EnrollmentManager.class);
- private static EnrollmentManager enrollmentManager;
-
- private static final String KEY_PAIR_ALGORITHM = "RSA";
- private static final String PROVIDER = "BC";
- private static final String SIGNATURE_ALG = "SHA1withRSA";
- private static final String CERT_IS_CA_EXTENSION = "is_ca";
- private static final int KEY_SIZE = 2048;
-
- // Seed to our PRNG. Make sure this is initialised randomly, NOT LIKE THIS
- private static final byte[] SEED = ")(*&^%$#@!".getBytes();
- private static final int CERT_VALIDITY = 730;
-
- // URL of our SCEP server
- private String SCEPUrl;
- private PrivateKey privateKey;
- private PublicKey publicKey;
- private PublicKey serverPublicKey;
- private X509Certificate SCEPCertificate;
- private boolean isEnrolled = false;
-
-
- /**
- * Constructor of the EnrollmentManager. Initializes the SCEPUrl as read from the configuration file by the
- * AgentManager.
- */
- private EnrollmentManager() {
- this.SCEPUrl = AgentManager.getInstance().getEnrollmentEP();
- }
-
- /**
- * Method to return the current singleton instance of the EnrollmentManager.
- *
- * @return the current singleton instance if available and if not initializes a new instance and returns it.
- */
- public static EnrollmentManager getInstance() {
- if (enrollmentManager == null) {
- enrollmentManager = new EnrollmentManager();
- }
- return enrollmentManager;
- }
-
-
- /**
- * Method to control the entire enrollment flow. This method calls the method to create the Private-Public Key
- * Pair, calls the specific method to generate the Certificate-Sign-Request, creates a one time self signed
- * certificate to present to the SCEP server with the initial CSR, calls the specific method to connect to the
- * SCEP Server and to get the SCEP Certificate and also calls the method that requests the SCEP Server for its
- * PublicKey for future payload encryption.
- *
- * @throws AgentCoreOperationException if the private method generateCertSignRequest() fails with an error or if
- * there is an error creating a self-sign certificate to present to the
- * server (whilst trying to get the CSR signed)
- */
- public void beginEnrollmentFlow() throws AgentCoreOperationException {
- Security.addProvider(new BouncyCastleProvider());
-
- KeyPair keyPair = generateKeyPair();
- this.privateKey = keyPair.getPrivate();
- this.publicKey = keyPair.getPublic();
-
- if (log.isDebugEnabled()) {
- log.info(AgentConstants.LOG_APPENDER + "DevicePrivateKey:\n[\n" + privateKey + "\n]\n");
- log.info(AgentConstants.LOG_APPENDER + "DevicePublicKey:\n[\n" + publicKey + "\n]\n");
- }
-
- PKCS10CertificationRequest certSignRequest = generateCertSignRequest();
-
- /**
- * -----------------------------------------------------------------------------------------------
- * Generate an ephemeral self-signed certificate. This is needed to present to the CA in the SCEP request.
- * In the future, add proper EKU and attributes in the request. The CA does NOT have to honour any of this.
- * -----------------------------------------------------------------------------------------------
- */
- X500Name issuer = new X500Name("CN=Temporary Issuer");
- BigInteger serial = new BigInteger(32, new SecureRandom());
- Date fromDate = new Date();
- Date toDate = new Date(System.currentTimeMillis() + (CERT_VALIDITY * 86400000L));
-
- // Build the self-signed cert using BC, sign it with our private key (self-signed)
- X509v3CertificateBuilder certBuilder = new X509v3CertificateBuilder(issuer, serial, fromDate, toDate,
- certSignRequest.getSubject(),
- certSignRequest.getSubjectPublicKeyInfo());
- ContentSigner sigGen;
- X509Certificate tmpCert;
-
- try {
- sigGen = new JcaContentSignerBuilder(SIGNATURE_ALG).setProvider(PROVIDER).build(keyPair.getPrivate());
- tmpCert = new JcaX509CertificateConverter().setProvider(PROVIDER).getCertificate(certBuilder.build(sigGen));
- } catch (OperatorCreationException e) {
- String errorMsg = "Error occurred whilst creating a ContentSigner for the Temp-Self-Signed Certificate.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- } catch (CertificateException e) {
- String errorMsg = "Error occurred whilst trying to create Temp-Self-Signed Certificate.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
- /**
- * -----------------------------------------------------------------------------------------------
- */
-
- this.SCEPCertificate = getSignedCertificateFromServer(tmpCert, certSignRequest);
- this.serverPublicKey = initPublicKeyOfServer();
-
- if (log.isDebugEnabled()) {
- log.info(AgentConstants.LOG_APPENDER + "TemporaryCertPublicKey:\n[\n" + tmpCert.getPublicKey() + "\n]\n");
- log.info(AgentConstants.LOG_APPENDER + "ServerPublicKey:\n[\n" + serverPublicKey + "\n]\n");
- }
-
- }
-
-
- /**
- * This method creates the Public-Private Key pair for the current client.
- *
- * @return the generated KeyPair object
- * @throws AgentCoreOperationException when the given Security Provider does not exist or the Algorithmn used to
- * generate the key pair is invalid.
- */
- private KeyPair generateKeyPair() throws AgentCoreOperationException {
-
- // Generate key pair
- KeyPairGenerator keyPairGenerator;
- try {
- keyPairGenerator = KeyPairGenerator.getInstance(KEY_PAIR_ALGORITHM, PROVIDER);
- keyPairGenerator.initialize(KEY_SIZE, new SecureRandom(SEED));
- } catch (NoSuchAlgorithmException e) {
- String errorMsg = "Algorithm [" + KEY_PAIR_ALGORITHM + "] provided for KeyPairGenerator is invalid.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- } catch (NoSuchProviderException e) {
- String errorMsg = "Provider [" + PROVIDER + "] provided for KeyPairGenerator does not exist.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
-
- return keyPairGenerator.genKeyPair();
- }
-
-
- /**
- * This method creates the PKCS10 Certificate Sign Request which is to be sent to the SCEP Server using the
- * generated PublicKey of the client. The certificate parameters used here are the ones from the AgentManager
- * which are the values read from the configurations file.
- *
- * @return the PKCS10CertificationRequest object created using the client specific configs and the generated
- * PublicKey
- * @throws AgentCoreOperationException if an error occurs when creating a content signer to sign the CSR.
- */
- private PKCS10CertificationRequest generateCertSignRequest() throws AgentCoreOperationException {
- // Build the CN for the cert that's being requested.
- X500NameBuilder nameBld = new X500NameBuilder(BCStyle.INSTANCE);
- nameBld.addRDN(BCStyle.CN, AgentManager.getInstance().getAgentConfigs().getTenantDomain());
- nameBld.addRDN(BCStyle.O, AgentManager.getInstance().getAgentConfigs().getDeviceOwner());
- nameBld.addRDN(BCStyle.OU, AgentManager.getInstance().getAgentConfigs().getDeviceOwner());
- nameBld.addRDN(BCStyle.UNIQUE_IDENTIFIER, AgentManager.getInstance().getAgentConfigs().getDeviceId());
- nameBld.addRDN(BCStyle.SERIALNUMBER, AgentManager.getInstance().getAgentConfigs().getDeviceId());
- X500Name principal = nameBld.build();
-
- JcaContentSignerBuilder contentSignerBuilder = new JcaContentSignerBuilder(SIGNATURE_ALG).setProvider(PROVIDER);
- ContentSigner contentSigner;
-
- try {
- contentSigner = contentSignerBuilder.build(this.privateKey);
- } catch (OperatorCreationException e) {
- String errorMsg = "Could not create content signer with private key.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
-
- // Generate the certificate signing request (csr = PKCS10)
- PKCS10CertificationRequestBuilder reqBuilder = new JcaPKCS10CertificationRequestBuilder(principal,
- this.publicKey);
- return reqBuilder.build(contentSigner);
- }
-
-
- /**
- * This method connects to the SCEP Server to fetch the signed SCEP Certificate.
- *
- * @param tempCert the temporary self-signed certificate of the client required for the initial CSR
- * request against the SCEP Server.
- * @param certSignRequest the PKCS10 Certificate-Sign-Request that is to be sent to the SCEP Server.
- * @return the SCEP-Certificate for the client signed by the SCEP-Server.
- * @throws AgentCoreOperationException if the SCEPUrl is invalid or if the flow of sending the CSR and getting
- * the signed certificate fails or if the signed certificate cannot be
- * retrieved from the reply from the server.
- */
- private X509Certificate getSignedCertificateFromServer(X509Certificate tempCert,
- PKCS10CertificationRequest certSignRequest)
- throws AgentCoreOperationException {
-
- X509Certificate signedSCEPCertificate = null;
- URL url;
- EnrollmentResponse enrolResponse;
- CertStore certStore;
-
- try {
- // The URL where we are going to request our cert from
- url = new URL(this.SCEPUrl);
-
- /* // This is called when we get the certificate for our CSR signed by CA
- // Implement this handler to check the CA cert in prod. We can do cert pinning here
- CallbackHandler cb = new CallbackHandler() {
- @Override
- public void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException {
- //throw new UnsupportedOperationException("Not supported yet."); //To change body of generated
- methods, choose Tools | Templates.
- }
- };*/
-
- // Implement verification of the CA cert. VERIFY the CA
- CertificateVerifier ocv = new OptimisticCertificateVerifier();
-
- // Instantiate our SCEP client
- Client scepClient = new Client(url, ocv);
-
- // Submit our cert for signing. SCEP server should allow the client to specify
- // the SCEP CA to issue the request against, if there are multiple CAs
- enrolResponse = scepClient.enrol(tempCert, this.privateKey, certSignRequest);
-
- // Verify we got what we want, and just print out the cert.
- certStore = enrolResponse.getCertStore();
-
- for (Certificate x509Certificate : certStore.getCertificates(null)) {
- if (log.isDebugEnabled()) {
- log.debug(x509Certificate.toString());
- }
- signedSCEPCertificate = (X509Certificate) x509Certificate;
- }
-
- } catch (MalformedURLException ex) {
- String errorMsg = "Could not create valid URL from given SCEP URI: " + SCEPUrl;
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, ex);
- } catch (TransactionException | ClientException e) {
- String errorMsg = "Enrollment process to SCEP Server at: " + SCEPUrl + " failed.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- } catch (CertStoreException e) {
- String errorMsg = "Could not retrieve [Signed-Certificate] from the response message from SCEP-Server.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
-
- return signedSCEPCertificate;
- }
-
-
- /**
- * Gets the Public Key of the SCEP-Server and initializes it for later use. This method contacts the SCEP Server
- * and fetches its CA Cert and extracts the Public Key of the server from the received reply.
- *
- * @return the public key of the SCEP Server which is to be used to encrypt pyloads.
- * @throws AgentCoreOperationException if the SCEPUrl is invalid or if the flow of sending the CSR and getting
- * the signed certificate fails or if the signed certificate cannot be
- * retrieved from the reply from the server.
- */
- private PublicKey initPublicKeyOfServer() throws AgentCoreOperationException {
- URL url;
- CertStore certStore;
- PublicKey serverCertPublicKey = null;
-
- try {
- // The URL where we are going to request our cert from
- url = new URL(this.SCEPUrl);
-
- /* // This is called when we get the certificate for our CSR signed by CA
- // Implement this handler to check the CA cert in prod. We can do cert pinning here
- CallbackHandler cb = new CallbackHandler() {
- @Override
- public void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException {
- //throw new UnsupportedOperationException("Not supported yet."); //To change body of generated
- methods, choose Tools | Templates.
- }
- };*/
-
- // Implement verification of the CA cert. VERIFY the CA
- CertificateVerifier ocv = new OptimisticCertificateVerifier();
-
- // Instantiate our SCEP client
- Client scepClient = new Client(url, ocv);
-
- // Get the CA capabilities. Should return SHA1withRSA for strongest hash and sig. Returns MD5.
- if (log.isDebugEnabled()) {
- Capabilities cap = scepClient.getCaCapabilities();
- log.debug(String.format(
- "\nStrongestCipher: %s,\nStrongestMessageDigest: %s,\nStrongestSignatureAlgorithm: %s," +
- "\nIsRenewalSupported: %s,\nIsRolloverSupported: %s",
- cap.getStrongestCipher(), cap.getStrongestMessageDigest(), cap.getStrongestSignatureAlgorithm(),
- cap.isRenewalSupported(), cap.isRolloverSupported()));
- }
-
- certStore = scepClient.getCaCertificate();
-
- for (Certificate cert : certStore.getCertificates(null)) {
- if (cert instanceof X509Certificate) {
- if (log.isDebugEnabled()) {
- log.debug(((X509Certificate) cert).getIssuerDN().getName());
- }
-
- // I have chosen the CA cert based on its BasicConstraintExtension "is_ca" being set to "true"
- // This is because the returned keystore may contain many certificates including RAs.
- if (((Boolean) ((X509CertImpl) cert).getBasicConstraintsExtension().get(CERT_IS_CA_EXTENSION))) {
- serverCertPublicKey = cert.getPublicKey();
- }
- }
- }
-
- } catch (MalformedURLException ex) {
- String errorMsg = "Could not create valid URL from given SCEP URI: " + SCEPUrl;
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, ex);
- } catch (ClientException e) {
- String errorMsg = "Could not retrieve [Server-Certificate] from the SCEP-Server.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- } catch (CertStoreException e) {
- String errorMsg = "Could not retrieve [Server-Certificates] from the response message from SCEP-Server.";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- } catch (IOException e) {
- String errorMsg = "Error occurred whilst trying to get property ['is_ca'] from the retreived Certificates";
- log.error(errorMsg);
- throw new AgentCoreOperationException(errorMsg, e);
- }
-
- return serverCertPublicKey;
- }
-
-
- /**
- * Gets the Public-Key of the client.
- *
- * @return the public key of the client.
- */
- public PublicKey getPublicKey() {
- return publicKey;
- }
-
- /**
- * Gets the Private-Key of the client.
- *
- * @return the private key of the client.
- */
- public PrivateKey getPrivateKey() {
- return privateKey;
- }
-
- /**
- * Gets the SCEP-Certificate of the client.
- *
- * @return the SCEP Certificate of the client.
- */
- public X509Certificate getSCEPCertificate() {
- return SCEPCertificate;
- }
-
- /**
- * Gets the Public-Key of the Server.
- *
- * @return the pubic key of the server.
- */
- public PublicKey getServerPublicKey() {
- return serverPublicKey;
- }
-
- /**
- * Checks whether the device has already been enrolled with the SCEP Server.
- *
- * @return the enrollment status; 'TRUE' if already enrolled else 'FALSE'.
- */
- public boolean isEnrolled() {
- return isEnrolled;
- }
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/exception/AgentCoreOperationException.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/exception/AgentCoreOperationException.java
deleted file mode 100644
index 7aa102042..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/exception/AgentCoreOperationException.java
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.exception;
-
-
-public class AgentCoreOperationException extends Exception {
- private static final long serialVersionUID = 2736466230451105710L;
-
- private String errorMessage;
-
- public String getErrorMessage() {
- return errorMessage;
- }
-
- public void setErrorMessage(String errorMessage) {
- this.errorMessage = errorMessage;
- }
-
- public AgentCoreOperationException(String msg, Exception nestedEx) {
- super(msg, nestedEx);
- setErrorMessage(msg);
- }
-
- public AgentCoreOperationException(String message, Throwable cause) {
- super(message, cause);
- setErrorMessage(message);
- }
-
- public AgentCoreOperationException(String msg) {
- super(msg);
- setErrorMessage(msg);
- }
-
- public AgentCoreOperationException() {
- super();
- }
-
- public AgentCoreOperationException(Throwable cause) {
- super(cause);
- }
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/sidhdhi/SidhdhiQuery.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/sidhdhi/SidhdhiQuery.java
deleted file mode 100644
index 9aa8b31ab..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/sidhdhi/SidhdhiQuery.java
+++ /dev/null
@@ -1,200 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.sidhdhi;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.apache.http.HttpResponse;
-import org.apache.http.client.HttpClient;
-import org.apache.http.client.methods.HttpGet;
-import org.apache.http.impl.client.DefaultHttpClient;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentConstants;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentUtilOperations;
-import org.wso2.siddhi.core.SiddhiManager;
-import org.wso2.siddhi.core.event.Event;
-import org.wso2.siddhi.core.stream.input.InputHandler;
-import org.wso2.siddhi.core.stream.output.StreamCallback;
-
-import java.io.BufferedReader;
-import java.io.File;
-import java.io.FileOutputStream;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.InputStreamReader;
-import java.nio.charset.Charset;
-import java.nio.charset.StandardCharsets;
-import java.nio.file.Files;
-import java.nio.file.Paths;
-
-/**
- * This class reads the humidity reading and injects values
- * to the siddhiEngine for processing on a routine basis
- * also if the siddhiquery is updated the class takes
- * care of re-initializing same.
- */
-public class SidhdhiQuery implements Runnable {
- private static final Log log = LogFactory.getLog(SidhdhiQuery.class);
- public static final String sidhdhiQueryPath = AgentManager.getInstance().getRootPath() + AgentConstants.CEP_FILE_NAME;
-
- //Bam data push client
- private static SiddhiManager siddhiManager = new SiddhiManager();
-
- public static SiddhiManager getSiddhiManager() {
- return siddhiManager;
- }
-
- public static void setSiddhiManager(SiddhiManager siddhiManager) {
- SidhdhiQuery.siddhiManager = siddhiManager;
- }
-
- public void run() {
-
- //Start the execution plan with pre-defined or previously persisted Siddhi query
- File f = new File(sidhdhiQueryPath);
- while (true) {
- if (f.exists()) {
- //AgentUtilOperations.writeToFile("", sidhdhiQueryPath);
- StartExecutionPlan startExecutionPlan = new StartExecutionPlan().invoke();
- //Check if there is new policy update available
- if (AgentManager.isUpdated()) {
- System.out.print("### Policy Update Detected!");
- //Restart execution plan with new query
- restartSiddhi();
- startExecutionPlan = new StartExecutionPlan().invoke();
- }
- InputHandler inputHandler = startExecutionPlan.getInputHandler();
- //Sending events to Siddhi
- try {
- int humidityReading = AgentManager.getInstance().getTemperature();
- inputHandler.send(new Object[]{"FIRE_1", humidityReading});
- Thread.sleep(3000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- break;
- }
- }
- }
- }
-
- /**
- * Re-Initialize SiddhiManager
- */
- private void restartSiddhi() {
- siddhiManager.shutdown();
- siddhiManager = new SiddhiManager();
- }
-
-
- /**
- * Read content from a given file and return as a string
- *
- * @param path
- * @param encoding
- * @return
- */
- public static String readFile(String path, Charset encoding) {
- byte[] encoded = new byte[0];
- try {
- if (new File(sidhdhiQueryPath).exists()) {
- encoded = Files.readAllBytes(Paths.get(path));
- }
- } catch (IOException e) {
- log.error("Error reading Sidhdhi query from file.");
- }
- return new String(encoded, encoding);
- }
-
-
- /**
- * Read humidity data from API URL
- *
- * @param humidityAPIUrl
- * @return
- */
- private String readHumidityData(String humidityAPIUrl) {
- HttpClient client = new DefaultHttpClient();
- HttpGet request = new HttpGet(humidityAPIUrl);
- String responseStr = null;
- try {
- HttpResponse response = client.execute(request);
- log.debug("Response Code : " + response);
- InputStream input = response.getEntity().getContent();
- BufferedReader br = new BufferedReader(new InputStreamReader(input, "UTF-8"));
- responseStr = String.valueOf(br.readLine());
- br.close();
-
- } catch (IOException e) {
- //log.error("Exception encountered while trying to make get request.");
- log.error("Error while reading humidity reading from file!");
- return responseStr;
- }
- return responseStr;
- }
-
- /**
- * Initialize SiddhiExecution plan
- */
- private static class StartExecutionPlan {
- private InputHandler inputHandler;
-
- public InputHandler getInputHandler() {
- return inputHandler;
- }
-
- public StartExecutionPlan invoke() {
- String executionPlan;
-
- executionPlan = readFile(sidhdhiQueryPath, StandardCharsets.UTF_8);
-
- //Generating runtime
- siddhiManager.addExecutionPlan(executionPlan);
-
- siddhiManager.addCallback("bulbOnStream", new StreamCallback() {
- @Override
- public void receive(Event[] events) {
- // System.out.println("Bulb on Event Fired!");
- if (events.length > 0) {
- if (!AgentManager.getInstance().isAlarmOn()) {
- AgentManager.getInstance().changeAlarmStatus(true);
- System.out.println("#### Performed HTTP call! ON.");
- }
- }
- }
- });
-
- siddhiManager.addCallback("bulbOffStream", new StreamCallback() {
- @Override
- public void receive(Event[] inEvents) {
- // System.out.println("Bulb off Event Fired");
- if (AgentManager.getInstance().isAlarmOn()) {
- AgentManager.getInstance().changeAlarmStatus(false);
- System.out.println("#### Performed HTTP call! OFF.");
- }
- }
-
- });
- //Retrieving InputHandler to push events into Siddhi
- inputHandler = siddhiManager.getInputHandler("fireAlarmEventStream");
- //Starting event processing
- // System.out.println("Execution Plan Started!");
- return this;
- }
- }
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/CommunicationUtils.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/CommunicationUtils.java
deleted file mode 100644
index dfcc4268c..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/CommunicationUtils.java
+++ /dev/null
@@ -1,226 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport;
-
-import org.apache.commons.codec.binary.Base64;
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-
-import javax.crypto.BadPaddingException;
-import javax.crypto.Cipher;
-import javax.crypto.IllegalBlockSizeException;
-import javax.crypto.NoSuchPaddingException;
-import java.nio.charset.StandardCharsets;
-import java.security.InvalidKeyException;
-import java.security.Key;
-import java.security.NoSuchAlgorithmException;
-import java.security.PrivateKey;
-import java.security.PublicKey;
-import java.security.Signature;
-import java.security.SignatureException;
-
-/**
- * This is a utility class which contains methods common to the communication process of a client and the server. The
- * methods include encryption/decryption of payloads and signing/verification of payloads received and to be sent.
- */
-public class CommunicationUtils {
- private static final Log log = LogFactory.getLog(TransportUtils.class);
-
- // The Signature Algorithm used.
- private static final String SHA_512 = "SHA-512";
- // The Encryption Algorithm and the Padding used.
- private static final String CIPHER_PADDING = "RSA/ECB/PKCS1Padding";
-
-
- /**
- * Encrypts the message with the key that's passed in.
- *
- * @param message the message to be encrypted.
- * @param encryptionKey the key to use for the encryption of the message.
- * @return the encrypted message in String format.
- * @throws TransportHandlerException if an error occurs with the encryption flow which can be due to Padding
- * issues, encryption key being invalid or the algorithm used is unrecognizable.
- */
- public static String encryptMessage(String message, Key encryptionKey) throws TransportHandlerException {
- Cipher encrypter;
- byte[] cipherData;
-
- try {
- encrypter = Cipher.getInstance(CIPHER_PADDING);
- encrypter.init(Cipher.ENCRYPT_MODE, encryptionKey);
- cipherData = encrypter.doFinal(message.getBytes(StandardCharsets.UTF_8));
-
- } catch (NoSuchAlgorithmException e) {
- String errorMsg = "Algorithm not found exception occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (NoSuchPaddingException e) {
- String errorMsg = "No Padding error occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (InvalidKeyException e) {
- String errorMsg = "InvalidKey exception occurred for encryptionKey \n[\n" + encryptionKey + "\n]\n";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (BadPaddingException e) {
- String errorMsg = "Bad Padding error occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (IllegalBlockSizeException e) {
- String errorMsg = "Illegal blockSize error occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- }
-
- return Base64.encodeBase64String(cipherData);
- }
-
-///TODO:: Exception needs to change according to the common package
-
- /**
- * Signed a given message using the PrivateKey that's passes in.
- *
- * @param message the message to be signed. Ideally some encrypted payload.
- * @param signatureKey the PrivateKey with which the message is to be signed.
- * @return the Base64Encoded String of the signed payload.
- * @throws TransportHandlerException if some error occurs with the signing process which may be related to the
- * signature algorithm used or the key used for signing.
- */
- public static String signMessage(String message, PrivateKey signatureKey) throws TransportHandlerException {
-
- Signature signature;
- String signedEncodedString;
-
- try {
- signature = Signature.getInstance(SHA_512);
- signature.initSign(signatureKey);
- signature.update(Base64.decodeBase64(message));
-
- byte[] signatureBytes = signature.sign();
- signedEncodedString = Base64.encodeBase64String(signatureBytes);
-
- } catch (NoSuchAlgorithmException e) {
- String errorMsg =
- "Algorithm not found exception occurred for Signature instance of [" + SHA_512 + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (SignatureException e) {
- String errorMsg = "Signature exception occurred for Signature instance of [" + SHA_512 + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (InvalidKeyException e) {
- String errorMsg = "InvalidKey exception occurred for signatureKey \n[\n" + signatureKey + "\n]\n";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- }
-
- return signedEncodedString;
- }
-
-
- /**
- * Verifies some signed-data against the a Public-Key to ensure that it was produced by the holder of the
- * corresponding Private Key.
- *
- * @param data the actual payoad which was signed by some Private Key.
- * @param signedData the signed data produced by signing the payload using a Private Key.
- * @param verificationKey the corresponding Public Key which is an exact pair of the Private-Key with we expect
- * the data to be signed by.
- * @return true if the signed data verifies to be signed by the corresponding Private Key.
- * @throws TransportHandlerException if some error occurs with the verification process which may be related to
- * the signature algorithm used or the key used for signing.
- */
- public static boolean verifySignature(String data, String signedData, PublicKey verificationKey)
- throws TransportHandlerException {
-
- Signature signature;
- boolean verified;
-
- try {
- signature = Signature.getInstance(SHA_512);
- signature.initVerify(verificationKey);
- signature.update(Base64.decodeBase64(data));
-
- verified = signature.verify(Base64.decodeBase64(signedData));
-
- } catch (NoSuchAlgorithmException e) {
- String errorMsg =
- "Algorithm not found exception occurred for Signature instance of [" + SHA_512 + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (SignatureException e) {
- String errorMsg = "Signature exception occurred for Signature instance of [" + SHA_512 + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (InvalidKeyException e) {
- String errorMsg = "InvalidKey exception occurred for signatureKey \n[\n" + verificationKey + "\n]\n";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- }
-
- return verified;
- }
-
-
- /**
- * Encrypts the message with the key that's passed in.
- *
- * @param encryptedMessage the encrypted message that is supposed to be decrypted.
- * @param decryptKey the key to use in the decryption process.
- * @return the decrypted message in String format.
- * @throws TransportHandlerException if an error occurs with the encryption flow which can be due to Padding
- * issues, encryption key being invalid or the algorithm used is unrecognizable.
- */
- public static String decryptMessage(String encryptedMessage, Key decryptKey) throws TransportHandlerException {
-
- Cipher decrypter;
- String decryptedMessage;
-
- try {
-
- decrypter = Cipher.getInstance(CIPHER_PADDING);
- decrypter.init(Cipher.DECRYPT_MODE, decryptKey);
- decryptedMessage = new String(decrypter.doFinal(Base64.decodeBase64(encryptedMessage)),
- StandardCharsets.UTF_8);
-
- } catch (NoSuchAlgorithmException e) {
- String errorMsg = "Algorithm not found exception occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (NoSuchPaddingException e) {
- String errorMsg = "No Padding error occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (InvalidKeyException e) {
- String errorMsg = "InvalidKey exception occurred for encryptionKey \n[\n" + decryptKey + "\n]\n";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (BadPaddingException e) {
- String errorMsg = "Bad Padding error occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (IllegalBlockSizeException e) {
- String errorMsg = "Illegal blockSize error occurred for Cipher instance of [" + CIPHER_PADDING + "]";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- }
-
- return decryptedMessage;
- }
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandler.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandler.java
deleted file mode 100644
index 8034f66e2..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandler.java
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport;
-
-/**
- * This interface consists of the core functionality related to the transport between any device and the server. The
- * interface is an abstraction, regardless of the underlying protocol used for the transport. Implementation of this
- * interface by any class that caters a specific protocol (ex: HTTP, XMPP, MQTT, CoAP) would ideally have methods
- * specific to the protocol used for communication and thees methods that implement the logic related to the devices
- * using the protocol.
- *
- * @param a message type specific to the protocol implemented
- */
-public interface TransportHandler {
- int DEFAULT_TIMEOUT_INTERVAL = 5000; // millis ~ 10 sec
-
- void connect();
-
- boolean isConnected();
-
- //TODO:: Any errors needs to be thrown ahead
- void processIncomingMessage(T message, String... messageParams);
-
- void processIncomingMessage();
-
- void publishDeviceData(String... publishData);
-
- void publishDeviceData();
-
- void disconnect();
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandlerException.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandlerException.java
deleted file mode 100644
index aeccc0fbc..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportHandlerException.java
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport;
-
-public class TransportHandlerException extends Exception {
- private static final long serialVersionUID = 2736466230451105440L;
-
- private String errorMessage;
-
- public String getErrorMessage() {
- return errorMessage;
- }
-
- public void setErrorMessage(String errorMessage) {
- this.errorMessage = errorMessage;
- }
-
- public TransportHandlerException(String msg, Exception nestedEx) {
- super(msg, nestedEx);
- setErrorMessage(msg);
- }
-
- public TransportHandlerException(String message, Throwable cause) {
- super(message, cause);
- setErrorMessage(message);
- }
-
- public TransportHandlerException(String msg) {
- super(msg);
- setErrorMessage(msg);
- }
-
- public TransportHandlerException() {
- super();
- }
-
- public TransportHandlerException(Throwable cause) {
- super(cause);
- }
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportUtils.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportUtils.java
deleted file mode 100644
index 4fb1c5adb..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/TransportUtils.java
+++ /dev/null
@@ -1,303 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-
-import java.io.BufferedReader;
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStreamReader;
-import java.net.DatagramSocket;
-import java.net.HttpURLConnection;
-import java.net.InetAddress;
-import java.net.MalformedURLException;
-import java.net.NetworkInterface;
-import java.net.ServerSocket;
-import java.net.SocketException;
-import java.net.URL;
-import java.nio.charset.StandardCharsets;
-import java.security.NoSuchAlgorithmException;
-import java.security.SecureRandom;
-import java.util.ArrayList;
-import java.util.Enumeration;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Random;
-
-public class TransportUtils {
- private static final Log log = LogFactory.getLog(TransportUtils.class);
-
- public static final int MIN_PORT_NUMBER = 9000;
- public static final int MAX_PORT_NUMBER = 11000;
-
- /**
- * Given a server endpoint as a String, this method splits it into Protocol, Host and Port
- *
- * @param ipString a network endpoint in the format - '://:'
- * @return a map with keys "Protocol", "Host" & "Port" for the related values from the ipString
- * @throws TransportHandlerException
- */
- public static Map getHostAndPort(String ipString)
- throws TransportHandlerException {
- Map ipPortMap = new HashMap();
- String[] ipPortArray = ipString.split(":");
-
- if (ipPortArray.length != 3) {
- String errorMsg =
- "The IP String - '" + ipString +
- "' is invalid. It needs to be in format '://:'.";
- log.info(errorMsg);
- throw new TransportHandlerException(errorMsg);
- }
-
- ipPortMap.put("Protocol", ipPortArray[0]);
- ipPortMap.put("Host", ipPortArray[1].replace("/", ""));
- ipPortMap.put("Port", ipPortArray[2]);
- return ipPortMap;
- }
-
- /**
- * This method validates whether a specific IP Address is of IPv4 type
- *
- * @param ipAddress the IP Address which needs to be validated
- * @return true if it is of IPv4 type and false otherwise
- */
- public static boolean validateIPv4(String ipAddress) {
- try {
- if (ipAddress == null || ipAddress.isEmpty()) {
- return false;
- }
-
- String[] parts = ipAddress.split("\\.");
- if (parts.length != 4) {
- return false;
- }
-
- for (String s : parts) {
- int i = Integer.parseInt(s);
- if ((i < 0) || (i > 255)) {
- return false;
- }
- }
- return !ipAddress.endsWith(".");
-
- } catch (NumberFormatException nfe) {
- log.warn("The IP Address: " + ipAddress + " could not " +
- "be validated against IPv4-style");
- return false;
- }
- }
-
-
- public static Map getInterfaceIPMap() throws TransportHandlerException {
-
- Map interfaceToIPMap = new HashMap();
- Enumeration networkInterfaces;
- String networkInterfaceName = "";
- String ipAddress;
-
- try {
- networkInterfaces = NetworkInterface.getNetworkInterfaces();
- } catch (SocketException exception) {
- String errorMsg =
- "Error encountered whilst trying to get the list of network-interfaces";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, exception);
- }
-
- try {
- for (; networkInterfaces.hasMoreElements(); ) {
- networkInterfaceName = networkInterfaces.nextElement().getName();
-
- if (log.isDebugEnabled()) {
- log.debug("Network Interface: " + networkInterfaceName);
- log.debug("------------------------------------------");
- }
-
- Enumeration interfaceIPAddresses = NetworkInterface.getByName(
- networkInterfaceName).getInetAddresses();
-
- for (; interfaceIPAddresses.hasMoreElements(); ) {
- ipAddress = interfaceIPAddresses.nextElement().getHostAddress();
-
- if (log.isDebugEnabled()) {
- log.debug("IP Address: " + ipAddress);
- }
-
- if (TransportUtils.validateIPv4(ipAddress)) {
- interfaceToIPMap.put(networkInterfaceName, ipAddress);
- }
- }
-
- if (log.isDebugEnabled()) {
- log.debug("------------------------------------------");
- }
- }
- } catch (SocketException exception) {
- String errorMsg =
- "Error encountered whilst trying to get the IP Addresses of the network " +
- "interface: " + networkInterfaceName;
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, exception);
- }
-
- return interfaceToIPMap;
- }
-
-
- /**
- * Attempts to find a free port between the MIN_PORT_NUMBER(9000) and MAX_PORT_NUMBER(11000).
- * Tries 'RANDOMLY picked' port numbers between this range up-until "randomAttempts" number of
- * times. If still fails, then tries each port in descending order from the MAX_PORT_NUMBER
- * whilst skipping already attempted ones via random selection.
- *
- * @param randomAttempts no of times to TEST port numbers picked randomly over the given range
- * @return an available/free port
- */
- public static synchronized int getAvailablePort(int randomAttempts) {
- ArrayList failedPorts = new ArrayList(randomAttempts);
- try {
- SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
- int randomPort = MAX_PORT_NUMBER;
- while (randomAttempts > 0) {
- randomPort = secureRandom.nextInt(MAX_PORT_NUMBER - MIN_PORT_NUMBER) + MIN_PORT_NUMBER;
- if (checkIfPortAvailable(randomPort)) {
- return randomPort;
- }
- failedPorts.add(randomPort);
- randomAttempts--;
- }
- randomPort = MAX_PORT_NUMBER;
- while (true) {
- if (!failedPorts.contains(randomPort) && checkIfPortAvailable(randomPort)) {
- return randomPort;
- }
- randomPort--;
- }
- } catch (NoSuchAlgorithmException e) {
- throw new RuntimeException("SHA1PRNG algorithm could not be found.");
- }
- }
-
-
- private static boolean checkIfPortAvailable(int port) {
- ServerSocket tcpSocket = null;
- DatagramSocket udpSocket = null;
-
- try {
- tcpSocket = new ServerSocket(port);
- tcpSocket.setReuseAddress(true);
-
- udpSocket = new DatagramSocket(port);
- udpSocket.setReuseAddress(true);
- return true;
- } catch (IOException ex) {
- // denotes the port is in use
- } finally {
- if (tcpSocket != null) {
- try {
- tcpSocket.close();
- } catch (IOException e) {
- /* not to be thrown */
- }
- }
-
- if (udpSocket != null) {
- udpSocket.close();
- }
- }
-
- return false;
- }
-
-
- /**
- * This is a utility method that creates and returns a HTTP connection object.
- *
- * @param urlString the URL pattern to which the connection needs to be created
- * @return an HTTPConnection object which cn be used to send HTTP requests
- * @throws TransportHandlerException if errors occur when creating the HTTP connection with
- * the given URL string
- */
- public static HttpURLConnection getHttpConnection(String urlString) throws
- TransportHandlerException {
- URL connectionUrl;
- HttpURLConnection httpConnection;
-
- try {
- connectionUrl = new URL(urlString);
- httpConnection = (HttpURLConnection) connectionUrl.openConnection();
- } catch (MalformedURLException e) {
- String errorMsg = "Error occured whilst trying to form HTTP-URL from string: " + urlString;
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, e);
- } catch (IOException exception) {
- String errorMsg = "Error occured whilst trying to open a connection to: " + urlString;
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, exception);
- }
- return httpConnection;
- }
-
- /**
- * This is a utility method that reads and returns the response from a HTTP connection
- *
- * @param httpConnection the connection from which a response is expected
- * @return the response (as a string) from the given HTTP connection
- * @throws TransportHandlerException if any errors occur whilst reading the response from
- * the connection stream
- */
- public static String readResponseFromHttpRequest(HttpURLConnection httpConnection)
- throws TransportHandlerException {
- BufferedReader bufferedReader;
- try {
- bufferedReader = new BufferedReader(new InputStreamReader(
- httpConnection.getInputStream(), StandardCharsets.UTF_8));
- } catch (IOException exception) {
- String errorMsg = "There is an issue with connecting the reader to the input stream at: " +
- httpConnection.getURL();
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, exception);
- }
-
- String responseLine;
- StringBuilder completeResponse = new StringBuilder();
-
- try {
- while ((responseLine = bufferedReader.readLine()) != null) {
- completeResponse.append(responseLine);
- }
- } catch (IOException exception) {
- String errorMsg = "Error occured whilst trying read from the connection stream at: " +
- httpConnection.getURL();
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, exception);
- }
- try {
- bufferedReader.close();
- } catch (IOException exception) {
- log.error(
- "Could not succesfully close the bufferedReader to the connection at: " + httpConnection.getURL());
- }
- return completeResponse.toString();
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/http/HTTPTransportHandler.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/http/HTTPTransportHandler.java
deleted file mode 100644
index 6abee0b09..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/http/HTTPTransportHandler.java
+++ /dev/null
@@ -1,91 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.http;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.eclipse.jetty.server.Server;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandler;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportUtils;
-
-/**
- * This is an abstract class that implements the "TransportHandler" interface. The interface is an abstraction for
- * the core functionality with regards to device-server communication regardless of the Transport protocol. This
- * specific class contains the HTTP-Transport specific implementations. The class implements utility methods for the
- * case of a HTTP communication. However, this "abstract class", even-though it implements the "TransportHandler"
- * interface, does not contain the logic relevant to the interface methods. The specific functionality of the
- * interface methods are intended to be implemented by the concrete class that extends this abstract class and
- * utilizes the HTTP specific functionality (ideally a device API writer who would like to communicate to the device
- * via HTTP Protocol).
- */
-public abstract class HTTPTransportHandler implements TransportHandler {
- private static final Log log = LogFactory.getLog(HTTPTransportHandler.class);
-
- protected Server server;
- protected int port;
- protected int timeoutInterval;
-
- protected HTTPTransportHandler() {
- this.port = TransportUtils.getAvailablePort(10);
- this.server = new Server(port);
- timeoutInterval = DEFAULT_TIMEOUT_INTERVAL;
- }
-
- protected HTTPTransportHandler(int port) {
- this.port = port;
- this.server = new Server(this.port);
- timeoutInterval = DEFAULT_TIMEOUT_INTERVAL;
- }
-
- protected HTTPTransportHandler(int port, int timeoutInterval) {
- this.port = port;
- this.server = new Server(this.port);
- this.timeoutInterval = timeoutInterval;
- }
-
- public void setTimeoutInterval(int timeoutInterval) {
- this.timeoutInterval = timeoutInterval;
- }
-
- /**
- * Checks whether the HTTP server is up and listening for incoming requests.
- *
- * @return true if the server is up & listening for requests, else false.
- */
- public boolean isConnected() {
- return server.isStarted();
- }
-
-
- protected void incrementPort() {
- this.port = this.port + 1;
- server = new Server(port);
- }
-
- /**
- * Shuts-down the HTTP Server.
- */
- public void closeConnection() throws Exception {
- if (server != null && isConnected()) {
- server.stop();
- }
- }
-
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/mqtt/MQTTTransportHandler.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/mqtt/MQTTTransportHandler.java
deleted file mode 100644
index c11bbe19c..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/mqtt/MQTTTransportHandler.java
+++ /dev/null
@@ -1,366 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.mqtt;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
-import org.eclipse.paho.client.mqttv3.MqttCallback;
-import org.eclipse.paho.client.mqttv3.MqttClient;
-import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
-import org.eclipse.paho.client.mqttv3.MqttException;
-import org.eclipse.paho.client.mqttv3.MqttMessage;
-import org.eclipse.paho.client.mqttv3.MqttSecurityException;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandler;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandlerException;
-
-import java.io.File;
-import java.nio.charset.StandardCharsets;
-
-/**
- * This is an abstract class that implements the "TransportHandler" interface. The interface is an abstraction for
- * the core functionality with regards to device-server communication regardless of the Transport protocol. This
- * specific class contains the HTTP-Transport specific implementations. The class implements utility methods for the
- * case of a HTTP communication. However, this "abstract class", even-though it implements the "TransportHandler"
- * interface, does not contain the logic relevant to the interface methods. The specific functionality of the
- * interface methods are intended to be implemented by the concrete class that extends this abstract class and
- * utilizes the HTTP specific functionality (ideally a device API writer who would like to communicate to the device
- * via HTTP Protocol).
- *
- * This class contains the Device-Management specific implementation for all the MQTT functionality. This includes
- * connecting to a MQTT Broker & subscribing to the appropriate MQTT-topic, action plan upon losing connection or
- * successfully delivering a message to the broker and processing incoming messages. Makes use of the 'Paho-MQTT'
- * library provided by Eclipse Org.
- */
-public abstract class MQTTTransportHandler
- implements MqttCallback, TransportHandler {
- private static final Log log = LogFactory.getLog(MQTTTransportHandler.class);
-
- public static final int DEFAULT_MQTT_QUALITY_OF_SERVICE = 0;
- private static final String DEFAULT_PASSWORD = "";
-
- private MqttClient client;
- private String clientId;
- private MqttConnectOptions options;
- private String clientWillTopic;
-
- protected String mqttBrokerEndPoint;
- protected int timeoutInterval;
- protected String subscribeTopic;
-
- /**
- * Constructor for the MQTTTransportHandler which takes in the owner, type of the device
- * and the MQTT Broker URL and the topic to subscribe.
- *
- * @param deviceOwner the owner of the device.
- * @param deviceType the CDMF Device-Type of the device.
- * @param mqttBrokerEndPoint the IP/URL of the MQTT broker endpoint.
- * @param subscribeTopic the MQTT topic to which the client is to be subscribed
- */
- protected MQTTTransportHandler(String deviceOwner, String deviceType,
- String mqttBrokerEndPoint,
- String subscribeTopic) {
- this.clientId = deviceOwner + ":" + deviceType;
- this.subscribeTopic = subscribeTopic;
- this.clientWillTopic = deviceType + File.separator + "disconnection";
- this.mqttBrokerEndPoint = mqttBrokerEndPoint;
- this.timeoutInterval = DEFAULT_TIMEOUT_INTERVAL;
- this.initSubscriber();
- options.setUserName(AgentManager.getInstance().getAgentConfigs().getAuthToken());
- options.setPassword(DEFAULT_PASSWORD.toCharArray());
- }
-
- /**
- * Constructor for the MQTTTransportHandler which takes in the owner, type of the device
- * and the MQTT Broker URL and the topic to subscribe. Additionally this constructor takes in
- * the reconnection-time interval between successive attempts to connect to the broker.
- *
- * @param deviceOwner the owner of the device.
- * @param deviceType the CDMF Device-Type of the device.
- * @param mqttBrokerEndPoint the IP/URL of the MQTT broker endpoint.
- * @param subscribeTopic the MQTT topic to which the client is to be subscribed
- * @param intervalInMillis the time interval in MILLI-SECONDS between successive
- * attempts to connect to the broker.
- */
- protected MQTTTransportHandler(String deviceOwner, String deviceType,
- String mqttBrokerEndPoint, String subscribeTopic,
- int intervalInMillis) {
- this.clientId = deviceOwner + ":" + deviceType;
- this.subscribeTopic = subscribeTopic;
- //TODO:: Use constant strings
- this.clientWillTopic = deviceType + File.separator + "disconnection";
- this.mqttBrokerEndPoint = mqttBrokerEndPoint;
- this.timeoutInterval = intervalInMillis;
- this.initSubscriber();
- options.setUserName(AgentManager.getInstance().getAgentConfigs().getAuthToken());
- options.setPassword(DEFAULT_PASSWORD.toCharArray());
- }
-
- public void setTimeoutInterval(int timeoutInterval) {
- this.timeoutInterval = timeoutInterval;
- }
-
- /**
- * Initializes the MQTT-Client. Creates a client using the given MQTT-broker endpoint and the
- * clientId (which is constructed by a concatenation of [deviceOwner]:[deviceType]). Also sets
- * the client's options parameter with the clientWillTopic (in-case of connection failure) and
- * other info. Also sets the call-back this current class.
- */
- private void initSubscriber() {
- try {
- client = new MqttClient(this.mqttBrokerEndPoint, clientId, null);
- //TODO:: Need to check for debug
- log.info("MQTT subscriber was created with ClientID : " + clientId);
- } catch (MqttException ex) {
- //TODO:: Remove unnecessary formatting and print exception
- String errorMsg = "MQTT Client Error\n" + "\tReason: " + ex.getReasonCode() +
- "\n\tMessage: " + ex.getMessage() + "\n\tLocalMsg: " +
- ex.getLocalizedMessage() + "\n\tCause: " + ex.getCause() +
- "\n\tException: " + ex;
- log.error(errorMsg);
- //TODO:: Throw the error out
- }
-
- options = new MqttConnectOptions();
- options.setCleanSession(false);
- //TODO:: Use constant strings
- options.setWill(clientWillTopic, "Connection-Lost".getBytes(StandardCharsets.UTF_8), 2,
- true);
- client.setCallback(this);
- }
-
- /**
- * Checks whether the connection to the MQTT-Broker persists.
- *
- * @return true if the client is connected to the MQTT-Broker, else false.
- */
- @Override
- public boolean isConnected() {
- return client.isConnected();
- }
-
-
- /**
- * Connects to the MQTT-Broker and if successfully established connection.
- *
- * @throws TransportHandlerException in the event of 'Connecting to' the MQTT broker fails.
- */
- protected void connectToQueue() throws TransportHandlerException {
- try {
- client.connect(options);
-
- if (log.isDebugEnabled()) {
- log.debug("Subscriber connected to queue at: " + this.mqttBrokerEndPoint);
- }
- } catch (MqttSecurityException ex) {
- String errorMsg = "MQTT Security Exception when connecting to queue\n" + "\tReason: " +
- " " +
- ex.getReasonCode() + "\n\tMessage: " + ex.getMessage() +
- "\n\tLocalMsg: " + ex.getLocalizedMessage() + "\n\tCause: " +
- ex.getCause() + "\n\tException: " + ex;
- //TODO:: Compulsory log of errors and remove formatted error
- if (log.isDebugEnabled()) {
- log.debug(errorMsg);
- }
- throw new TransportHandlerException(errorMsg, ex);
-
- } catch (MqttException ex) {
- //TODO:: Compulsory log of errors and remove formatted error
- String errorMsg = "MQTT Exception when connecting to queue\n" + "\tReason: " +
- ex.getReasonCode() + "\n\tMessage: " + ex.getMessage() +
- "\n\tLocalMsg: " + ex.getLocalizedMessage() + "\n\tCause: " +
- ex.getCause() + "\n\tException: " + ex;
- if (log.isDebugEnabled()) {
- log.debug(errorMsg);
- }
- throw new TransportHandlerException(errorMsg, ex);
- }
- }
-
- /**
- * Subscribes to the MQTT-Topic specific to this MQTT Client. (The MQTT-Topic specific to the
- * device is taken in as a constructor parameter of this class) .
- *
- * @throws TransportHandlerException in the event of 'Subscribing to' the MQTT broker
- * fails.
- */
- protected void subscribeToQueue() throws TransportHandlerException {
- try {
- //TODO:: QoS Level take it from a variable
- client.subscribe(subscribeTopic, 0);
- log.info("Subscriber '" + clientId + "' subscribed to topic: " + subscribeTopic);
- } catch (MqttException ex) {
- //TODO:: Compulsory log of errors and remove formatted error
- String errorMsg = "MQTT Exception when trying to subscribe to topic: " +
- subscribeTopic + "\n\tReason: " + ex.getReasonCode() +
- "\n\tMessage: " + ex.getMessage() + "\n\tLocalMsg: " +
- ex.getLocalizedMessage() + "\n\tCause: " + ex.getCause() +
- "\n\tException: " + ex;
- if (log.isDebugEnabled()) {
- log.debug(errorMsg);
- }
-
- throw new TransportHandlerException(errorMsg, ex);
- }
- }
-
-
- /**
- * This method is used to publish reply-messages for the control signals received.
- * Invocation of this method calls its overloaded-method with a QoS equal to that of the
- * default value.
- *
- * @param topic the topic to which the reply message is to be published.
- * @param payLoad the reply-message (payload) of the MQTT publish action.
- */
- protected void publishToQueue(String topic, String payLoad)
- throws TransportHandlerException {
- publishToQueue(topic, payLoad, DEFAULT_MQTT_QUALITY_OF_SERVICE, false);
- }
-
- /**
- * This is an overloaded method that publishes MQTT reply-messages for control signals
- * received form the IoT-Server.
- *
- * @param topic the topic to which the reply message is to be published
- * @param payLoad the reply-message (payload) of the MQTT publish action.
- * @param qos the Quality-of-Service of the current publish action.
- * Could be 0(At-most once), 1(At-least once) or 2(Exactly once)
- */
- protected void publishToQueue(String topic, String payLoad, int qos, boolean retained)
- throws TransportHandlerException {
- try {
- client.publish(topic, payLoad.getBytes(StandardCharsets.UTF_8), qos, retained);
- if (log.isDebugEnabled()) {
- log.debug("Message: " + payLoad + " to MQTT topic [" + topic +
- "] published successfully");
- }
- } catch (MqttException ex) {
- String errorMsg =
- "MQTT Client Error" + "\n\tReason: " + ex.getReasonCode() + "\n\tMessage: " +
- ex.getMessage() + "\n\tLocalMsg: " + ex.getLocalizedMessage() +
- "\n\tCause: " + ex.getCause() + "\n\tException: " + ex;
- log.info(errorMsg);
- throw new TransportHandlerException(errorMsg, ex);
- }
- }
-
-
- protected void publishToQueue(String topic, MqttMessage message)
- throws TransportHandlerException {
- try {
- client.publish(topic, message);
- if (log.isDebugEnabled()) {
- log.debug("Message: " + message.toString() + " to MQTT topic [" + topic +
- "] published successfully");
- }
- } catch (MqttException ex) {
- //TODO:: Compulsory log of errors and remove formatted error
- String errorMsg =
- "MQTT Client Error" + "\n\tReason: " + ex.getReasonCode() + "\n\tMessage: " +
- ex.getMessage() + "\n\tLocalMsg: " + ex.getLocalizedMessage() +
- "\n\tCause: " + ex.getCause() + "\n\tException: " + ex;
- log.info(errorMsg);
- throw new TransportHandlerException(errorMsg, ex);
- }
- }
-
-
- /**
- * Callback method which is triggered once the MQTT client losers its connection to the broker.
- * Spawns a new thread that executes necessary actions to try and reconnect to the endpoint.
- *
- * @param throwable a Throwable Object containing the details as to why the failure occurred.
- */
- @Override
- public void connectionLost(Throwable throwable) {
- log.warn("Lost Connection for client: " + this.clientId +
- " to " + this.mqttBrokerEndPoint + ".\nThis was due to - " +
- throwable.getMessage());
-
- Thread reconnectThread = new Thread() {
- public void run() {
- connect();
- }
- };
- reconnectThread.setDaemon(true);
- reconnectThread.start();
- }
-
- /**
- * Callback method which is triggered upon receiving a MQTT Message from the broker. Spawns a
- * new thread that executes any actions to be taken with the received message.
- *
- * @param topic the MQTT-Topic to which the received message was published to and the
- * client was subscribed to.
- * @param mqttMessage the actual MQTT-Message that was received from the broker.
- */
- @Override
- public void messageArrived(final String topic, final MqttMessage mqttMessage) {
- if (log.isDebugEnabled()) {
- log.info("Got an MQTT message '" + mqttMessage.toString() + "' for topic '" + topic + "'.");
- }
-
- Thread messageProcessorThread = new Thread() {
- public void run() {
- processIncomingMessage(mqttMessage, topic);
- }
- };
- messageProcessorThread.setDaemon(true);
- messageProcessorThread.start();
- }
-
- /**
- * Callback method which gets triggered upon successful completion of a message delivery to
- * the broker.
- *
- * @param iMqttDeliveryToken the MQTT-DeliveryToken which includes the details about the
- * specific message delivery.
- */
- @Override
- public void deliveryComplete(IMqttDeliveryToken iMqttDeliveryToken) {
- String message = "";
- try {
- message = iMqttDeliveryToken.getMessage().toString();
- } catch (MqttException e) {
- //TODO:: Throw errors
- log.error(
- "Error occurred whilst trying to read the message from the MQTT delivery " +
- "token.");
- }
- String topic = iMqttDeliveryToken.getTopics()[0];
- String client = iMqttDeliveryToken.getClient().getClientId();
-
- if (log.isDebugEnabled()) {
- log.debug("Message - '" + message + "' of client [" + client + "] for the topic (" +
- topic + ") was delivered successfully.");
- }
- }
-
- /**
- * Closes the connection to the MQTT Broker.
- */
- public void closeConnection() throws MqttException {
- if (client != null && isConnected()) {
- client.disconnect();
- }
- }
-}
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/xmpp/XMPPTransportHandler.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/xmpp/XMPPTransportHandler.java
deleted file mode 100644
index ba8320c7c..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/transport/xmpp/XMPPTransportHandler.java
+++ /dev/null
@@ -1,366 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.xmpp;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.jivesoftware.smack.ConnectionConfiguration;
-import org.jivesoftware.smack.PacketListener;
-import org.jivesoftware.smack.SmackConfiguration;
-import org.jivesoftware.smack.XMPPConnection;
-import org.jivesoftware.smack.XMPPException;
-import org.jivesoftware.smack.filter.AndFilter;
-import org.jivesoftware.smack.filter.FromContainsFilter;
-import org.jivesoftware.smack.filter.OrFilter;
-import org.jivesoftware.smack.filter.PacketFilter;
-import org.jivesoftware.smack.filter.PacketTypeFilter;
-import org.jivesoftware.smack.filter.ToContainsFilter;
-import org.jivesoftware.smack.packet.Message;
-import org.jivesoftware.smack.packet.Packet;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandler;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.transport.TransportHandlerException;
-
-/**
- * This is an abstract class that implements the "TransportHandler" interface. The interface is an abstraction for
- * the core functionality with regards to device-server communication regardless of the Transport protocol. This
- * specific class contains the HTTP-Transport specific implementations. The class implements utility methods for the
- * case of a HTTP communication. However, this "abstract class", even-though it implements the "TransportHandler"
- * interface, does not contain the logic relevant to the interface methods. The specific functionality of the
- * interface methods are intended to be implemented by the concrete class that extends this abstract class and
- * utilizes the HTTP specific functionality (ideally a device API writer who would like to communicate to the device
- * via HTTP Protocol).
- *
- * This class contains the IoT-Server specific implementation for all the XMPP functionality. This includes
- * connecting to a XMPP Server & Login-In using the device's/server's XMPP-Account, Setting listeners and filters on
- * incoming XMPP messages and Sending XMPP replies for messages received. Makes use of the 'Smack-XMPP' library
- * provided by jivesoftware/igniterealtime.
- */
-public abstract class XMPPTransportHandler implements TransportHandler {
- private static final Log log = LogFactory.getLog(XMPPTransportHandler.class);
-
- protected String server;
- protected int timeoutInterval; // millis
-
- //TODO:: Shouldnt be hard-coded. Need to be read from configs
- private static final int DEFAULT_XMPP_PORT = 5222;
- private XMPPConnection connection;
- private int port;
- private ConnectionConfiguration config;
- private PacketFilter filter;
- private PacketListener listener;
-
-
- /**
- * Constructor for XMPPTransportHandler passing only the server-IP.
- *
- * @param server the IP of the XMPP server.
- */
- protected XMPPTransportHandler(String server) {
- this.server = server;
- this.port = DEFAULT_XMPP_PORT;
- this.timeoutInterval = DEFAULT_TIMEOUT_INTERVAL;
- initXMPPClient();
- }
-
- /**
- * Constructor for XMPPTransportHandler passing server-IP and the XMPP-port.
- *
- * @param server the IP of the XMPP server.
- * @param port the XMPP server's port to connect to. (default - 5222)
- */
- protected XMPPTransportHandler(String server, int port) {
- this.server = server;
- this.port = port;
- this.timeoutInterval = DEFAULT_TIMEOUT_INTERVAL;
- initXMPPClient();
- }
-
- /**
- * Constructor for XMPPTransportHandler passing server-IP, the XMPP-port and the
- * timeoutInterval used by listeners to the server and for reconnection schedules.
- *
- * @param server the IP of the XMPP server.
- * @param port the XMPP server's port to connect to. (default - 5222)
- * @param timeoutInterval the timeout interval to use for the connection and reconnection
- */
- protected XMPPTransportHandler(String server, int port, int timeoutInterval) {
- this.server = server;
- this.port = port;
- this.timeoutInterval = timeoutInterval;
- initXMPPClient();
- }
-
- /**
- * Sets the client's time-out-limit whilst waiting for XMPP-replies from server.
- *
- * @param millis the time in millis to be set as the time-out-limit whilst waiting for a
- * XMPP-reply.
- */
- public void setTimeoutInterval(int millis) {
- this.timeoutInterval = millis;
- }
-
- /**
- * Checks whether the connection to the XMPP-Server persists.
- *
- * @return true if the client is connected to the XMPP-Server, else false.
- */
- @Override
- public boolean isConnected() {
- return connection.isConnected();
- }
-
- /**
- * Initializes the XMPP Client. Sets the time-out-limit whilst waiting for XMPP-replies from
- * server. Sets the XMPP configurations to connect to the server and creates the
- * XMPPConnection object used for connecting and Logging-In.
- */
- private void initXMPPClient() {
- log.info(String.format("Initializing connection to XMPP Server at %1$s via port " +
- "%2$d.", server, port));
- SmackConfiguration.setPacketReplyTimeout(timeoutInterval);
- config = new ConnectionConfiguration(server, port);
-// TODO:: Need to enable SASL-Authentication appropriately
- config.setSASLAuthenticationEnabled(false);
- config.setSecurityMode(ConnectionConfiguration.SecurityMode.disabled);
- connection = new XMPPConnection(config);
- }
-
-//TODO:: Re-check all exception handling
-
- /**
- * Connects to the XMPP-Server and if attempt unsuccessful, then throws exception.
- *
- * @throws TransportHandlerException in the event of 'Connecting to' the XMPP server fails.
- */
- protected void connectToServer() throws TransportHandlerException {
- try {
- connection.connect();
- log.info(String.format("Connection to XMPP Server at %1$s established successfully......", server));
-
- } catch (XMPPException xmppExcepion) {
- String errorMsg = "Connection attempt to the XMPP Server at " + server + " via port " + port + " failed.";
- log.info(errorMsg);
- throw new TransportHandlerException(errorMsg, xmppExcepion);
- }
- }
-
- /**
- * If successfully established connection, then tries to Log in using the device's XMPP
- * Account credentials.
- *
- * @param username the username of the device's XMPP-Account.
- * @param password the password of the device's XMPP-Account.
- * @param resource the resource the resource, specific to the XMPP-Account to which the login
- * is made to
- * @throws TransportHandlerException in the event of 'Logging into' the XMPP server fails.
- */
- protected void loginToServer(String username, String password, String resource)
- throws TransportHandlerException {
- if (isConnected()) {
- try {
- if (resource == null) {
- connection.login(username, password);
- log.info(String.format("Logged into XMPP Server at %1$s as user %2$s......", server, username));
- } else {
- connection.login(username, password, resource);
- log.info(String.format("Logged into XMPP Server at %1$s as user %2$s on resource %3$s......",
- server, username, resource));
- }
- } catch (XMPPException xmppException) {
- String errorMsg =
- "Login attempt to the XMPP Server at " + server + " with username - " + username + " failed.";
- log.error(errorMsg);
- throw new TransportHandlerException(errorMsg, xmppException);
- }
- } else {
- String errorMsg = "Not connected to XMPP-Server to attempt Login. Please 'connectToServer' before Login";
- throw new TransportHandlerException(errorMsg);
- }
- }
-
-
- /**
- * Sets a filter for all the incoming XMPP-Messages on the Sender's JID (XMPP-Account ID).
- * Also creates a listener for the incoming messages and connects the listener to the
- * XMPPConnection alongside the set filter.
- *
- * @param senderJID the JID (XMPP-Account ID of the sender) to which the filter is to be set.
- */
- protected void setFilterOnSender(String senderJID) {
- filter = new AndFilter(new PacketTypeFilter(Message.class), new FromContainsFilter(
- senderJID));
- listener = new PacketListener() {
- @Override
- public void processPacket(Packet packet) {
- if (packet instanceof Message) {
- final Message xmppMessage = (Message) packet;
- Thread msgProcessThread = new Thread() {
- public void run() {
- processIncomingMessage(xmppMessage);
- }
- };
- msgProcessThread.setDaemon(true);
- msgProcessThread.start();
- }
- }
- };
-
- connection.addPacketListener(listener, filter);
- }
-
-
- /**
- * Sets a filter for all the incoming XMPP-Messages on the Receiver's JID (XMPP-Account ID).
- * Also creates a listener for the incoming messages and connects the listener to the
- * XMPPConnection alongside the set filter.
- *
- * @param receiverJID the JID (XMPP-Account ID of the receiver) to which the filter is to be
- * set.
- */
- protected void setFilterOnReceiver(String receiverJID) {
- filter = new AndFilter(new PacketTypeFilter(Message.class), new ToContainsFilter(
- receiverJID));
- listener = new PacketListener() {
- @Override
- public void processPacket(Packet packet) {
- if (packet instanceof Message) {
- final Message xmppMessage = (Message) packet;
- Thread msgProcessThread = new Thread() {
- public void run() {
- processIncomingMessage(xmppMessage);
- }
- };
- msgProcessThread.setDaemon(true);
- msgProcessThread.start();
- }
- }
- };
-
- connection.addPacketListener(listener, filter);
- }
-
-
- /**
- * Sets a filter for all the incoming XMPP-Messages on the From-JID & To-JID (XMPP-Account IDs)
- * passed in. Also creates a listener for the incoming messages and connects the listener to
- * the XMPPConnection alongside the set filter.
- *
- * @param senderJID the From-JID (XMPP-Account ID) to which the filter is to be set.
- * @param receiverJID the To-JID (XMPP-Account ID) to which the filter is to be set.
- * @param andCondition if true: then filter is set with 'AND' operator (senderJID &&
- * receiverJID),
- * if false: then the filter is set with 'OR' operator (senderJID |
- * receiverJID)
- */
- protected void setMessageFilterAndListener(String senderJID, String receiverJID, boolean
- andCondition) {
- PacketFilter jidFilter;
-
- if (andCondition) {
- jidFilter = new AndFilter(new FromContainsFilter(senderJID), new ToContainsFilter(
- receiverJID));
- } else {
- jidFilter = new OrFilter(new FromContainsFilter(senderJID), new ToContainsFilter(
- receiverJID));
- }
-
- filter = new AndFilter(new PacketTypeFilter(Message.class), jidFilter);
- listener = new PacketListener() {
- @Override
- public void processPacket(Packet packet) {
- if (packet instanceof Message) {
- final Message xmppMessage = (Message) packet;
- Thread msgProcessThread = new Thread() {
- public void run() {
- processIncomingMessage(xmppMessage);
- }
- };
- msgProcessThread.setDaemon(true);
- msgProcessThread.start();
- }
- }
- };
-
- connection.addPacketListener(listener, filter);
- }
-
-
- /**
- * Sends an XMPP message. Calls the overloaded method with Subject set to "Reply-From-Device"
- *
- * @param JID the JID (XMPP Account ID) to which the message is to be sent to.
- * @param message the XMPP-Message that is to be sent.
- */
- protected void sendXMPPMessage(String JID, String message) {
- sendXMPPMessage(JID, message, "XMPP-Message");
- }
-
-
- /**
- * Overloaded method to send an XMPP message. Includes the subject to be mentioned in the
- * message that is sent.
- *
- * @param JID the JID (XMPP Account ID) to which the message is to be sent to.
- * @param message the XMPP-Message that is to be sent.
- * @param subject the subject that the XMPP-Message would carry.
- */
- protected void sendXMPPMessage(String JID, String message, String subject) {
- Message xmppMessage = new Message();
- xmppMessage.setTo(JID);
- xmppMessage.setSubject(subject);
- xmppMessage.setBody(message);
- xmppMessage.setType(Message.Type.chat);
- sendXMPPMessage(JID, xmppMessage);
- }
-
-
- /**
- * Sends an XMPP message.
- *
- * @param JID the JID (XMPP Account ID) to which the message is to be sent to.
- * @param xmppMessage the XMPP-Message that is to be sent.
- */
- protected void sendXMPPMessage(String JID, Message xmppMessage) {
- connection.sendPacket(xmppMessage);
- if (log.isDebugEnabled()) {
- log.debug("Message: '" + xmppMessage.getBody() + "' sent to XMPP JID [" + JID +
- "] sent successfully.");
- }
- }
-
-
- /**
- * Disables default debugger provided by the XMPPConnection.
- */
- protected void disableDebugger() {
- connection.DEBUG_ENABLED = false;
- }
-
-
- /**
- * Closes the connection to the XMPP Server.
- */
- public void closeConnection() {
- if (connection != null && isConnected()) {
- connection.disconnect();
- }
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/VirtualHardwareManager.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/VirtualHardwareManager.java
deleted file mode 100644
index 1a676ed82..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/VirtualHardwareManager.java
+++ /dev/null
@@ -1,223 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.virtual;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentConstants;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentUtilOperations;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.virtual.ui.AgentUI;
-
-import javax.sound.midi.InvalidMidiDataException;
-import javax.sound.midi.MidiSystem;
-import javax.sound.midi.MidiUnavailableException;
-import javax.sound.midi.Sequence;
-import javax.sound.midi.Sequencer;
-import javax.sound.sampled.Clip;
-import javax.swing.*;
-import java.io.IOException;
-import java.io.InputStream;
-import java.security.NoSuchAlgorithmException;
-import java.security.SecureRandom;
-
-/**
- * This class use to emulate virtual hardware functionality
- */
-public class VirtualHardwareManager {
-
- private static final Log log = LogFactory.getLog(VirtualHardwareManager.class);
-
- private static VirtualHardwareManager virtualHardwareManager;
-
- private AgentUI agentUI;
- private Sequencer sequencer = null;
-
- private int temperature = 30, humidity = 30;
- private int temperatureMin = 20, temperatureMax = 50, humidityMin = 20, humidityMax = 50;
- private int temperatureSVF = 50, humiditySVF = 50;
- private boolean isTemperatureRandomized, isHumidityRandomized;
- private boolean isTemperatureSmoothed, isHumiditySmoothed;
-
- private VirtualHardwareManager(){
- }
-
- public static VirtualHardwareManager getInstance(){
- if (virtualHardwareManager == null){
- virtualHardwareManager = new VirtualHardwareManager();
- }
- return virtualHardwareManager;
- }
-
- public void init(){
- try {
- // Set System L&F for Device UI
- UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
- } catch (UnsupportedLookAndFeelException e) {
- log.error(
- "'UnsupportedLookAndFeelException' error occurred whilst initializing the" +
- " Agent UI.");
- } catch (ClassNotFoundException e) {
- log.error(
- "'ClassNotFoundException' error occurred whilst initializing the Agent UI.");
- } catch (InstantiationException e) {
- log.error(
- "'InstantiationException' error occurred whilst initializing the Agent UI.");
- } catch (IllegalAccessException e) {
- log.error(
- "'IllegalAccessException' error occurred whilst initializing the Agent UI.");
- }
- java.awt.EventQueue.invokeLater(new Runnable() {
- public void run() {
- agentUI = new AgentUI();
- agentUI.setVisible(true);
- }
- });
- setAudioSequencer();
- }
-
- /**
- * Get temperature from emulated device
- * @return Temperature
- */
- public int getTemperature() {
- if (isTemperatureRandomized) {
- temperature = getRandom(temperatureMax, temperatureMin, temperature,
- isTemperatureSmoothed, temperatureSVF);
- agentUI.updateTemperature(temperature);
- }
- return temperature;
- }
-
- public void setTemperature(int temperature) {
- this.temperature = temperature;
- }
-
- /**
- * Get humidity from emulated device
- * @return Humidity
- */
- public int getHumidity() {
- if (isHumidityRandomized) {
- humidity = getRandom(humidityMax, humidityMin, humidity, isHumiditySmoothed,
- humiditySVF);
- agentUI.updateHumidity(humidity);
- }
- return humidity;
- }
-
- public void setHumidity(int humidity) {
- this.humidity = humidity;
- }
-
- public void setTemperatureMin(int temperatureMin) {
- this.temperatureMin = temperatureMin;
- }
-
- public void setTemperatureMax(int temperatureMax) {
- this.temperatureMax = temperatureMax;
- }
-
- public void setHumidityMin(int humidityMin) {
- this.humidityMin = humidityMin;
- }
-
- public void setHumidityMax(int humidityMax) {
- this.humidityMax = humidityMax;
- }
-
- public void setIsHumidityRandomized(boolean isHumidityRandomized) {
- this.isHumidityRandomized = isHumidityRandomized;
- }
-
- public void setIsTemperatureRandomized(boolean isTemperatureRandomized) {
- this.isTemperatureRandomized = isTemperatureRandomized;
- }
-
- public void setTemperatureSVF(int temperatureSVF) {
- this.temperatureSVF = temperatureSVF;
- }
-
- public void setHumiditySVF(int humiditySVF) {
- this.humiditySVF = humiditySVF;
- }
-
- public void setIsTemperatureSmoothed(boolean isTemperatureSmoothed) {
- this.isTemperatureSmoothed = isTemperatureSmoothed;
- }
-
- public void setIsHumiditySmoothed(boolean isHumiditySmoothed) {
- this.isHumiditySmoothed = isHumiditySmoothed;
- }
-
- public void changeAlarmStatus(boolean isOn) {
- agentUI.setAlarmStatus(isOn);
-
- if (isOn) {
- sequencer.start();
- } else {
- sequencer.stop();
- }
- }
-
- public void addToPolicyLog(String policy) {
- agentUI.addToPolicyLog(policy);
- }
-
-
- private int getRandom(int max, int min, int current, boolean isSmoothed, int svf) {
-
- if (isSmoothed) {
- int offset = (max - min) * svf / 100;
- double mx = current + offset;
- max = (mx > max) ? max : (int) Math.round(mx);
-
- double mn = current - offset;
- min = (mn < min) ? min : (int) Math.round(mn);
- }
- try {
- SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
- return secureRandom.nextInt(max - min) + min;
- } catch (NoSuchAlgorithmException e) {
- throw new RuntimeException("SHA1PRNG algorithm could not be found.");
- }
-
- }
-
- private void setAudioSequencer() {
- InputStream audioSrc = AgentUtilOperations.class.getResourceAsStream(
- "/" + AgentConstants.AUDIO_FILE_NAME);
- Sequence sequence;
-
- try {
- sequence = MidiSystem.getSequence(audioSrc);
- sequencer = MidiSystem.getSequencer();
- sequencer.open();
- sequencer.setSequence(sequence);
- } catch (InvalidMidiDataException e) {
- log.error("AudioReader: Error whilst setting MIDI Audio reader sequence");
- } catch (IOException e) {
- log.error("AudioReader: Error whilst getting audio sequence from stream");
- } catch (MidiUnavailableException e) {
- log.error("AudioReader: Error whilst openning MIDI Audio reader sequencer");
- }
-
- sequencer.setLoopCount(Clip.LOOP_CONTINUOUSLY);
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/ui/AgentUI.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/ui/AgentUI.java
deleted file mode 100644
index 963872555..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/java/org/wso2/carbon/device/mgt/iot/virtualfirealarm/agent/advanced/virtual/ui/AgentUI.java
+++ /dev/null
@@ -1,1034 +0,0 @@
-/*
- * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
- *
- * WSO2 Inc. licenses this file to you 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 org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.virtual.ui;
-
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentConstants;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentManager;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.core.AgentUtilOperations;
-import org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.virtual.VirtualHardwareManager;
-
-import javax.swing.*;
-import java.awt.*;
-import java.net.URI;
-import java.net.URL;
-import java.util.ArrayList;
-
-public class AgentUI extends JFrame {
-
- private boolean isTemperatureRandomized, isHumidityRandomized;
- private boolean isTemperatureSmoothed, isHumiditySmoothed;
-
- private volatile boolean isAlarmOn = false;
-
- private final Object _lock = new Object();
-
- private JLabel picLabelBulbOn, picLabelBulbOff;
-
- private volatile java.util.List policyLogs = new ArrayList<>();
-
- // Variables declaration - do not modify
- private JCheckBox chkbxEmulate;
- private JCheckBox chkbxHumidityRandom;
- private JCheckBox chkbxHumiditySmooth;
- private JCheckBox chkbxTemperatureRandom;
- private JCheckBox chkbxTemperatureSmooth;
- private JComboBox cmbInterface;
- private JComboBox cmbPeriod;
- private JComboBox cmbProtocol;
- private JLabel jLabel1;
- private JLabel jLabel10;
- private JLabel jLabel11;
- private JLabel jLabel12;
- private JLabel jLabel2;
- private JLabel jLabel20;
- private JLabel jLabel23;
- private JLabel jLabel24;
- private JLabel jLabel25;
- private JLabel jLabel3;
- private JLabel jLabel4;
- private JLabel jLabel5;
- private JLabel jLabel6;
- private JLabel jLabel7;
- private JLabel jLabel8;
- private JLabel jLabel9;
- private JPanel jPanel1;
- private JPanel jPanel2;
- private JPanel jPanel3;
- private JPanel jPanel4;
- private JPanel jPanel6;
- private JPanel jPanel7;
- private JPanel jPanel8;
- private JPanel jPanel9;
- private JScrollPane jScrollPane1;
- private JSeparator jSeparator1;
- private JSeparator jSeparator5;
- private JLabel lblAgentName;
- private JLabel lblStatus;
- private JPanel pnlBulbStatus;
- private JSpinner spinnerHumidity;
- private JSpinner spinnerInterval;
- private JSpinner spinnerTemperature;
- private JTextArea txtAreaLogs;
- private JTextField txtHumidityMax;
- private JTextField txtHumidityMin;
- private JTextField txtHumiditySVF;
- private JTextField txtTemperatureMax;
- private JTextField txtTemperatureMin;
- private JTextField txtTemperatureSVF;
- // End of variables declaration
-
- //Update UI from AgentManager changes
- private Runnable uiUpdater = new Runnable() {
- @Override
- public void run() {
- while (true) {
- EventQueue.invokeLater(new Runnable() {
- @Override
- public void run() {
- pnlBulbStatus.removeAll();
- pnlBulbStatus.add(isAlarmOn ? picLabelBulbOn : picLabelBulbOff);
- pnlBulbStatus.updateUI();
- lblStatus.setText(AgentManager.getInstance().getAgentStatus());
- String policy = getPolicyLog();
- if (policy != null){
- txtAreaLogs.append("\n" + policy);
- txtAreaLogs.append("\n--------------------------------------------------\n");
- }
- if (isTemperatureRandomized) {
- txtTemperatureMinActionPerformed(null);
- txtTemperatureMaxActionPerformed(null);
- if (isTemperatureSmoothed) {
- txtTemperatureSVFActionPerformed(null);
- }
- }
- if (isHumidityRandomized) {
- txtHumidityMinActionPerformed(null);
- txtHumidityMaxActionPerformed(null);
- if (isHumiditySmoothed) {
- txtHumiditySVFActionPerformed(null);
- }
- }
- }
- });
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- break;
- }
- }
- }
- };
-
-
- /**
- * Creates new form AgentUI
- */
- public AgentUI() {
- initComponents();
- }
-
- /**
- * This method is called from within the constructor to initialize the form.
- * WARNING: Do NOT modify this code. The content of this method is always
- * regenerated by the Form Editor.
- */
- @SuppressWarnings("unchecked")
- private void initComponents() {
-
- lblAgentName = new JLabel();
- jLabel2 = new JLabel();
- jPanel1 = new JPanel();
- jLabel3 = new JLabel();
- pnlBulbStatus = new JPanel();
- jPanel2 = new JPanel();
- jLabel4 = new JLabel();
- chkbxTemperatureRandom = new JCheckBox();
- jSeparator1 = new JSeparator();
- jPanel7 = new JPanel();
- jLabel5 = new JLabel();
- txtTemperatureMin = new JTextField();
- jLabel6 = new JLabel();
- txtTemperatureMax = new JTextField();
- jLabel10 = new JLabel();
- txtTemperatureSVF = new JTextField();
- spinnerTemperature = new JSpinner();
- chkbxTemperatureSmooth = new JCheckBox();
- jPanel6 = new JPanel();
- jLabel20 = new JLabel();
- lblStatus = new JLabel();
- jPanel8 = new JPanel();
- jLabel23 = new JLabel();
- chkbxHumidityRandom = new JCheckBox();
- jSeparator5 = new JSeparator();
- jPanel9 = new JPanel();
- jLabel24 = new JLabel();
- txtHumidityMin = new JTextField();
- jLabel25 = new JLabel();
- txtHumidityMax = new JTextField();
- txtHumiditySVF = new JTextField();
- jLabel11 = new JLabel();
- spinnerHumidity = new JSpinner();
- chkbxHumiditySmooth = new JCheckBox();
- jPanel3 = new JPanel();
- jLabel7 = new JLabel();
- spinnerInterval = new JSpinner();
- jLabel8 = new JLabel();
- jLabel9 = new JLabel();
- cmbProtocol = new JComboBox();
- jLabel12 = new JLabel();
- cmbInterface = new JComboBox();
- jScrollPane1 = new JScrollPane();
- txtAreaLogs = new JTextArea();
- jPanel4 = new JPanel();
- chkbxEmulate = new JCheckBox();
- cmbPeriod = new JComboBox();
- jLabel1 = new JLabel();
-
- setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
- setTitle("Fire Alarm Emulator");
- setResizable(false);
- Dimension dim = Toolkit.getDefaultToolkit().getScreenSize();
- setLocation(dim.width / 2 - 650 / 2, dim.height / 2 - 440 / 2);
-
- lblAgentName.setFont(new Font("Cantarell", 1, 24)); // NOI18N
- lblAgentName.setHorizontalAlignment(SwingConstants.LEFT);
- lblAgentName.setText("Device Name: " + AgentManager.getInstance().getDeviceName());
-
- jLabel2.setHorizontalAlignment(SwingConstants.CENTER);
- jLabel2.setText("Copyright (c) 2015, WSO2 Inc.");
-
- jPanel1.setBackground(new Color(220, 220, 220));
-
- jLabel3.setFont(new Font("Cantarell", 0, 18)); // NOI18N
- jLabel3.setHorizontalAlignment(SwingConstants.CENTER);
- jLabel3.setText("Alarm Status");
-
- pnlBulbStatus.setBackground(new Color(220, 220, 220));
-
- GroupLayout pnlBulbStatusLayout = new GroupLayout(pnlBulbStatus);
- pnlBulbStatus.setLayout(pnlBulbStatusLayout);
- pnlBulbStatusLayout.setHorizontalGroup(
- pnlBulbStatusLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGap(0, 0, Short.MAX_VALUE)
- );
- pnlBulbStatusLayout.setVerticalGroup(
- pnlBulbStatusLayout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGap(0, 167, Short.MAX_VALUE)
- );
-
- GroupLayout jPanel1Layout = new GroupLayout(jPanel1);
- jPanel1.setLayout(jPanel1Layout);
- jPanel1Layout.setHorizontalGroup(
- jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(GroupLayout.Alignment.TRAILING, jPanel1Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel1Layout.createParallelGroup(
- GroupLayout.Alignment.TRAILING)
- .addComponent(pnlBulbStatus,
- GroupLayout
- .DEFAULT_SIZE,
- GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addComponent(jLabel3,
- GroupLayout.DEFAULT_SIZE,
- 190, Short.MAX_VALUE))
- .addContainerGap())
- );
- jPanel1Layout.setVerticalGroup(
- jPanel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel1Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(jLabel3)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(pnlBulbStatus, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addContainerGap())
- );
-
- jPanel2.setBackground(new Color(220, 220, 220));
-
- jLabel4.setFont(new Font("Cantarell", 0, 18)); // NOI18N
- jLabel4.setHorizontalAlignment(SwingConstants.CENTER);
- jLabel4.setText("Temperature");
-
- chkbxTemperatureRandom.setText("Randomize Data");
- chkbxTemperatureRandom.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxTemperatureRandomActionPerformed(evt);
- }
- });
-
- jSeparator1.setOrientation(SwingConstants.VERTICAL);
-
- jPanel7.setBackground(new Color(220, 220, 220));
-
- jLabel5.setHorizontalAlignment(SwingConstants.LEFT);
- jLabel5.setText("Min");
-
- txtTemperatureMin.setHorizontalAlignment(JTextField.CENTER);
- txtTemperatureMin.setText("20");
- txtTemperatureMin.setEnabled(false);
- txtTemperatureMin.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtTemperatureMinActionPerformed(evt);
- }
- });
-
- jLabel6.setHorizontalAlignment(SwingConstants.RIGHT);
- jLabel6.setText("Max");
-
- txtTemperatureMax.setHorizontalAlignment(JTextField.CENTER);
- txtTemperatureMax.setText("50");
- txtTemperatureMax.setEnabled(false);
- txtTemperatureMax.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtTemperatureMaxActionPerformed(evt);
- }
- });
-
- jLabel10.setHorizontalAlignment(SwingConstants.RIGHT);
- jLabel10.setText("SV %");
-
- txtTemperatureSVF.setHorizontalAlignment(JTextField.CENTER);
- txtTemperatureSVF.setText("50");
- txtTemperatureSVF.setEnabled(false);
- txtTemperatureSVF.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtTemperatureSVFActionPerformed(evt);
- }
- });
-
- GroupLayout jPanel7Layout = new GroupLayout(jPanel7);
- jPanel7.setLayout(jPanel7Layout);
- jPanel7Layout.setHorizontalGroup(
- jPanel7Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel7Layout.createSequentialGroup()
- .addComponent(jLabel5)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtTemperatureMin, GroupLayout.PREFERRED_SIZE, 45, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel6)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtTemperatureMax, GroupLayout.PREFERRED_SIZE, 45, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel10)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtTemperatureSVF, GroupLayout.PREFERRED_SIZE, 45, GroupLayout.PREFERRED_SIZE)
- .addContainerGap(GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE))
- );
- jPanel7Layout.setVerticalGroup(
- jPanel7Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(GroupLayout.Alignment.TRAILING, jPanel7Layout
- .createSequentialGroup()
- .addContainerGap(GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addGroup(jPanel7Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(txtTemperatureMin,
- GroupLayout
- .PREFERRED_SIZE,
- GroupLayout
- .DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE)
- .addComponent(txtTemperatureMax,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel6)
- .addComponent(jLabel5)
- .addComponent(jLabel10)
- .addComponent(txtTemperatureSVF,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE))
- .addGap(35, 35, 35))
- );
-
- spinnerTemperature.setFont(new Font("Cantarell", 1, 24)); // NOI18N
- spinnerTemperature.setModel(new SpinnerNumberModel(30, 0, 100, 1));
- spinnerTemperature.addChangeListener(new javax.swing.event.ChangeListener() {
- public void stateChanged(javax.swing.event.ChangeEvent evt) {
- spinnerTemperatureStateChanged(evt);
- }
- });
-
- chkbxTemperatureSmooth.setText("Smooth Variation");
- chkbxTemperatureSmooth.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxTemperatureSmoothActionPerformed(evt);
- }
- });
-
- GroupLayout jPanel2Layout = new GroupLayout(jPanel2);
- jPanel2.setLayout(jPanel2Layout);
- jPanel2Layout.setHorizontalGroup(
- jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING, false)
- .addComponent(jLabel4, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(spinnerTemperature))
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jSeparator1, GroupLayout.PREFERRED_SIZE, 6, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addComponent(jPanel7, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addComponent(chkbxTemperatureRandom)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(chkbxTemperatureSmooth)))
- .addContainerGap())
- );
- jPanel2Layout.setVerticalGroup(
- jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel2Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addComponent(jSeparator1)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addGroup(jPanel2Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(
- chkbxTemperatureRandom)
- .addComponent(
- chkbxTemperatureSmooth))
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel7, GroupLayout.PREFERRED_SIZE, 51, GroupLayout.PREFERRED_SIZE)
- .addGap(0, 0, Short.MAX_VALUE))
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addComponent(jLabel4, GroupLayout.PREFERRED_SIZE, 23, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(spinnerTemperature)))
- .addContainerGap())
- );
-
- jPanel6.setBackground(new Color(253, 254, 209));
-
- jLabel20.setText("Connection Status:");
- jLabel20.setVerticalTextPosition(SwingConstants.TOP);
-
- lblStatus.setFont(new Font("Cantarell", 1, 15)); // NOI18N
- lblStatus.setText("Not Connected");
-
- GroupLayout jPanel6Layout = new GroupLayout(jPanel6);
- jPanel6.setLayout(jPanel6Layout);
- jPanel6Layout.setHorizontalGroup(
- jPanel6Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel6Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(jLabel20)
- .addPreferredGap(LayoutStyle
- .ComponentPlacement.RELATED)
- .addComponent(lblStatus, GroupLayout
- .DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addContainerGap())
- );
- jPanel6Layout.setVerticalGroup(
- jPanel6Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(GroupLayout.Alignment.TRAILING, jPanel6Layout.createSequentialGroup()
- .addContainerGap(GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addGroup(jPanel6Layout.createParallelGroup(
- GroupLayout.Alignment.LEADING, false)
- .addComponent(jLabel20,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addGroup(jPanel6Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(lblStatus)))
- .addContainerGap())
- );
-
- jPanel8.setBackground(new Color(220, 220, 220));
-
- jLabel23.setFont(new Font("Cantarell", 0, 18)); // NOI18N
- jLabel23.setHorizontalAlignment(SwingConstants.CENTER);
- jLabel23.setText("Humidity");
-
- chkbxHumidityRandom.setText("Randomize Data");
- chkbxHumidityRandom.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxHumidityRandomActionPerformed(evt);
- }
- });
-
- jSeparator5.setOrientation(SwingConstants.VERTICAL);
-
- jPanel9.setBackground(new Color(220, 220, 220));
-
- jLabel24.setHorizontalAlignment(SwingConstants.LEFT);
- jLabel24.setText("Min");
-
- txtHumidityMin.setHorizontalAlignment(JTextField.CENTER);
- txtHumidityMin.setText("20");
- txtHumidityMin.setEnabled(false);
- txtHumidityMin.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtHumidityMinActionPerformed(evt);
- }
- });
-
- jLabel25.setHorizontalAlignment(SwingConstants.RIGHT);
- jLabel25.setText("Max");
-
- txtHumidityMax.setHorizontalAlignment(JTextField.CENTER);
- txtHumidityMax.setText("50");
- txtHumidityMax.setEnabled(false);
- txtHumidityMax.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtHumidityMaxActionPerformed(evt);
- }
- });
-
- txtHumiditySVF.setHorizontalAlignment(JTextField.CENTER);
- txtHumiditySVF.setText("50");
- txtHumiditySVF.setEnabled(false);
- txtHumiditySVF.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtHumiditySVFActionPerformed(evt);
- }
- });
-
- jLabel11.setHorizontalAlignment(SwingConstants.RIGHT);
- jLabel11.setText("SV %");
-
- GroupLayout jPanel9Layout = new GroupLayout(jPanel9);
- jPanel9.setLayout(jPanel9Layout);
- jPanel9Layout.setHorizontalGroup(
- jPanel9Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel9Layout.createSequentialGroup()
- .addComponent(jLabel24)
- .addPreferredGap(LayoutStyle
- .ComponentPlacement.RELATED)
- .addComponent(txtHumidityMin, GroupLayout
- .PREFERRED_SIZE, 45, GroupLayout
- .PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle
- .ComponentPlacement.RELATED)
- .addComponent(jLabel25)
- .addPreferredGap(LayoutStyle
- .ComponentPlacement.RELATED)
- .addComponent(txtHumidityMax, GroupLayout.PREFERRED_SIZE, 45, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel11)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtHumiditySVF, GroupLayout.PREFERRED_SIZE, 45, GroupLayout.PREFERRED_SIZE)
- .addContainerGap(GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
- );
- jPanel9Layout.setVerticalGroup(
- jPanel9Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(GroupLayout.Alignment.TRAILING, jPanel9Layout.createSequentialGroup()
- .addContainerGap(GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addGroup(jPanel9Layout.createParallelGroup(
- GroupLayout.Alignment.LEADING)
- .addGroup(jPanel9Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(jLabel11)
- .addComponent(txtHumiditySVF,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE))
- .addGroup(jPanel9Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(txtHumidityMin,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE)
- .addComponent(txtHumidityMax,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel25)
- .addComponent(jLabel24)))
- .addGap(35, 35, 35))
- );
-
- spinnerHumidity.setFont(new Font("Cantarell", 1, 24)); // NOI18N
- spinnerHumidity.setModel(new SpinnerNumberModel(30, 0, 100, 1));
- spinnerHumidity.addChangeListener(new javax.swing.event.ChangeListener() {
- public void stateChanged(javax.swing.event.ChangeEvent evt) {
- spinnerHumidityStateChanged(evt);
- }
- });
-
- chkbxHumiditySmooth.setText("Smooth Variation");
- chkbxHumiditySmooth.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxHumiditySmoothActionPerformed(evt);
- }
- });
-
- GroupLayout jPanel8Layout = new GroupLayout(jPanel8);
- jPanel8.setLayout(jPanel8Layout);
- jPanel8Layout.setHorizontalGroup(
- jPanel8Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel8Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addComponent(jLabel23, GroupLayout.PREFERRED_SIZE, 100, GroupLayout.PREFERRED_SIZE)
- .addComponent(spinnerHumidity))
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jSeparator5, GroupLayout.PREFERRED_SIZE, 6, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(jPanel8Layout.createParallelGroup(GroupLayout.Alignment.LEADING, false)
- .addComponent(jPanel9, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addComponent(chkbxHumidityRandom)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(chkbxHumiditySmooth)))
- .addContainerGap())
- );
- jPanel8Layout.setVerticalGroup(
- jPanel8Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel8Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addComponent(jSeparator5)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addGroup(jPanel8Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(
- chkbxHumidityRandom)
- .addComponent(
- chkbxHumiditySmooth))
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel9, GroupLayout.PREFERRED_SIZE, 51, GroupLayout.PREFERRED_SIZE)
- .addGap(0, 1, Short.MAX_VALUE))
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addComponent(jLabel23, GroupLayout.PREFERRED_SIZE, 23, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap
- (LayoutStyle.ComponentPlacement.RELATED)
- .addComponent
- (spinnerHumidity)))
- .addContainerGap())
- );
-
- jPanel3.setBackground(new Color(207, 233, 234));
-
- jLabel7.setText("Data Push Interval:");
-
- spinnerInterval.setModel(new SpinnerNumberModel(Integer.valueOf(5), Integer
- .valueOf(1), null, Integer.valueOf(1)));
- spinnerInterval.addChangeListener(new javax.swing.event.ChangeListener() {
- public void stateChanged(javax.swing.event.ChangeEvent evt) {
- spinnerIntervalStateChanged(evt);
- }
- });
-
- jLabel8.setText("Seconds");
-
- jLabel9.setText("Protocol:");
-
- cmbProtocol.setModel(new DefaultComboBoxModel(new String[] { "MQTT", "XMPP",
- "HTTP" }));
- cmbProtocol.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- cmbProtocolActionPerformed(evt);
- }
- });
-
- jLabel12.setText("Interface:");
-
- cmbInterface.setModel(new DefaultComboBoxModel(new String[] { "eth0" }));
- cmbInterface.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- cmbInterfaceActionPerformed(evt);
- }
- });
-
- GroupLayout jPanel3Layout = new GroupLayout(jPanel3);
- jPanel3.setLayout(jPanel3Layout);
- jPanel3Layout.setHorizontalGroup(
- jPanel3Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel3Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(jLabel7)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(spinnerInterval, GroupLayout.PREFERRED_SIZE, 55, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel8)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jLabel12)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(cmbInterface, GroupLayout.PREFERRED_SIZE, 100, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel9)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(cmbProtocol, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addContainerGap())
- );
- jPanel3Layout.setVerticalGroup(
- jPanel3Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(GroupLayout.Alignment.TRAILING, jPanel3Layout
- .createSequentialGroup()
- .addContainerGap(GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addGroup(jPanel3Layout.createParallelGroup(
- GroupLayout.Alignment.LEADING)
- .addGroup(jPanel3Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(jLabel12)
- .addComponent(cmbInterface,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE))
- .addGroup(jPanel3Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(jLabel7)
- .addComponent(spinnerInterval,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel8)
- .addComponent(jLabel9)
- .addComponent(cmbProtocol,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE)))
- .addContainerGap())
- );
-
- txtAreaLogs.setBackground(new Color(1, 1, 1));
- txtAreaLogs.setColumns(20);
- txtAreaLogs.setFont(new Font("Courier 10 Pitch", Font.BOLD, 9)); // NOI18N
- txtAreaLogs.setForeground(new Color(0, 255, 0));
- txtAreaLogs.setRows(5);
- jScrollPane1.setViewportView(txtAreaLogs);
-
- jPanel4.setBackground(new Color(169, 253, 173));
-
- chkbxEmulate.setText("Emulate data");
- chkbxEmulate.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxEmulateActionPerformed(evt);
- }
- });
-
- cmbPeriod.setModel(new DefaultComboBoxModel(new String[] { "1 hour", "1 day", "1 week", "1 month " }));
- cmbPeriod.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- cmbPeriodActionPerformed(evt);
- }
- });
-
- jLabel1.setText("Emulation Period");
-
- GroupLayout jPanel4Layout = new GroupLayout(jPanel4);
- jPanel4.setLayout(jPanel4Layout);
- jPanel4Layout.setHorizontalGroup(
- jPanel4Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(jPanel4Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(chkbxEmulate)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jLabel1)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(cmbPeriod, GroupLayout.PREFERRED_SIZE, 162, GroupLayout.PREFERRED_SIZE)
- .addContainerGap())
- );
- jPanel4Layout.setVerticalGroup(
- jPanel4Layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(GroupLayout.Alignment.TRAILING, jPanel4Layout.createSequentialGroup()
- .addContainerGap(GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addGroup(jPanel4Layout.createParallelGroup(
- GroupLayout.Alignment.BASELINE)
- .addComponent(chkbxEmulate)
- .addComponent(cmbPeriod,
- GroupLayout.PREFERRED_SIZE,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel1))
- .addContainerGap())
- );
-
- GroupLayout layout = new GroupLayout(getContentPane());
- getContentPane().setLayout(layout);
- layout.setHorizontalGroup(
- layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addComponent(jScrollPane1)
- .addComponent(lblAgentName, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jPanel6, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGroup(layout.createSequentialGroup()
- .addComponent(jPanel1, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(layout.createParallelGroup(
- GroupLayout.Alignment.LEADING)
- .addComponent(
- jPanel8,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)
- .addComponent(
- jPanel2,
- GroupLayout.DEFAULT_SIZE,
- GroupLayout.DEFAULT_SIZE,
- Short.MAX_VALUE)))
- .addComponent(jLabel2, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jPanel4, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jPanel3, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
- .addContainerGap())
- );
- layout.setVerticalGroup(
- layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(layout.createSequentialGroup()
- .addComponent(lblAgentName, GroupLayout.PREFERRED_SIZE, 53, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel6, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(layout.createParallelGroup(GroupLayout.Alignment.LEADING)
- .addGroup(layout.createSequentialGroup()
- .addComponent(jPanel2, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel8, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
- .addComponent(jPanel1, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE))
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jScrollPane1, GroupLayout.PREFERRED_SIZE, 115, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel3, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel4, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel2, GroupLayout.PREFERRED_SIZE, 28, GroupLayout.PREFERRED_SIZE)
- .addContainerGap())
- );
-
- pack();
-
- chkbxTemperatureSmooth.setEnabled(false);
- chkbxTemperatureSmooth.setEnabled(false);
-
- cmbInterface.removeAllItems();
- for (String item : AgentManager.getInstance().getInterfaceList()){
- cmbInterface.addItem(item);
- }
- cmbInterface.setEnabled(false);
-
- cmbProtocol.removeAllItems();
- for (String item : AgentManager.getInstance().getProtocolList()){
- cmbProtocol.addItem(item);
- }
- cmbProtocol.setSelectedItem(AgentConstants.DEFAULT_PROTOCOL);
-
- URL urlAlarmOn = this.getClass().getResource("/alarm-on.gif");
- ImageIcon imageIconAlarmOn = new ImageIcon(urlAlarmOn);
-
- URL urlAlarmOff = this.getClass().getResource("/alarm-off.gif");
- ImageIcon imageIconAlarmOff = new ImageIcon(urlAlarmOff);
-
- picLabelBulbOn = new JLabel(imageIconAlarmOn);
- picLabelBulbOn.setSize(pnlBulbStatus.getSize());
-
- picLabelBulbOff = new JLabel(imageIconAlarmOff);
- picLabelBulbOff.setSize(pnlBulbStatus.getSize());
-
- addToPolicyLog(AgentUtilOperations.formatMessage(AgentManager.getInstance().getInitialPolicy()));
- new Thread(uiUpdater).start();
-
- AgentManager.getInstance().setDeviceReady(true);
- }
-
- private void chkbxTemperatureRandomActionPerformed(java.awt.event.ActionEvent evt) {
- isTemperatureRandomized = chkbxTemperatureRandom.isSelected();
- VirtualHardwareManager.getInstance().setIsTemperatureRandomized(isTemperatureRandomized);
- spinnerTemperature.setEnabled(!isTemperatureRandomized);
- txtTemperatureMax.setEnabled(isTemperatureRandomized);
- txtTemperatureMin.setEnabled(isTemperatureRandomized);
- chkbxTemperatureSmooth.setEnabled(isTemperatureRandomized);
- txtTemperatureSVF.setEnabled(isTemperatureRandomized && isTemperatureSmoothed);
- }
-
- private void chkbxHumidityRandomActionPerformed(java.awt.event.ActionEvent evt) {
- isHumidityRandomized = chkbxHumidityRandom.isSelected();
- VirtualHardwareManager.getInstance().setIsHumidityRandomized(isHumidityRandomized);
- spinnerHumidity.setEnabled(!isHumidityRandomized);
- txtHumidityMax.setEnabled(isHumidityRandomized);
- txtHumidityMin.setEnabled(isHumidityRandomized);
- chkbxHumiditySmooth.setEnabled(isHumidityRandomized);
- txtTemperatureSVF.setEnabled(isHumidityRandomized && isHumiditySmoothed);
- }
-
- private void spinnerTemperatureStateChanged(javax.swing.event.ChangeEvent evt) {
- if (!isTemperatureRandomized) {
- try {
- int temperature = Integer.parseInt(spinnerTemperature.getValue().toString());
- VirtualHardwareManager.getInstance().setTemperature(temperature);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid temperature value", "Error", JOptionPane.ERROR_MESSAGE);
- spinnerTemperature.setValue(VirtualHardwareManager.getInstance().getTemperature());
- }
- }
- }
-
- private void spinnerHumidityStateChanged(javax.swing.event.ChangeEvent evt) {
- if (!isHumidityRandomized) {
- try {
- int humidity = Integer.parseInt(spinnerHumidity.getValue().toString());
- VirtualHardwareManager.getInstance().setHumidity(humidity);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid humidity value", "Error", JOptionPane.ERROR_MESSAGE);
- spinnerHumidity.setValue(VirtualHardwareManager.getInstance().getHumidity());
- }
- }
- }
-
- private void txtTemperatureMinActionPerformed(java.awt.event.ActionEvent evt) {
- try {
- int temperature = Integer.parseInt(txtTemperatureMin.getText());
- VirtualHardwareManager.getInstance().setTemperatureMin(temperature);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid temperature value", "Error", JOptionPane.ERROR_MESSAGE);
- txtTemperatureMin.setText("20");
- }
- }
-
- private void txtTemperatureMaxActionPerformed(java.awt.event.ActionEvent evt) {
- try {
- int temperature = Integer.parseInt(txtTemperatureMax.getText());
- VirtualHardwareManager.getInstance().setTemperatureMax(temperature);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid temperature value", "Error", JOptionPane.ERROR_MESSAGE);
- txtTemperatureMax.setText("50");
- }
- }
-
- private void txtHumidityMinActionPerformed(java.awt.event.ActionEvent evt) {
- try {
- int humidity = Integer.parseInt(txtHumidityMin.getText());
- VirtualHardwareManager.getInstance().setHumidityMin(humidity);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid humidity value", "Error", JOptionPane.ERROR_MESSAGE);
- txtHumidityMin.setText("20");
- }
- }
-
- private void txtHumidityMaxActionPerformed(java.awt.event.ActionEvent evt) {
- try {
- int humidity = Integer.parseInt(txtHumidityMax.getText());
- VirtualHardwareManager.getInstance().setHumidityMax(humidity);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid humidity value", "Error", JOptionPane.ERROR_MESSAGE);
- txtHumidityMax.setText("50");
- }
- }
-
- private void spinnerIntervalStateChanged(javax.swing.event.ChangeEvent evt) {
- try {
- int interval = Integer.parseInt(spinnerInterval.getValue().toString());
- AgentManager.getInstance().setPushInterval(interval);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid time interval value", "Error", JOptionPane.ERROR_MESSAGE);
- spinnerInterval.setValue(5);
- }
- }
-
- private void cmbInterfaceActionPerformed(java.awt.event.ActionEvent evt) {
- AgentManager.getInstance().setInterface(cmbInterface.getSelectedIndex());
- }
-
- private void cmbProtocolActionPerformed(java.awt.event.ActionEvent evt) {
- if (cmbProtocol.getSelectedIndex() != -1 && cmbProtocol.getItemAt(
- cmbProtocol.getSelectedIndex()).equals(AgentConstants.HTTP_PROTOCOL)) {
- cmbInterface.setEnabled(true);
- } else {
- cmbInterface.setEnabled(false);
- }
-
- AgentManager.getInstance().setProtocol(cmbProtocol.getSelectedIndex());
-
- }
-
- private void txtTemperatureSVFActionPerformed(java.awt.event.ActionEvent evt) {
- try {
- int temperatureSVF = Integer.parseInt(txtTemperatureSVF.getText());
- VirtualHardwareManager.getInstance().setTemperatureSVF(temperatureSVF);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid value", "Error", JOptionPane.ERROR_MESSAGE);
- txtTemperatureSVF.setText("50");
- }
- }
-
- private void txtHumiditySVFActionPerformed(java.awt.event.ActionEvent evt) {
- try {
- int humiditySVF = Integer.parseInt(txtHumiditySVF.getText());
- VirtualHardwareManager.getInstance().setHumiditySVF(humiditySVF);
- } catch (NumberFormatException e) {
- JOptionPane.showMessageDialog(this, "Invalid value", "Error", JOptionPane.ERROR_MESSAGE);
- txtHumiditySVF.setText("50");
- }
- }
-
- private void chkbxTemperatureSmoothActionPerformed(java.awt.event.ActionEvent evt) {
- isTemperatureSmoothed = chkbxTemperatureSmooth.isSelected();
- txtTemperatureSVF.setEnabled(isTemperatureSmoothed);
- VirtualHardwareManager.getInstance().setIsTemperatureSmoothed(isTemperatureSmoothed);
- }
-
- private void chkbxHumiditySmoothActionPerformed(java.awt.event.ActionEvent evt) {
- isHumiditySmoothed = chkbxHumiditySmooth.isSelected();
- txtHumiditySVF.setEnabled(isHumiditySmoothed);
- VirtualHardwareManager.getInstance().setIsHumiditySmoothed(isHumiditySmoothed);
- }
-
- private void cmbPeriodActionPerformed(java.awt.event.ActionEvent evt) {
- // TODO add your handling code here:
- }
-
- private void chkbxEmulateActionPerformed(java.awt.event.ActionEvent evt) {
- // TODO add your handling code here:
- }
-
- public void setAlarmStatus(boolean isAlarmOn) {
- this.isAlarmOn = isAlarmOn;
- }
-
- public void updateTemperature(int temperature) {
- spinnerTemperature.setValue(temperature);
- spinnerTemperature.updateUI();
- }
-
- public void updateHumidity(int humidity) {
- spinnerHumidity.setValue(humidity);
- spinnerHumidity.updateUI();
- }
-
- public void addToPolicyLog(String policy) {
- synchronized (this._lock) {
- policyLogs.add(policy);
- }
- }
-
- private String getPolicyLog() {
- synchronized (this._lock) {
- if (policyLogs.size() > 0) {
- String policy = policyLogs.get(0);
- policyLogs.remove(0);
- return policy;
- } else {
- return null;
- }
- }
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/alarm-off.gif b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/alarm-off.gif
deleted file mode 100644
index c346605ad00627e4bda392cd37ab24bde7643395..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001
literal 4265
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
aL6?Fu
zH$_G-^Q!!mIm+@hEff_j^ND5mov>iy!FD0p8!RH8X(W7fQSm!d#kj?FP-#{_T_L|0
zA~0buIeGJRnoM2>Cw@NN`L>#Fw91=jE#E5K^0W>c6mxBEoZ`%xZ;`vHNx!5;I{QMN
z+NyoO>5uOt4m^G5sI=cgZZ?<}@^PhPWnc<4!agZ>TBE$F2K%KffO@mi2hrcmM0g
z%uS2y*8LB@?JRW$y?NUI@Mw=VoD+7d|4YF1%2c)S8(D?Kxm~3cua-yAzn|r74IH6r`5U|NO=%?8)uu|28$!*0(H!xHa-3(@U@n
zn<>2OuxP(-CSIgvnOyI6_6zN(HcO?b;%0u=^cpTj?cN3UH1>CmD;fsem7FeD6eXJ0
z?06aK7E0XYmrI=mRC$ZEDG_Ebu1E~|^OeY4mRNT_vf)FE|Kgzkb=ZLaNm_%zKlqvvMs!aGwEqX<
C_s;DA
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/cep_query.txt b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/cep_query.txt
deleted file mode 100644
index 01f6f7d31..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/cep_query.txt
+++ /dev/null
@@ -1,11 +0,0 @@
-define stream fireAlarmEventStream (deviceID string, temp int);
-from fireAlarmEventStream#window.time(10 sec)
-select deviceID, max(temp) as maxValue
-group by deviceID
-insert into analyzeStream for expired-events;
-from analyzeStream[maxValue < 88]
-select maxValue
-insert into bulbOnStream;
-from fireAlarmEventStream[temp > 1093]
-select deviceID, temp
-insert into bulbOffStream;
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/deviceConfig.properties b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/deviceConfig.properties
deleted file mode 100644
index 4eba166c1..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/deviceConfig.properties
+++ /dev/null
@@ -1,35 +0,0 @@
-#
-# Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
-#
-# 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.
-#
-#
-
-#[Device-Configurations]
-server-name=WSO2IoTServer
-owner=shabirmean
-deviceId=t4ctwq8qfl11
-device-name=SMEAN_t4ctwq8qfl11
-controller-context=/virtual_firealarm/device
-scep-context=/virtual_firealarm_scep
-https-ep=https://localhost:9443
-http-ep=http://localhost:9763
-apim-ep=http://192.168.67.21:8281
-mqtt-ep=tcp://192.168.67.21:1883
-xmpp-ep=http://204.232.188.215:5222
-auth-method=token
-auth-token=79d68b50ae5f5a06e812889979b3453
-refresh-token=8bdda6359dddad218cff3354d5a8cb3b
-network-interface=en0
-push-interval=14
-xmpp-server-name=localhost
\ No newline at end of file
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/fireAlarmSound.mid b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/resources/fireAlarmSound.mid
deleted file mode 100644
index d1a2241b2d87d668b9cfa999f05be6a8c477d895..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001
literal 6719
zcmeI%&rc&|7zglY+L=<>4Yh|&?8cA@YYBz~Q>>7XY15%lD8d3Q;20ul)6PO!VUezl
zB_jA>{7SQ2H^mm&olGP
zJ2TJw%nQsdZ6t}vMjSb~-{+QgFS9L)3btqF;=7mCUGc&NDl7>iQ=)>x^OooARCwK@
zZyniZ(aJrzM}?QDl;au|toEq-*4yfKLZt$Kc4|(XP&287Dtca_g2?sIL#L*l;W)d+
zZng7vo84jmhaR3M@uFtoI5r@T74j&7tuA3Ml+h^A(|nnUn9RJ^%MC?8rCSRNy9|p
zqwdy-9l}CxB6d_wl!bhVvXHM)v{UEGKYv0mOzOaOv1ji`S+G)I72q!yM?-gK$&)2t
zmcm)RCfpglEIb+g@%u8YJ}8`lr{QUM8lHylz<1y~@E!OTd<(t>--2(#H{qM`P53%|
z9lj1TiJ4
zj(9>kV%4&Dy!ooa<(m1j>>~!u@{XW|v0Y0q%^(uMW@~Y*AfaKy!a%p(<8=
zd21G`#eBKg#|dqJWIv&dl|INX{!Gp~EJrK5)l2?--C-@~s?XkXs_T1CZdgz0B~~6h
zO_`L?%X$e}Tn9!8eYYqauoC){0(8)@jx2vXvW|*LbFoiS8eP@)-n*(Sq?CSROI}FH
z=YAol0rla^&c}=8Z6-5oD$g7KkjA<1
zdEr*qLgV&p)f;(FRr3|a+V)$_NrxooVxJ~7+R*lL357P4jIkxthOGWdP6O)0m7R|l
z%deOuZPPi;#`?rgd5PW7XN%Xie~vw-2nC}w5uwQ_g(5T+rRj^ggnnb$GYng3rkAFB
zX|k8bZ6tsFPUmmRiG2{Ir>z&bMB@?#C7O_EQlgMVQxZ)}6qablORshppNDWr(+-++
z(72W4$DEh=OCayMU7nZ14+8%e`MKN8mPL>8IxFVP#Xe(mGNtY1*_=!%8DmSPl&n4=
zrvdfh%Ff4&RvUB~RX0hU}ZIZNn
zolU}Kd0UOO>6BH|#_TtVQT=shbKNnf&5vo}PO~Y)-GAh(te7ts`+QN`dw)^M6o1O<
zZ{)0@Qpnh)c00dPb3h9@YIC-b;>O5-AI4L1DODvg(tL&EVKI?&xbBup!Y2Imu5g!?
ygz*a{MNtMz>YM7$#+7aMZ
-
-
-
-
-
-
-
-
-
- Builds, tests, and runs the project VirtualAgentUI.
-
-
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/manifest.mf b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/manifest.mf
deleted file mode 100644
index 328e8e5bc..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/manifest.mf
+++ /dev/null
@@ -1,3 +0,0 @@
-Manifest-Version: 1.0
-X-COMMENT: Main-Class will be added automatically by build
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/build-impl.xml b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/build-impl.xml
deleted file mode 100644
index 67a63a7f4..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/build-impl.xml
+++ /dev/null
@@ -1,1420 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must set src.dir
- Must set test.src.dir
- Must set build.dir
- Must set dist.dir
- Must set build.classes.dir
- Must set dist.javadoc.dir
- Must set build.test.classes.dir
- Must set build.test.results.dir
- Must set build.classes.excludes
- Must set dist.jar
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must set javac.includes
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- No tests executed.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must set JVM to use for profiling in profiler.info.jvm
- Must set profiler agent JVM arguments in profiler.info.jvmargs.agent
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must select some files in the IDE or set javac.includes
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- To run this application from the command line without Ant, try:
-
- java -jar "${dist.jar.resolved}"
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must select one file in the IDE or set run.class
-
-
-
- Must select one file in the IDE or set run.class
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must select one file in the IDE or set debug.class
-
-
-
-
- Must select one file in the IDE or set debug.class
-
-
-
-
- Must set fix.includes
-
-
-
-
-
-
-
-
-
- This target only works when run from inside the NetBeans IDE.
-
-
-
-
-
-
-
-
- Must select one file in the IDE or set profile.class
- This target only works when run from inside the NetBeans IDE.
-
-
-
-
-
-
-
-
- This target only works when run from inside the NetBeans IDE.
-
-
-
-
-
-
-
-
-
-
-
-
- This target only works when run from inside the NetBeans IDE.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must select one file in the IDE or set run.class
-
-
-
-
-
- Must select some files in the IDE or set test.includes
-
-
-
-
- Must select one file in the IDE or set run.class
-
-
-
-
- Must select one file in the IDE or set applet.url
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must select some files in the IDE or set javac.includes
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Some tests failed; see details above.
-
-
-
-
-
-
-
-
- Must select some files in the IDE or set test.includes
-
-
-
- Some tests failed; see details above.
-
-
-
- Must select some files in the IDE or set test.class
- Must select some method in the IDE or set test.method
-
-
-
- Some tests failed; see details above.
-
-
-
-
- Must select one file in the IDE or set test.class
-
-
-
- Must select one file in the IDE or set test.class
- Must select some method in the IDE or set test.method
-
-
-
-
-
-
-
-
-
-
-
-
-
- Must select one file in the IDE or set applet.url
-
-
-
-
-
-
-
-
- Must select one file in the IDE or set applet.url
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/genfiles.properties b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/genfiles.properties
deleted file mode 100644
index 1a7c9fdef..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/genfiles.properties
+++ /dev/null
@@ -1,8 +0,0 @@
-build.xml.data.CRC32=e60df945
-build.xml.script.CRC32=7c331eea
-build.xml.stylesheet.CRC32=8064a381@1.75.2.48
-# This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml.
-# Do not edit this file. You may delete it but then the IDE will never regenerate such files for you.
-nbproject/build-impl.xml.data.CRC32=e60df945
-nbproject/build-impl.xml.script.CRC32=18800575
-nbproject/build-impl.xml.stylesheet.CRC32=830a3534@1.80.1.48
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.properties b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.properties
deleted file mode 100644
index eda34e66d..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.properties
+++ /dev/null
@@ -1,2 +0,0 @@
-compile.on.save=true
-user.properties.file=/home/lahiru/.netbeans/8.2/build.properties
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.xml b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.xml
deleted file mode 100644
index 21b090f78..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/private/private.xml
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
- file:/home/lahiru/WSO2IOT/carbon-device-mgt-plugins/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.java
- file:/home/lahiru/WSO2IOT/carbon-device-mgt-plugins/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/VirtualAgentUI.java
-
-
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.properties b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.properties
deleted file mode 100644
index fb798f614..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.properties
+++ /dev/null
@@ -1,73 +0,0 @@
-annotation.processing.enabled=true
-annotation.processing.enabled.in.editor=false
-annotation.processing.processor.options=
-annotation.processing.processors.list=
-annotation.processing.run.all.processors=true
-annotation.processing.source.output=${build.generated.sources.dir}/ap-source-output
-build.classes.dir=${build.dir}/classes
-build.classes.excludes=**/*.java,**/*.form
-# This directory is removed when the project is cleaned:
-build.dir=build
-build.generated.dir=${build.dir}/generated
-build.generated.sources.dir=${build.dir}/generated-sources
-# Only compile against the classpath explicitly listed here:
-build.sysclasspath=ignore
-build.test.classes.dir=${build.dir}/test/classes
-build.test.results.dir=${build.dir}/test/results
-# Uncomment to specify the preferred debugger connection transport:
-#debug.transport=dt_socket
-debug.classpath=\
- ${run.classpath}
-debug.test.classpath=\
- ${run.test.classpath}
-# Files in build.classes.dir which should be excluded from distribution jar
-dist.archive.excludes=
-# This directory is removed when the project is cleaned:
-dist.dir=dist
-dist.jar=${dist.dir}/VirtualAgentUI.jar
-dist.javadoc.dir=${dist.dir}/javadoc
-excludes=
-includes=**
-jar.compress=false
-javac.classpath=
-# Space-separated list of extra javac options
-javac.compilerargs=
-javac.deprecation=false
-javac.processorpath=\
- ${javac.classpath}
-javac.source=1.8
-javac.target=1.8
-javac.test.classpath=\
- ${javac.classpath}:\
- ${build.classes.dir}
-javac.test.processorpath=\
- ${javac.test.classpath}
-javadoc.additionalparam=
-javadoc.author=false
-javadoc.encoding=${source.encoding}
-javadoc.noindex=false
-javadoc.nonavbar=false
-javadoc.notree=false
-javadoc.private=false
-javadoc.splitindex=true
-javadoc.use=true
-javadoc.version=false
-javadoc.windowtitle=
-main.class=org.wso2.carbon.device.mgt.iot.agent.virtual.VirtualAgentUI
-manifest.file=manifest.mf
-meta.inf.dir=${src.dir}/META-INF
-mkdist.disabled=false
-platform.active=default_platform
-run.classpath=\
- ${javac.classpath}:\
- ${build.classes.dir}
-# Space-separated list of JVM arguments used when running the project.
-# You may also define separate properties like run-sys-prop.name=value instead of -Dname=value.
-# To set system properties for unit tests define test-sys-prop.name=value:
-run.jvmargs=
-run.test.classpath=\
- ${javac.test.classpath}:\
- ${build.test.classes.dir}
-source.encoding=UTF-8
-src.dir=src
-test.src.dir=test
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.xml b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.xml
deleted file mode 100644
index 438f1e6a3..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/nbproject/project.xml
+++ /dev/null
@@ -1,15 +0,0 @@
-
-
- org.netbeans.modules.java.j2seproject
-
-
- VirtualAgentUI
-
-
-
-
-
-
-
-
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/bulb-on.jpg b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/bulb-on.jpg
deleted file mode 100644
index 51d40cd834db53f1bf305997832ad4c5f7a00356..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001
literal 6942
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
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/VirtualAgentUI.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/VirtualAgentUI.java
deleted file mode 100644
index a2aa2116a..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/VirtualAgentUI.java
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * To change this license header, choose License Headers in Project Properties.
- * To change this template file, choose Tools | Templates
- * and open the template in the editor.
- */
-package org.wso2.carbon.device.mgt.iot.agent.virtual;
-
-import javax.swing.UIManager;
-import javax.swing.UnsupportedLookAndFeelException;
-import org.wso2.carbon.device.mgt.iot.agent.virtual.ui.AgentUI;
-
-/**
- *
- * @author charitha
- */
-public class VirtualAgentUI {
-
- /**
- * @param args the command line arguments
- */
- public static void main(String[] args) {
- try {
- // Set System L&F
- UIManager.setLookAndFeel(
- UIManager.getSystemLookAndFeelClassName());
- } catch (UnsupportedLookAndFeelException | ClassNotFoundException | InstantiationException | IllegalAccessException e) {
- // handle exception
- }
-
- java.awt.EventQueue.invokeLater(new Runnable() {
- public void run() {
- new AgentUI().setVisible(true);
- }
- });
- }
-
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.form b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.form
deleted file mode 100644
index 55a99b0a9..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.form
+++ /dev/null
@@ -1,806 +0,0 @@
-
-
-
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.java b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.java
deleted file mode 100644
index 851d572cb..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.agent.advanced.impl/src/main/ui/src/org/wso2/carbon/device/mgt/iot/agent/virtual/ui/AgentUI.java
+++ /dev/null
@@ -1,725 +0,0 @@
-/*
- * To change this license header, choose License Headers in Project Properties.
- * To change this template file, choose Tools | Templates
- * and open the template in the editor.
- */
-package org.wso2.carbon.device.mgt.iot.agent.virtual.ui;
-
-/**
- *
- * @author charitha
- */
-public class AgentUI extends javax.swing.JFrame {
-
- /**
- * Creates new form AgentUI
- */
- public AgentUI() {
- initComponents();
- }
-
- /**
- * This method is called from within the constructor to initialize the form.
- * WARNING: Do NOT modify this code. The content of this method is always
- * regenerated by the Form Editor.
- */
- @SuppressWarnings("unchecked")
- // //GEN-BEGIN:initComponents
- private void initComponents() {
-
- lblAgentName = new javax.swing.JLabel();
- jLabel2 = new javax.swing.JLabel();
- jPanel1 = new javax.swing.JPanel();
- jLabel3 = new javax.swing.JLabel();
- pnlBulbStatus = new javax.swing.JPanel();
- jPanel2 = new javax.swing.JPanel();
- jLabel4 = new javax.swing.JLabel();
- chkbxTemperatureRandom = new javax.swing.JCheckBox();
- jSeparator1 = new javax.swing.JSeparator();
- jPanel7 = new javax.swing.JPanel();
- jLabel5 = new javax.swing.JLabel();
- txtTemperatureMin = new javax.swing.JTextField();
- jLabel6 = new javax.swing.JLabel();
- txtTemperatureMax = new javax.swing.JTextField();
- jLabel10 = new javax.swing.JLabel();
- txtTemperatureSVF = new javax.swing.JTextField();
- spinnerTemperature = new javax.swing.JSpinner();
- chkbxTemperatureSmooth = new javax.swing.JCheckBox();
- jPanel6 = new javax.swing.JPanel();
- jLabel20 = new javax.swing.JLabel();
- lblStatus = new javax.swing.JLabel();
- jPanel8 = new javax.swing.JPanel();
- jLabel23 = new javax.swing.JLabel();
- chkbxHumidityRandom = new javax.swing.JCheckBox();
- jSeparator5 = new javax.swing.JSeparator();
- jPanel9 = new javax.swing.JPanel();
- jLabel24 = new javax.swing.JLabel();
- txtHumidityMin = new javax.swing.JTextField();
- jLabel25 = new javax.swing.JLabel();
- txtHumidityMax = new javax.swing.JTextField();
- txtHumiditySVF = new javax.swing.JTextField();
- jLabel11 = new javax.swing.JLabel();
- spinnerHumidity = new javax.swing.JSpinner();
- chkbxHumiditySmooth = new javax.swing.JCheckBox();
- jPanel3 = new javax.swing.JPanel();
- jLabel7 = new javax.swing.JLabel();
- spinnerInterval = new javax.swing.JSpinner();
- jLabel8 = new javax.swing.JLabel();
- jLabel9 = new javax.swing.JLabel();
- cmbProtocol = new javax.swing.JComboBox();
- jLabel12 = new javax.swing.JLabel();
- cmbInterface = new javax.swing.JComboBox();
- jScrollPane1 = new javax.swing.JScrollPane();
- txtAreaLogs = new javax.swing.JTextArea();
- jPanel4 = new javax.swing.JPanel();
- chkbxEmulate = new javax.swing.JCheckBox();
- cmbPeriod = new javax.swing.JComboBox();
- jLabel1 = new javax.swing.JLabel();
-
- setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
- setTitle("Fire Alarm Emulator");
- setResizable(false);
-
- lblAgentName.setFont(new java.awt.Font("Cantarell", 1, 24)); // NOI18N
- lblAgentName.setHorizontalAlignment(javax.swing.SwingConstants.LEFT);
- lblAgentName.setText("Device Name: WSO2 IoT Virtual Agent");
-
- jLabel2.setHorizontalAlignment(javax.swing.SwingConstants.CENTER);
- jLabel2.setText("Copyright (c) 2015, WSO2 Inc.");
-
- jPanel1.setBackground(new java.awt.Color(220, 220, 220));
-
- jLabel3.setFont(new java.awt.Font("Cantarell", 0, 18)); // NOI18N
- jLabel3.setHorizontalAlignment(javax.swing.SwingConstants.CENTER);
- jLabel3.setText("Bulb Status");
-
- pnlBulbStatus.setBackground(new java.awt.Color(220, 220, 220));
-
- javax.swing.GroupLayout pnlBulbStatusLayout = new javax.swing.GroupLayout(pnlBulbStatus);
- pnlBulbStatus.setLayout(pnlBulbStatusLayout);
- pnlBulbStatusLayout.setHorizontalGroup(
- pnlBulbStatusLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGap(0, 0, Short.MAX_VALUE)
- );
- pnlBulbStatusLayout.setVerticalGroup(
- pnlBulbStatusLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGap(0, 167, Short.MAX_VALUE)
- );
-
- javax.swing.GroupLayout jPanel1Layout = new javax.swing.GroupLayout(jPanel1);
- jPanel1.setLayout(jPanel1Layout);
- jPanel1Layout.setHorizontalGroup(
- jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel1Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
- .addComponent(pnlBulbStatus, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jLabel3, javax.swing.GroupLayout.DEFAULT_SIZE, 190, Short.MAX_VALUE))
- .addContainerGap())
- );
- jPanel1Layout.setVerticalGroup(
- jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel1Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(jLabel3)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(pnlBulbStatus, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addContainerGap())
- );
-
- jPanel2.setBackground(new java.awt.Color(220, 220, 220));
-
- jLabel4.setFont(new java.awt.Font("Cantarell", 0, 18)); // NOI18N
- jLabel4.setHorizontalAlignment(javax.swing.SwingConstants.CENTER);
- jLabel4.setText("Temperature");
-
- chkbxTemperatureRandom.setText("Randomize Data");
- chkbxTemperatureRandom.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxTemperatureRandomActionPerformed(evt);
- }
- });
-
- jSeparator1.setOrientation(javax.swing.SwingConstants.VERTICAL);
-
- jPanel7.setBackground(new java.awt.Color(220, 220, 220));
-
- jLabel5.setHorizontalAlignment(javax.swing.SwingConstants.LEFT);
- jLabel5.setText("Min");
-
- txtTemperatureMin.setHorizontalAlignment(javax.swing.JTextField.CENTER);
- txtTemperatureMin.setText("20");
- txtTemperatureMin.setEnabled(false);
- txtTemperatureMin.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtTemperatureMinActionPerformed(evt);
- }
- });
-
- jLabel6.setHorizontalAlignment(javax.swing.SwingConstants.RIGHT);
- jLabel6.setText("Max");
-
- txtTemperatureMax.setHorizontalAlignment(javax.swing.JTextField.CENTER);
- txtTemperatureMax.setText("50");
- txtTemperatureMax.setEnabled(false);
- txtTemperatureMax.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtTemperatureMaxActionPerformed(evt);
- }
- });
-
- jLabel10.setHorizontalAlignment(javax.swing.SwingConstants.RIGHT);
- jLabel10.setText("SV %");
-
- txtTemperatureSVF.setHorizontalAlignment(javax.swing.JTextField.CENTER);
- txtTemperatureSVF.setText("50");
- txtTemperatureSVF.setEnabled(false);
- txtTemperatureSVF.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtTemperatureSVFActionPerformed(evt);
- }
- });
-
- javax.swing.GroupLayout jPanel7Layout = new javax.swing.GroupLayout(jPanel7);
- jPanel7.setLayout(jPanel7Layout);
- jPanel7Layout.setHorizontalGroup(
- jPanel7Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel7Layout.createSequentialGroup()
- .addComponent(jLabel5)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtTemperatureMin, javax.swing.GroupLayout.PREFERRED_SIZE, 45, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel6)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtTemperatureMax, javax.swing.GroupLayout.PREFERRED_SIZE, 45, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel10)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtTemperatureSVF, javax.swing.GroupLayout.PREFERRED_SIZE, 45, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
- );
- jPanel7Layout.setVerticalGroup(
- jPanel7Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel7Layout.createSequentialGroup()
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGroup(jPanel7Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(txtTemperatureMin, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addComponent(txtTemperatureMax, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel6)
- .addComponent(jLabel5)
- .addComponent(jLabel10)
- .addComponent(txtTemperatureSVF, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
- .addGap(35, 35, 35))
- );
-
- spinnerTemperature.setFont(new java.awt.Font("Cantarell", 1, 24)); // NOI18N
- spinnerTemperature.setModel(new javax.swing.SpinnerNumberModel(30, 0, 100, 1));
- spinnerTemperature.addChangeListener(new javax.swing.event.ChangeListener() {
- public void stateChanged(javax.swing.event.ChangeEvent evt) {
- spinnerTemperatureStateChanged(evt);
- }
- });
-
- chkbxTemperatureSmooth.setText("Smooth Variation");
- chkbxTemperatureSmooth.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxTemperatureSmoothActionPerformed(evt);
- }
- });
-
- javax.swing.GroupLayout jPanel2Layout = new javax.swing.GroupLayout(jPanel2);
- jPanel2.setLayout(jPanel2Layout);
- jPanel2Layout.setHorizontalGroup(
- jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
- .addComponent(jLabel4, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(spinnerTemperature))
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jSeparator1, javax.swing.GroupLayout.PREFERRED_SIZE, 6, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addComponent(jPanel7, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addComponent(chkbxTemperatureRandom)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(chkbxTemperatureSmooth)))
- .addContainerGap())
- );
- jPanel2Layout.setVerticalGroup(
- jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addComponent(jSeparator1)
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addGroup(jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(chkbxTemperatureRandom)
- .addComponent(chkbxTemperatureSmooth))
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel7, javax.swing.GroupLayout.PREFERRED_SIZE, 51, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addGap(0, 0, Short.MAX_VALUE))
- .addGroup(jPanel2Layout.createSequentialGroup()
- .addComponent(jLabel4, javax.swing.GroupLayout.PREFERRED_SIZE, 23, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(spinnerTemperature)))
- .addContainerGap())
- );
-
- jPanel6.setBackground(new java.awt.Color(253, 254, 209));
-
- jLabel20.setText("Connection Status:");
- jLabel20.setVerticalTextPosition(javax.swing.SwingConstants.TOP);
-
- lblStatus.setFont(new java.awt.Font("Cantarell", 1, 15)); // NOI18N
- lblStatus.setText("Not Connected");
-
- javax.swing.GroupLayout jPanel6Layout = new javax.swing.GroupLayout(jPanel6);
- jPanel6.setLayout(jPanel6Layout);
- jPanel6Layout.setHorizontalGroup(
- jPanel6Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel6Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(jLabel20)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(lblStatus, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGap(273, 273, 273))
- );
- jPanel6Layout.setVerticalGroup(
- jPanel6Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel6Layout.createSequentialGroup()
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGroup(jPanel6Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
- .addComponent(jLabel20, javax.swing.GroupLayout.DEFAULT_SIZE, 27, Short.MAX_VALUE)
- .addComponent(lblStatus, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
- .addContainerGap())
- );
-
- jPanel8.setBackground(new java.awt.Color(220, 220, 220));
-
- jLabel23.setFont(new java.awt.Font("Cantarell", 0, 18)); // NOI18N
- jLabel23.setHorizontalAlignment(javax.swing.SwingConstants.CENTER);
- jLabel23.setText("Humidity");
-
- chkbxHumidityRandom.setText("Randomize Data");
- chkbxHumidityRandom.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxHumidityRandomActionPerformed(evt);
- }
- });
-
- jSeparator5.setOrientation(javax.swing.SwingConstants.VERTICAL);
-
- jPanel9.setBackground(new java.awt.Color(220, 220, 220));
-
- jLabel24.setHorizontalAlignment(javax.swing.SwingConstants.LEFT);
- jLabel24.setText("Min");
-
- txtHumidityMin.setHorizontalAlignment(javax.swing.JTextField.CENTER);
- txtHumidityMin.setText("20");
- txtHumidityMin.setEnabled(false);
- txtHumidityMin.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtHumidityMinActionPerformed(evt);
- }
- });
-
- jLabel25.setHorizontalAlignment(javax.swing.SwingConstants.RIGHT);
- jLabel25.setText("Max");
-
- txtHumidityMax.setHorizontalAlignment(javax.swing.JTextField.CENTER);
- txtHumidityMax.setText("50");
- txtHumidityMax.setEnabled(false);
- txtHumidityMax.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtHumidityMaxActionPerformed(evt);
- }
- });
-
- txtHumiditySVF.setHorizontalAlignment(javax.swing.JTextField.CENTER);
- txtHumiditySVF.setText("50");
- txtHumiditySVF.setEnabled(false);
- txtHumiditySVF.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- txtHumiditySVFActionPerformed(evt);
- }
- });
-
- jLabel11.setHorizontalAlignment(javax.swing.SwingConstants.RIGHT);
- jLabel11.setText("SV %");
-
- javax.swing.GroupLayout jPanel9Layout = new javax.swing.GroupLayout(jPanel9);
- jPanel9.setLayout(jPanel9Layout);
- jPanel9Layout.setHorizontalGroup(
- jPanel9Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel9Layout.createSequentialGroup()
- .addComponent(jLabel24)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtHumidityMin, javax.swing.GroupLayout.PREFERRED_SIZE, 45, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel25)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtHumidityMax, javax.swing.GroupLayout.PREFERRED_SIZE, 45, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel11)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(txtHumiditySVF, javax.swing.GroupLayout.PREFERRED_SIZE, 45, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
- );
- jPanel9Layout.setVerticalGroup(
- jPanel9Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel9Layout.createSequentialGroup()
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGroup(jPanel9Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel9Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(jLabel11)
- .addComponent(txtHumiditySVF, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
- .addGroup(jPanel9Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(txtHumidityMin, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addComponent(txtHumidityMax, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel25)
- .addComponent(jLabel24)))
- .addGap(35, 35, 35))
- );
-
- spinnerHumidity.setFont(new java.awt.Font("Cantarell", 1, 24)); // NOI18N
- spinnerHumidity.setModel(new javax.swing.SpinnerNumberModel(30, 0, 100, 1));
- spinnerHumidity.addChangeListener(new javax.swing.event.ChangeListener() {
- public void stateChanged(javax.swing.event.ChangeEvent evt) {
- spinnerHumidityStateChanged(evt);
- }
- });
-
- chkbxHumiditySmooth.setText("Smooth Variation");
- chkbxHumiditySmooth.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxHumiditySmoothActionPerformed(evt);
- }
- });
-
- javax.swing.GroupLayout jPanel8Layout = new javax.swing.GroupLayout(jPanel8);
- jPanel8.setLayout(jPanel8Layout);
- jPanel8Layout.setHorizontalGroup(
- jPanel8Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel8Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addComponent(jLabel23, javax.swing.GroupLayout.PREFERRED_SIZE, 100, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addComponent(spinnerHumidity))
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jSeparator5, javax.swing.GroupLayout.PREFERRED_SIZE, 6, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(jPanel8Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
- .addComponent(jPanel9, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addComponent(chkbxHumidityRandom)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(chkbxHumiditySmooth)))
- .addContainerGap())
- );
- jPanel8Layout.setVerticalGroup(
- jPanel8Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(jPanel8Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addComponent(jSeparator5)
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addGroup(jPanel8Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(chkbxHumidityRandom)
- .addComponent(chkbxHumiditySmooth))
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel9, javax.swing.GroupLayout.PREFERRED_SIZE, 51, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addGap(0, 1, Short.MAX_VALUE))
- .addGroup(jPanel8Layout.createSequentialGroup()
- .addComponent(jLabel23, javax.swing.GroupLayout.PREFERRED_SIZE, 23, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(spinnerHumidity)))
- .addContainerGap())
- );
-
- jPanel3.setBackground(new java.awt.Color(207, 233, 234));
-
- jLabel7.setText("Data Push Interval:");
-
- spinnerInterval.setModel(new javax.swing.SpinnerNumberModel(5, 1, null, 1));
- spinnerInterval.addChangeListener(new javax.swing.event.ChangeListener() {
- public void stateChanged(javax.swing.event.ChangeEvent evt) {
- spinnerIntervalStateChanged(evt);
- }
- });
-
- jLabel8.setText("Seconds");
-
- jLabel9.setText("Protocol:");
-
- cmbProtocol.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "MQTT", "XMPP", "HTTP" }));
- cmbProtocol.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- cmbProtocolActionPerformed(evt);
- }
- });
-
- jLabel12.setText("Interface:");
-
- cmbInterface.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "eth0" }));
- cmbInterface.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- cmbInterfaceActionPerformed(evt);
- }
- });
-
- javax.swing.GroupLayout jPanel3Layout = new javax.swing.GroupLayout(jPanel3);
- jPanel3.setLayout(jPanel3Layout);
- jPanel3Layout.setHorizontalGroup(
- jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel3Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(jLabel7)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(spinnerInterval, javax.swing.GroupLayout.PREFERRED_SIZE, 55, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel8)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jLabel12)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(cmbInterface, javax.swing.GroupLayout.PREFERRED_SIZE, 100, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel9)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(cmbProtocol, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addContainerGap())
- );
- jPanel3Layout.setVerticalGroup(
- jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel3Layout.createSequentialGroup()
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(jLabel12)
- .addComponent(cmbInterface, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
- .addGroup(jPanel3Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(jLabel7)
- .addComponent(spinnerInterval, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel8)
- .addComponent(jLabel9)
- .addComponent(cmbProtocol, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)))
- .addContainerGap())
- );
-
- txtAreaLogs.setBackground(new java.awt.Color(1, 1, 1));
- txtAreaLogs.setColumns(20);
- txtAreaLogs.setFont(new java.awt.Font("Courier 10 Pitch", 1, 18)); // NOI18N
- txtAreaLogs.setForeground(new java.awt.Color(0, 255, 0));
- txtAreaLogs.setRows(5);
- jScrollPane1.setViewportView(txtAreaLogs);
-
- jPanel4.setBackground(new java.awt.Color(169, 253, 173));
-
- chkbxEmulate.setText("Emulate data");
- chkbxEmulate.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- chkbxEmulateActionPerformed(evt);
- }
- });
-
- cmbPeriod.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "1 hour", "1 day", "1 week", "1 month " }));
- cmbPeriod.addActionListener(new java.awt.event.ActionListener() {
- public void actionPerformed(java.awt.event.ActionEvent evt) {
- cmbPeriodActionPerformed(evt);
- }
- });
-
- jLabel1.setText("Emulation Period");
-
- javax.swing.GroupLayout jPanel4Layout = new javax.swing.GroupLayout(jPanel4);
- jPanel4.setLayout(jPanel4Layout);
- jPanel4Layout.setHorizontalGroup(
- jPanel4Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(jPanel4Layout.createSequentialGroup()
- .addContainerGap()
- .addComponent(chkbxEmulate)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jLabel1)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(cmbPeriod, javax.swing.GroupLayout.PREFERRED_SIZE, 162, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addContainerGap())
- );
- jPanel4Layout.setVerticalGroup(
- jPanel4Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, jPanel4Layout.createSequentialGroup()
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGroup(jPanel4Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
- .addComponent(chkbxEmulate)
- .addComponent(cmbPeriod, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addComponent(jLabel1))
- .addContainerGap())
- );
-
- javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
- getContentPane().setLayout(layout);
- layout.setHorizontalGroup(
- layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(layout.createSequentialGroup()
- .addContainerGap()
- .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addComponent(jScrollPane1)
- .addComponent(lblAgentName, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jPanel6, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGroup(layout.createSequentialGroup()
- .addComponent(jPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addComponent(jPanel8, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jPanel2, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))
- .addComponent(jLabel2, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jPanel4, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(jPanel3, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
- .addContainerGap())
- );
- layout.setVerticalGroup(
- layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(layout.createSequentialGroup()
- .addComponent(lblAgentName, javax.swing.GroupLayout.PREFERRED_SIZE, 53, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel6, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
- .addGroup(layout.createSequentialGroup()
- .addComponent(jPanel2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel8, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
- .addComponent(jPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 115, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel3, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jPanel4, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
- .addComponent(jLabel2, javax.swing.GroupLayout.PREFERRED_SIZE, 28, javax.swing.GroupLayout.PREFERRED_SIZE)
- .addContainerGap())
- );
-
- pack();
- }// //GEN-END:initComponents
-
- private void chkbxTemperatureRandomActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_chkbxTemperatureRandomActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_chkbxTemperatureRandomActionPerformed
-
- private void chkbxHumidityRandomActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_chkbxHumidityRandomActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_chkbxHumidityRandomActionPerformed
-
- private void spinnerTemperatureStateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerTemperatureStateChanged
- // TODO add your handling code here:
- }//GEN-LAST:event_spinnerTemperatureStateChanged
-
- private void spinnerHumidityStateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerHumidityStateChanged
- // TODO add your handling code here:
- }//GEN-LAST:event_spinnerHumidityStateChanged
-
- private void txtTemperatureMinActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_txtTemperatureMinActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_txtTemperatureMinActionPerformed
-
- private void txtTemperatureMaxActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_txtTemperatureMaxActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_txtTemperatureMaxActionPerformed
-
- private void txtHumidityMinActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_txtHumidityMinActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_txtHumidityMinActionPerformed
-
- private void txtHumidityMaxActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_txtHumidityMaxActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_txtHumidityMaxActionPerformed
-
- private void spinnerIntervalStateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_spinnerIntervalStateChanged
- // TODO add your handling code here:
- }//GEN-LAST:event_spinnerIntervalStateChanged
-
- private void cmbInterfaceActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_cmbInterfaceActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_cmbInterfaceActionPerformed
-
- private void cmbProtocolActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_cmbProtocolActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_cmbProtocolActionPerformed
-
- private void txtTemperatureSVFActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_txtTemperatureSVFActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_txtTemperatureSVFActionPerformed
-
- private void txtHumiditySVFActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_txtHumiditySVFActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_txtHumiditySVFActionPerformed
-
- private void chkbxTemperatureSmoothActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_chkbxTemperatureSmoothActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_chkbxTemperatureSmoothActionPerformed
-
- private void chkbxHumiditySmoothActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_chkbxHumiditySmoothActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_chkbxHumiditySmoothActionPerformed
-
- private void cmbPeriodActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_cmbPeriodActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_cmbPeriodActionPerformed
-
- private void chkbxEmulateActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_chkbxEmulateActionPerformed
- // TODO add your handling code here:
- }//GEN-LAST:event_chkbxEmulateActionPerformed
-
- // Variables declaration - do not modify//GEN-BEGIN:variables
- private javax.swing.JCheckBox chkbxEmulate;
- private javax.swing.JCheckBox chkbxHumidityRandom;
- private javax.swing.JCheckBox chkbxHumiditySmooth;
- private javax.swing.JCheckBox chkbxTemperatureRandom;
- private javax.swing.JCheckBox chkbxTemperatureSmooth;
- private javax.swing.JComboBox cmbInterface;
- private javax.swing.JComboBox cmbPeriod;
- private javax.swing.JComboBox cmbProtocol;
- private javax.swing.JLabel jLabel1;
- private javax.swing.JLabel jLabel10;
- private javax.swing.JLabel jLabel11;
- private javax.swing.JLabel jLabel12;
- private javax.swing.JLabel jLabel2;
- private javax.swing.JLabel jLabel20;
- private javax.swing.JLabel jLabel23;
- private javax.swing.JLabel jLabel24;
- private javax.swing.JLabel jLabel25;
- private javax.swing.JLabel jLabel3;
- private javax.swing.JLabel jLabel4;
- private javax.swing.JLabel jLabel5;
- private javax.swing.JLabel jLabel6;
- private javax.swing.JLabel jLabel7;
- private javax.swing.JLabel jLabel8;
- private javax.swing.JLabel jLabel9;
- private javax.swing.JPanel jPanel1;
- private javax.swing.JPanel jPanel2;
- private javax.swing.JPanel jPanel3;
- private javax.swing.JPanel jPanel4;
- private javax.swing.JPanel jPanel6;
- private javax.swing.JPanel jPanel7;
- private javax.swing.JPanel jPanel8;
- private javax.swing.JPanel jPanel9;
- private javax.swing.JScrollPane jScrollPane1;
- private javax.swing.JSeparator jSeparator1;
- private javax.swing.JSeparator jSeparator5;
- private javax.swing.JLabel lblAgentName;
- private javax.swing.JLabel lblStatus;
- private javax.swing.JPanel pnlBulbStatus;
- private javax.swing.JSpinner spinnerHumidity;
- private javax.swing.JSpinner spinnerInterval;
- private javax.swing.JSpinner spinnerTemperature;
- private javax.swing.JTextArea txtAreaLogs;
- private javax.swing.JTextField txtHumidityMax;
- private javax.swing.JTextField txtHumidityMin;
- private javax.swing.JTextField txtHumiditySVF;
- private javax.swing.JTextField txtTemperatureMax;
- private javax.swing.JTextField txtTemperatureMin;
- private javax.swing.JTextField txtTemperatureSVF;
- // End of variables declaration//GEN-END:variables
-}
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.hbs b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.hbs
deleted file mode 100644
index 7b9952568..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.hbs
+++ /dev/null
@@ -1,18 +0,0 @@
-{{!
- Copyright (c) 2016, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
-
- WSO2 Inc. licenses this file to you 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.
-}}
-{{unit "cdmf.unit.policy.edit"}}
\ No newline at end of file
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.json b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.json
deleted file mode 100644
index 9eecd8f5b..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-edit/policy-edit.json
+++ /dev/null
@@ -1,3 +0,0 @@
-{
- "version": "1.0.0"
-}
\ No newline at end of file
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.hbs b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.hbs
deleted file mode 100644
index e1454e050..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.hbs
+++ /dev/null
@@ -1,18 +0,0 @@
-{{!
- Copyright (c) 2016, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
-
- WSO2 Inc. licenses this file to you 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.
-}}
-{{unit "cdmf.unit.policy.view"}}
\ No newline at end of file
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.json b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.json
deleted file mode 100644
index 9eecd8f5b..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-view/policy-view.json
+++ /dev/null
@@ -1,3 +0,0 @@
-{
- "version": "1.0.0"
-}
\ No newline at end of file
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.hbs b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.hbs
deleted file mode 100644
index fbd9fb6d0..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.hbs
+++ /dev/null
@@ -1,18 +0,0 @@
-{{!
- Copyright (c) 2016, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
-
- WSO2 Inc. licenses this file to you 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.
-}}
-{{unit "cdmf.unit.policy.create"}}
\ No newline at end of file
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.json b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.json
deleted file mode 100644
index 9eecd8f5b..000000000
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.policy-wizard/policy-wizard.json
+++ /dev/null
@@ -1,3 +0,0 @@
-{
- "version": "1.0.0"
-}
\ No newline at end of file
diff --git a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.type-view/type-view.hbs b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.type-view/type-view.hbs
index 09bdc00ae..556c0e551 100644
--- a/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.type-view/type-view.hbs
+++ b/components/device-types/virtual-fire-alarm-plugin/org.wso2.carbon.device.mgt.iot.virtualfirealarm.ui/src/main/resources/jaggeryapps/devicemgt/app/units/cdmf.unit.device.type.virtual_firealarm.type-view/type-view.hbs
@@ -26,25 +26,25 @@
What it Does
A Virtual Device that mimics the functionality of a real Firealarm.
- Once run, the Virtual Firealarm will connect to WSO2 IoTServer and
- push Temperature readings.
+ Once run, the Virtual Firealarm will connect to WSO2 IoTServer and
+ push Temperature readings.
The device supports MQTT and XMPP Communications. It is configured to use MQTT by
- default.
+ default.
What You Need
STEP 01
- Go ahead and [Download] the Device.
+ Go ahead and [Download] the Device.
STEP 02
- Proceed to [Prepare] section.
+ Proceed to [Prepare] section.
STEP 03
- Read [Try Out] section to further experiment with the device.
+ Read [Try Out] section to further experiment with the device.
@@ -56,7 +56,7 @@
Download Agent
Click [ here ] for latest instructions and
+ target="_blank">[ here ] for latest instructions and
troubleshooting.