Update operation features with endpoints

charithag 9 years ago
parent 9cfb57e983
commit afcabb7fbc

@ -1,27 +1,45 @@
/*
* 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.digitaldisplay.api; package org.wso2.carbon.device.mgt.iot.digitaldisplay.api;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.wso2.carbon.apimgt.annotations.api.API;
import org.wso2.carbon.apimgt.annotations.device.DeviceType; import org.wso2.carbon.apimgt.annotations.device.DeviceType;
import org.wso2.carbon.apimgt.annotations.device.feature.Feature;
import org.wso2.carbon.device.mgt.common.DeviceManagementException; import org.wso2.carbon.device.mgt.common.DeviceManagementException;
import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.exception.DigitalDisplayException; import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.exception.DigitalDisplayException;
import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.transport.CommunicationHandlerException; import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.transport.CommunicationHandlerException;
import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.util.DigitalDisplayMqttCommunicationHandler; import org.wso2.carbon.device.mgt.iot.digitaldisplay.api.util.DigitalDisplayMqttCommunicationHandler;
import org.wso2.carbon.device.mgt.iot.digitaldisplay.constants.DigitalDisplayConstants; import org.wso2.carbon.device.mgt.iot.digitaldisplay.constants.DigitalDisplayConstants;
import org.wso2.carbon.apimgt.annotations.api.API;
import org.wso2.carbon.apimgt.annotations.device.feature.Feature;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.ws.rs.*; import javax.ws.rs.FormParam;
import javax.ws.rs.HeaderParam;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.core.Context; import javax.ws.rs.core.Context;
import javax.ws.rs.core.Response; import javax.ws.rs.core.Response;
/**
* Created by nuwan on 11/13/15.
*/
@API( name="digital_display", version="1.0.0", context="/digital_display") @API(name = "digital_display", version = "1.0.0", context = "/digital_display")
@DeviceType( value = "digital_display") @DeviceType(value = "digital_display")
public class DigitalDisplayControllerService { public class DigitalDisplayControllerService {
@ -29,18 +47,18 @@ public class DigitalDisplayControllerService {
private static DigitalDisplayMqttCommunicationHandler digitalDisplayMqttCommunicationHandler; private static DigitalDisplayMqttCommunicationHandler digitalDisplayMqttCommunicationHandler;
public void setDigitalDisplayMqttCommunicationHandler(DigitalDisplayMqttCommunicationHandler digitalDisplayMqttCommunicationHandler){ public DigitalDisplayMqttCommunicationHandler getDigitalDisplayMqttCommunicationHandler() {
return DigitalDisplayControllerService.digitalDisplayMqttCommunicationHandler;
}
public void setDigitalDisplayMqttCommunicationHandler(
DigitalDisplayMqttCommunicationHandler digitalDisplayMqttCommunicationHandler) {
DigitalDisplayControllerService.digitalDisplayMqttCommunicationHandler = digitalDisplayMqttCommunicationHandler; DigitalDisplayControllerService.digitalDisplayMqttCommunicationHandler = digitalDisplayMqttCommunicationHandler;
digitalDisplayMqttCommunicationHandler.connect(); digitalDisplayMqttCommunicationHandler.connect();
} }
public DigitalDisplayMqttCommunicationHandler getDigitalDisplayMqttCommunicationHandler(){
return DigitalDisplayControllerService.digitalDisplayMqttCommunicationHandler;
}
/** /**
* Restart the running browser in the given digital display. * Restart the running browser in the given digital display.
* *
@ -51,22 +69,22 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/restart-browser") @Path("/restart-browser")
@POST @POST
@Feature( code="DISPLAY_BROWSERRESTART", name="Restart Browser", @Feature(code = "DISPLAY_BROWSERRESTART", name = "Restart Browser",
description="Restart Browser in Digital Display") description = "Restart Browser in Digital Display")
public void restartBrowser(@FormParam("deviceId") String deviceId , public void restartBrowser(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Restrat Browser : " + deviceId); log.info("Restrat Browser : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId +"::" + DigitalDisplayConstants.RESTART_BROWSER_CONSTANT + ":",""); sendCommandViaMQTT(owner, deviceId, sessionId + "::" + DigitalDisplayConstants.RESTART_BROWSER_CONSTANT + ":", "");
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
@ -84,22 +102,22 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/close-browser") @Path("/close-browser")
@POST @POST
@Feature( code="DISPLAY_BROWSERCLOSE", name="Close Browser", @Feature(code = "DISPLAY_BROWSERCLOSE", name = "Close Browser",
description="Close Browser in Digital Display") description = "Close Browser in Digital Display")
public void closeBrowser(@FormParam("deviceId") String deviceId, public void closeBrowser(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Close Browser : " + deviceId); log.info("Close Browser : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId +"::" + DigitalDisplayConstants.CLOSE_BROWSER_CONSTANT + ":" ,""); sendCommandViaMQTT(owner, deviceId, sessionId + "::" + DigitalDisplayConstants.CLOSE_BROWSER_CONSTANT + ":", "");
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -116,22 +134,22 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/terminate-display") @Path("/terminate-display")
@POST @POST
@Feature( code="DISPLAY_TERMINATE", name="Terminate Display", @Feature(code = "DISPLAY_TERMINATE", name = "Terminate Display",
description="Terminate all running processe in Digital Display") description = "Terminate all running processe in Digital Display")
public void terminateDisplay(@FormParam("deviceId") String deviceId, public void terminateDisplay(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Terminate Display : " + deviceId); log.info("Terminate Display : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId +"::" + DigitalDisplayConstants.TERMINATE_DISPLAY_CONSTANT +":" ,""); sendCommandViaMQTT(owner, deviceId, sessionId + "::" + DigitalDisplayConstants.TERMINATE_DISPLAY_CONSTANT + ":", "");
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -148,22 +166,22 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/restart-display") @Path("/restart-display")
@POST @POST
@Feature( code="DISPLAY_RESTART", name="Restart Display", @Feature(code = "DISPLAY_RESTART", name = "Restart Display",
description="Restart Digital Display") description = "Restart Digital Display")
public void restartDisplay(@FormParam("deviceId") String deviceId, public void restartDisplay(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Restrat Display : " + deviceId); log.info("Restrat Display : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId +"::" + DigitalDisplayConstants.RESTART_DISPLAY_CONSTANT + ":" ,""); sendCommandViaMQTT(owner, deviceId, sessionId + "::" + DigitalDisplayConstants.RESTART_DISPLAY_CONSTANT + ":", "");
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -183,26 +201,26 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/edit-content") @Path("/edit-content")
@POST @POST
@Feature( code="DISPLAY_EDITCONTENT", name="Edit Content", @Feature(code = "DISPLAY_EDITCONTENT", name = "Edit Content",
description="Search through the sequence and edit requested resource in Digital Display") description = "Search through the sequence and edit requested resource in Digital Display")
public void editContent(@FormParam("deviceId") String deviceId, public void editContent(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("path") String path, @FormParam("path") String path,
@FormParam("attribute") String attribute, @FormParam("attribute") String attribute,
@FormParam("new-value") String newValue, @FormParam("new-value") String newValue,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Edit Content Display Id - " + deviceId + " by " + owner); log.info("Edit Content Display Id - " + deviceId + " by " + owner);
try { try {
String params = path + "|" + attribute + "|" + newValue; String params = path + "|" + attribute + "|" + newValue;
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + DigitalDisplayConstants.EDIT_SEQUENCE_CONSTANT +":" ,params); sendCommandViaMQTT(owner, deviceId, sessionId + "::" + DigitalDisplayConstants.EDIT_SEQUENCE_CONSTANT + ":", params);
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -222,27 +240,27 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/add-resource") @Path("/add-resource")
@POST @POST
@Feature( code="DISPLAY_ADDRESOURCE", name="Add Resource", @Feature(code = "DISPLAY_ADDRESOURCE", name = "Add Resource",
description="Add new resource end to the existing sequence in Digital Display") description = "Add new resource end to the existing sequence in Digital Display")
public void addNewResource(@FormParam("deviceId") String deviceId, public void addNewResource(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("type") String type, @FormParam("type") String type,
@FormParam("time") String time, @FormParam("time") String time,
@FormParam("path") String path, @FormParam("path") String path,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Add Sequence : " + deviceId); log.info("Add Sequence : " + deviceId);
try { try {
String params = type + "|" + time + "|" + path; String params = type + "|" + time + "|" + path;
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + sendCommandViaMQTT(owner, deviceId, sessionId + "::" +
DigitalDisplayConstants.ADD_NEW_RESOURCE_CONSTANT +":" ,params); DigitalDisplayConstants.ADD_NEW_RESOURCE_CONSTANT + ":", params);
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -262,29 +280,29 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/add-resource-before") @Path("/add-resource-before")
@POST @POST
@Feature( code="DISPLAY_ADDRESOURCE_BEFORE", name="Add Resource Before", @Feature(code = "DISPLAY_ADDRESOURCE_BEFORE", name = "Add Resource Before",
description="Add new resource to sequence before given page no. in Digital Display") description = "Add new resource to sequence before given page no. in Digital Display")
public void addNewResourceBefore(@FormParam("deviceId") String deviceId, public void addNewResourceBefore(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@FormParam("type") String type, @FormParam("type") String type,
@FormParam("time") String time, @FormParam("time") String time,
@FormParam("path") String path, @FormParam("path") String path,
@FormParam("next-page") String nextPage, @FormParam("next-page") String nextPage,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Add Sequence : " + deviceId); log.info("Add Sequence : " + deviceId);
try { try {
String params = type + "|" + time + "|" + path + String params = type + "|" + time + "|" + path +
"|" + "before=" + nextPage; "|" + "before=" + nextPage;
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + sendCommandViaMQTT(owner, deviceId, sessionId + "::" +
DigitalDisplayConstants.ADD_NEW_RESOURCE_CONSTANT +":" ,params); DigitalDisplayConstants.ADD_NEW_RESOURCE_CONSTANT + ":", params);
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -305,29 +323,29 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/add-resource-next") @Path("/add-resource-next")
@POST @POST
@Feature( code="DISPLAY_ADDRESOURCE_NEXT", name="Add Resource Next", @Feature(code = "DISPLAY_ADDRESOURCE_NEXT", name = "Add Resource Next",
description="Add new resource to sequence after given page in Digital Display") description = "Add new resource to sequence after given page in Digital Display")
public void addNewResourceAfter(@FormParam("deviceId") String deviceId, public void addNewResourceAfter(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("type") String type, @FormParam("type") String type,
@FormParam("time") String time, @FormParam("time") String time,
@FormParam("path") String path, @FormParam("path") String path,
@FormParam("before-page") String beforePage, @FormParam("before-page") String beforePage,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Add Sequence : " + deviceId); log.info("Add Sequence : " + deviceId);
try { try {
String params = type + "|" + time + "|" + path + String params = type + "|" + time + "|" + path +
"|" + "after=" + beforePage; "|" + "after=" + beforePage;
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + sendCommandViaMQTT(owner, deviceId, sessionId + "::" +
DigitalDisplayConstants.ADD_NEW_RESOURCE_CONSTANT + ":",params); DigitalDisplayConstants.ADD_NEW_RESOURCE_CONSTANT + ":", params);
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -344,24 +362,24 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/remove-resource") @Path("/remove-resource")
@POST @POST
@Feature( code="DISPLAY_REMOVE_RESOURCE", name="Remove Resource", @Feature(code = "DISPLAY_REMOVE_RESOURCE", name = "Remove Resource",
description="Delete a resource from sequence in Digital Display") description = "Delete a resource from sequence in Digital Display")
public void removeResource(@FormParam("deviceId") String deviceId, public void removeResource(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("path") String path, @FormParam("path") String path,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Remove Resource : " + deviceId); log.info("Remove Resource : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + sendCommandViaMQTT(owner, deviceId, sessionId + "::" +
DigitalDisplayConstants.REMOVE_RESOURCE_CONSTANT + ":",path); DigitalDisplayConstants.REMOVE_RESOURCE_CONSTANT + ":", path);
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -379,23 +397,23 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/remove-directory") @Path("/remove-directory")
@POST @POST
@Feature( code="DISPLAY_REMOVE_DIR", name="Remove Directory", @Feature(code = "DISPLAY_REMOVE_DIR", name = "Remove Directory",
description="Remove directory and whole content in Digital Display") description = "Remove directory and whole content in Digital Display")
public void removeDirectory(@FormParam("directory-name") String directoryName, public void removeDirectory(@FormParam("directory-name") String directoryName,
@FormParam("deviceId") String deviceId , @HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Remove Directory : " + deviceId); log.info("Remove Directory : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + sendCommandViaMQTT(owner, deviceId, sessionId + "::" +
DigitalDisplayConstants.REMOVE_DIRECTORY_CONSTANT + ":",directoryName); DigitalDisplayConstants.REMOVE_DIRECTORY_CONSTANT + ":", directoryName);
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -414,24 +432,24 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/remove-content") @Path("/remove-content")
@POST @POST
@Feature( code="DISPLAY_REMOVE_CONTENT", name="Remove Content", @Feature(code = "DISPLAY_REMOVE_CONTENT", name = "Remove Content",
description="Remove content from www folder in Digital Display") description = "Remove content from www folder in Digital Display")
public void removeContent(@FormParam("directory-name") String directoryName, public void removeContent(@FormParam("directory-name") String directoryName,
@FormParam("content") String content, @FormParam("content") String content,
@FormParam("deviceId") String deviceId , @HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Remove Content : " + deviceId); log.info("Remove Content : " + deviceId);
try { try {
String param = directoryName + "|" + content; String param = directoryName + "|" + content;
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + DigitalDisplayConstants.REMOVE_CONTENT_CONSTANT + ":",param); sendCommandViaMQTT(owner, deviceId, sessionId + "::" + DigitalDisplayConstants.REMOVE_CONTENT_CONSTANT + ":", param);
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -448,22 +466,22 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/shutdown-display") @Path("/shutdown-display")
@POST @POST
@Feature( code="DISPLAY_SHUTDOWN", name="Shut Down", @Feature(code = "DISPLAY_SHUTDOWN", name = "Shut Down",
description="Stop specific display in Digital Display") description = "Stop specific display in Digital Display")
public void shutDownDisplay(@FormParam("deviceId") String deviceId, public void shutDownDisplay(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Shut down display : " + deviceId); log.info("Shut down display : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId + "::" + DigitalDisplayConstants.SHUTDOWN_DISPLAY_CONSTANT + ":" ,""); sendCommandViaMQTT(owner, deviceId, sessionId + "::" + DigitalDisplayConstants.SHUTDOWN_DISPLAY_CONSTANT + ":", "");
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -479,23 +497,23 @@ public class DigitalDisplayControllerService {
* @param response response type of the method * @param response response type of the method
*/ */
@Path("/get-status") @Path("/get-status")
@GET @POST
@Feature( code="DISPLAY_GET_STATUS", name="Get Status", @Feature(code = "DISPLAY_GET_STATUS", name = "Get Status",
description="Check specific digital display power ON of OFF") description = "Check specific digital display power ON of OFF")
public void getStatus(@FormParam("deviceId") String deviceId, public void getStatus(@HeaderParam("deviceId") String deviceId,
@FormParam("owner") String owner, @HeaderParam("owner") String owner,
@FormParam("sessionId") String sessionId, @HeaderParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response) {
log.info("Status : " + deviceId); log.info("Status : " + deviceId);
try { try {
sendCommandViaMQTT(owner,deviceId,sessionId + ":" + DigitalDisplayConstants.GET_STATUS_CONSTANT,""); sendCommandViaMQTT(owner, deviceId, sessionId + ":" + DigitalDisplayConstants.GET_STATUS_CONSTANT, "");
response.setStatus(Response.Status.OK.getStatusCode()); response.setStatus(Response.Status.OK.getStatusCode());
} catch (DeviceManagementException e) { } catch (DeviceManagementException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode()); response.setStatus(Response.Status.UNAUTHORIZED.getStatusCode());
}catch (DigitalDisplayException e){ } catch (DigitalDisplayException e) {
log.error(e); log.error(e);
response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode()); response.setStatus(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode());
} }
@ -513,17 +531,18 @@ public class DigitalDisplayControllerService {
* @throws DigitalDisplayException * @throws DigitalDisplayException
*/ */
private void sendCommandViaMQTT(String deviceOwner, String deviceId, String operation, private void sendCommandViaMQTT(String deviceOwner, String deviceId, String operation,
String param) throws DeviceManagementException, DigitalDisplayException { String param)
throws DeviceManagementException, DigitalDisplayException {
log.info(deviceOwner); log.info(deviceOwner);
String topic = String.format(DigitalDisplayConstants.PUBLISH_TOPIC , deviceOwner , deviceId); String topic = String.format(DigitalDisplayConstants.PUBLISH_TOPIC, deviceOwner, deviceId);
String payload = operation + ":" + param; String payload = operation + ":" + param;
try { try {
digitalDisplayMqttCommunicationHandler.publishToDigitalDisplay(topic, payload, 2, true); digitalDisplayMqttCommunicationHandler.publishToDigitalDisplay(topic, payload, 2, true);
} catch (CommunicationHandlerException e) { } catch (CommunicationHandlerException e) {
String errorMessage = "Error publishing data to device with ID " + deviceId; String errorMessage = "Error publishing data to device with ID " + deviceId;
throw new DigitalDisplayException(errorMessage,e); throw new DigitalDisplayException(errorMessage, e);
} }
} }

@ -58,6 +58,7 @@ import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.ws.rs.Consumes; import javax.ws.rs.Consumes;
import javax.ws.rs.DELETE; import javax.ws.rs.DELETE;
import javax.ws.rs.FormParam;
import javax.ws.rs.GET; import javax.ws.rs.GET;
import javax.ws.rs.HeaderParam; import javax.ws.rs.HeaderParam;
import javax.ws.rs.POST; import javax.ws.rs.POST;
@ -566,14 +567,14 @@ public class VirtualFireAlarmService {
* @param state * @param state
* @param response * @param response
*/ */
@Path("controller/bulb/{state}") @Path("controller/bulb")
@POST @POST
@Feature( code="VIRTUALFIREALARM_BULBCONTROL", name="Control Bulb", @Feature( code="VIRTUALFIREALARM_BULBCONTROL", name="Control Bulb",
description="Switch on/off Virtual Fire Alarm Bulb") description="Switch on/off Virtual Fire Alarm Bulb")
public void switchBulb(@HeaderParam("owner") String owner, public void switchBulb(@HeaderParam("owner") String owner,
@HeaderParam("deviceId") String deviceId, @HeaderParam("deviceId") String deviceId,
@HeaderParam("protocol") String protocol, @HeaderParam("protocol") String protocol,
@PathParam("state") String state, @FormParam("state") String state,
@Context HttpServletResponse response) { @Context HttpServletResponse response) {
try { try {

@ -6,7 +6,7 @@
Operations Operations
</div> </div>
<div class="add-margin-top-4x"> <div class="add-margin-top-4x">
{{unit "iot.unit.device.digitaldisplay.operation" device=device}} {{unit "iot.unit.device.operation" device=device}}
</div> </div>
{{/zone}} {{/zone}}
{{#zone "device-detail-properties"}} {{#zone "device-detail-properties"}}

@ -1,10 +1,28 @@
/*
* 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.
*/
function onRequest(context) { function onRequest(context) {
var log = new Log("detail.js"); var log = new Log("detail.js");
var deviceType = context.uriParams.deviceType; var deviceType = context.uriParams.deviceType;
var deviceId = request.getParameter("id"); var deviceId = request.getParameter("id");
if (deviceType != null && deviceType != undefined && deviceId != null && deviceId != undefined) { if (deviceType != null && deviceType != undefined && deviceId != null && deviceId != undefined) {
var deviceModule = require("/modules/device.js").deviceModule; var deviceModule = require("/app/modules/device.js").deviceModule;
var device = deviceModule.viewDevice(deviceType, deviceId); var device = deviceModule.viewDevice(deviceType, deviceId);
if (device && device.status != "error") { if (device && device.status != "error") {

@ -1,88 +0,0 @@
<style>
::-webkit-input-placeholder { color:#161616; }
::-moz-placeholder { color:#161616; }
:-ms-input-placeholder { color:#161616; }
input:-moz-placeholder { color:#161616; }
</style>
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="headingOne">
<h2 class="sub-title panel-title">
<a data-toggle="collapse"
href="#collapseOne" aria-expanded="true"
aria-controls="collapseOne">
<span class="fw-stack">
<i class="fw fw-ring fw-stack-2x"></i>
<i class="fw fw-arrow fw-down fw-stack-1x"></i>
</span>
Device Operations
</a>
</h2>
</div>
<div id="collapseOne" class="panel-collapse collapse in"
role="tabpanel" aria-labelledby="headingOne">
<div id="device-location" class="panel-body">
{{#if control_operations}}
{{#each control_operations}}
<form action="{{@app.context}}/api/operations/{{../../device.type}}/{{operation}}" method="post">
<div class="row">
<div class="wr-input-control">
<label class="wr-input-label">{{name}}</label>
<input type="hidden" name="owner"
value={{../../device.owner}}>
<input type="hidden" name="deviceId"
value={{../../device.deviceIdentifier}}>
{{#if editcontent}}
<input type="text" name="path"
placeholder="page no">
<input type="text" name="attribute"
placeholder="attribute">
<input type="text" name="new-value"
placeholder="new-value">
{{/if}}
{{#if add}}
<input type="text" name="type"
placeholder="type">
<input type="text" name="time"
placeholder="time">
<input type="text" name="path"
placeholder="page no">
{{/if}}
{{#if before}}
<input type="text" name="next-page"
placeholder="next-page">
{{/if}}
{{#if after}}
<input type="text" name="before-page"
placeholder="before-page">
{{/if}}
{{#if removeresource}}
<input type="text" name="path"
placeholder="page no">
{{/if}}
{{#if remove}}
<input type="text" name="directory-name"
placeholder="directory-name">
{{/if}}
{{#if content}}
<input type="text" name="content"
placeholder="content">
{{/if}}
<button class="wr-btn">&nbsp;&nbsp;&nbsp;&nbsp;Send
to Device&nbsp;&nbsp;&nbsp;&nbsp;</button>
<label id="lblSending" class="wr-input-label hidden"><i class="fw fw-lifecycle fw-spin fw-2x"></i> Sending..</label>
<label id="lblSent" class="wr-input-label hidden"><i class="fw fw-check fw-2x"></i> Sent</label>
<label id="lblLastState" class="wr-input-label wr-input-label-status"></label>
</div>
</div>
</form>
{{/each}}
{{/if}}
</div>
</div>
</div>

@ -1,6 +0,0 @@
function onRequest(context) {
var operationModule = require("/app/modules/operation.js").operationModule;
var device = context.unit.params.device;
var control_operations = operationModule.getControlOperations(device.type);
return {"control_operations": control_operations, "device": device};
}

@ -1,10 +1,28 @@
{{#if control_operations}} {{#if control_operations}}
<style>
::-webkit-input-placeholder {
color: #B8B8B8;
}
::-moz-placeholder {
color: #B8B8B8;
}
:-ms-input-placeholder {
color: #B8B8B8;
}
input:-moz-placeholder {
color: #B8B8B8;
}
</style>
{{#each control_operations}} {{#each control_operations}}
<form action="{{@app.context}}/api/operations/{{../device.type}}/{{operation}}?deviceId={{../device.deviceIdentifier}}" <form action="{{@app.context}}/api/operations/{{../device.type}}/{{operation}}?deviceId={{../device.deviceIdentifier}}"
method="post" class="form-inline"> method="post" class="form-inline" style="padding-bottom: 20px;">
<label class="wr-input-label">{{name}}</label> <label class="wr-input-label">{{name}}</label>
<input type="number" name="value" {{#each params}}
placeholder="{{description}}"> <input type="text" name="{{this}}" placeholder="{{this}}">
{{/each}}
<button class="wr-btn">&nbsp;&nbsp;&nbsp;&nbsp;Send <button class="wr-btn">&nbsp;&nbsp;&nbsp;&nbsp;Send
to Device&nbsp;&nbsp;&nbsp;&nbsp;</button> to Device&nbsp;&nbsp;&nbsp;&nbsp;</button>
<label id="lblSending" class="wr-input-label hidden"><i <label id="lblSending" class="wr-input-label hidden"><i
@ -16,3 +34,7 @@
</form> </form>
{{/each}} {{/each}}
{{/if}} {{/if}}
{{#zone "bottomJs"}}
{{js "js/operation.js"}}
{{/zone}}

@ -0,0 +1,42 @@
/*
* 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.
*/
$("form").on('submit', function (e) {
var postOperationRequest = $.ajax({
url: $(this).attr("action") + '&' + $(this).serialize(),
method: "post"
});
var lblSending = $('#lblSending', this);
lblSending.removeClass('hidden');
var lblSent = $('#lblSent', this);
postOperationRequest.done(function (data) {
lblSending.addClass('hidden');
lblSent.removeClass('hidden');
setTimeout(function () {
lblSent.addClass('hidden');
}, 3000);
});
postOperationRequest.fail(function (jqXHR, textStatus) {
lblSending.addClass('hidden');
lblSent.addClass('hidden');
});
e.preventDefault();
});

@ -10,8 +10,8 @@
* *
* Unless required by applicable law or agreed to in writing, * Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an * software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* either express or implied. See the License for the * KIND, either express or implied. See the License for the
* specific language governing permissions and limitations * specific language governing permissions and limitations
* under the License. * under the License.
*/ */
@ -83,33 +83,6 @@ $(document).ready(function () {
updateGraphs(); updateGraphs();
}); });
$("form").on('submit', function (e) {
var postOperationRequest = $.ajax({
url: $(this).attr("action") + '&' + $(this).serialize(),
method: "post"
});
var lblSending = $('#lblSending', this);
lblSending.removeClass('hidden');
var lblSent = $('#lblSent', this);
var sentValue = $(this).find('input[name="value"]').val();
postOperationRequest.done(function (data) {
lblSending.addClass('hidden');
lblSent.removeClass('hidden');
setTimeout(function () {
lblSent.addClass('hidden');
}, 3000);
$('#lblLastState').text('Current value: ' + (sentValue == '1' ? 'On' : 'Off'));
});
postOperationRequest.fail(function (jqXHR, textStatus) {
lblSending.addClass('hidden');
lblSent.addClass('hidden');
});
e.preventDefault();
});
function updateGraphs() { function updateGraphs() {
var tv = 5000; var tv = 5000;

Loading…
Cancel
Save