Merge pull request #61 from charithag/IoTS-1.0.0-M1

Nuwan's digital display related changes
Ruwan 9 years ago
commit 0ae8bb200c

@ -11,9 +11,7 @@ import org.wso2.carbon.device.mgt.iot.digitaldisplay.constants.DigitalDisplayCon
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.ws.rs.*; import javax.ws.rs.*;
import javax.ws.rs.core.Context; import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response; import javax.ws.rs.core.Response;
import java.io.File;
/** /**
* Created by nuwan on 11/13/15. * Created by nuwan on 11/13/15.
@ -48,15 +46,15 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/restart-browser") @Path("/restart-browser")
@POST @POST
public void restartBrowser(@QueryParam("deviceId") String deviceId , public void restartBrowser(@FormParam("deviceId") String deviceId ,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@QueryParam("sessionId") String sessionId, @FormParam("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);
@ -79,15 +77,15 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/close-browser") @Path("/close-browser")
@POST @POST
public void closeBrowser(@QueryParam("deviceId") String deviceId, public void closeBrowser(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@QueryParam("sessionId") String sessionId, @FormParam("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);
@ -109,15 +107,15 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/terminate-display") @Path("/terminate-display")
@POST @POST
public void terminateDisplay(@QueryParam("deviceId") String deviceId, public void terminateDisplay(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@QueryParam("sessionId") String sessionId, @FormParam("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);
@ -139,15 +137,15 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/restart-display") @Path("/restart-display")
@POST @POST
public void restartDisplay(@QueryParam("deviceId") String deviceId, public void restartDisplay(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@QueryParam("sessionId") String sessionId, @FormParam("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);
@ -170,22 +168,21 @@ public class DigitalDisplayControllerService {
* @param attribute this can be path,time or type * @param attribute this can be path,time or type
* @param newValue page is used to replace path * @param newValue page is used to replace path
*/ */
@Path("/edit-content/{path}/{attribute}/{new-value}") @Path("/edit-content")
@PUT @POST
@Produces(MediaType.APPLICATION_JSON) public void editContent(@FormParam("deviceId") String deviceId,
public void editContent(@QueryParam("deviceId") String deviceId, @FormParam("owner") String owner,
@QueryParam("owner") String owner, @FormParam("path") String path,
@PathParam("path") String path, @FormParam("attribute") String attribute,
@PathParam("attribute") String attribute, @FormParam("new-value") String newValue,
@PathParam("new-value") String newValue, @FormParam("sessionId") String sessionId,
@QueryParam("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 + File.separator + attribute + File.separator + 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);
@ -208,22 +205,22 @@ public class DigitalDisplayControllerService {
* @param time new resource visible time * @param time new resource visible time
* @param path URL of the new resource * @param path URL of the new resource
*/ */
@Path("/add-resource/{type}/{time}/{path}") @Path("/add-resource")
@POST @POST
public void addNewResource(@QueryParam("deviceId") String deviceId, public void addNewResource(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@PathParam("type") String type, @FormParam("type") String type,
@PathParam("time") String time, @FormParam("time") String time,
@PathParam("path") String path, @FormParam("path") String path,
@QueryParam("sessionId") String sessionId, @FormParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response){
log.info("Add Sequence : " + deviceId); log.info("Add Sequence : " + deviceId);
try { try {
String params = type + File.separator + time + File.separator + 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);
@ -246,24 +243,24 @@ public class DigitalDisplayControllerService {
* @param path URL of the new resource * @param path URL of the new resource
* @param nextPage next page no of after adding new resource * @param nextPage next page no of after adding new resource
*/ */
@Path("/add-resource-before/{type}/{time}/{path}/{next-page}") @Path("/add-resource-before")
@POST @POST
public void addNewResourceBefore(@QueryParam("deviceId") String deviceId, public void addNewResourceBefore(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@QueryParam("sessionId") String sessionId, @FormParam("sessionId") String sessionId,
@PathParam("type") String type, @FormParam("type") String type,
@PathParam("time") String time, @FormParam("time") String time,
@PathParam("path") String path, @FormParam("path") String path,
@PathParam("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 + File.separator + time + File.separator + path + String params = type + "|" + time + "|" + path +
File.separator + "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);
@ -287,24 +284,24 @@ public class DigitalDisplayControllerService {
* @param path URL of the new resource * @param path URL of the new resource
* @param beforePage before page no of after adding new resource * @param beforePage before page no of after adding new resource
*/ */
@Path("/add-resource-next/{type}/{time}/{path}/{before-page}") @Path("/add-resource-next")
@POST @POST
public void addNewResourceAfter(@QueryParam("deviceId") String deviceId, public void addNewResourceAfter(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@PathParam("type") String type, @FormParam("type") String type,
@PathParam("time") String time, @FormParam("time") String time,
@PathParam("path") String path, @FormParam("path") String path,
@PathParam("before-page") String beforePage, @FormParam("before-page") String beforePage,
@QueryParam("sessionId") String sessionId, @FormParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response){
log.info("Add Sequence : " + deviceId); log.info("Add Sequence : " + deviceId);
try { try {
String params = type + File.separator + time + File.separator + path + String params = type + "|" + time + "|" + path +
File.separator + "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);
@ -324,20 +321,19 @@ public class DigitalDisplayControllerService {
* @param response response type of the method * @param response response type of the method
* @param path path of the page no need to delete * @param path path of the page no need to delete
*/ */
@Path("/remove-resource/{path}") @Path("/remove-resource")
@DELETE @POST
@Produces(MediaType.APPLICATION_JSON) public void removeResource(@FormParam("deviceId") String deviceId,
public void removeResource(@QueryParam("deviceId") String deviceId, @FormParam("owner") String owner,
@QueryParam("owner") String owner, @FormParam("path") String path,
@PathParam("path") String path, @FormParam("sessionId") String sessionId,
@QueryParam("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);
@ -358,19 +354,18 @@ public class DigitalDisplayControllerService {
* @param response response type of the method * @param response response type of the method
* @param directoryName path of the folder need to delete * @param directoryName path of the folder need to delete
*/ */
@Path("/remove-directory/{directory-name}") @Path("/remove-directory")
@DELETE @POST
@Produces(MediaType.APPLICATION_JSON) public void removeDirectory(@FormParam("directory-name") String directoryName,
public void removeDirectory(@PathParam("directory-name") String directoryName, @FormParam("deviceId") String deviceId ,
@QueryParam("deviceId") String deviceId , @FormParam("owner") String owner,
@QueryParam("owner") String owner, @FormParam("sessionId") String sessionId,
@QueryParam("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);
@ -392,20 +387,19 @@ public class DigitalDisplayControllerService {
* @param content file name of need to delete * @param content file name of need to delete
* @param response response type of the method * @param response response type of the method
*/ */
@Path("/remove-content/{directory_name}/{content}") @Path("/remove-content")
@DELETE @POST
@Produces(MediaType.APPLICATION_JSON) public void removeContent(@FormParam("directory-name") String directoryName,
public void removeContent(@PathParam("directory_name") String directoryName, @FormParam("content") String content,
@PathParam("content") String content, @FormParam("deviceId") String deviceId ,
@QueryParam("deviceId") String deviceId , @FormParam("owner") String owner,
@QueryParam("owner") String owner, @FormParam("sessionId") String sessionId,
@QueryParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response){
log.info("Remove Content : " + deviceId); log.info("Remove Content : " + deviceId);
try { try {
String param = directoryName + File.separator + 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);
@ -427,15 +421,15 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/shutdown-display") @Path("/shutdown-display")
@POST @POST
public void shutDownDisplay(@QueryParam("deviceId") String deviceId, public void shutDownDisplay(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@QueryParam("sessionId") String sessionId, @FormParam("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);
@ -457,9 +451,9 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/get-status") @Path("/get-status")
@GET @GET
public void getStatus(@QueryParam("deviceId") String deviceId, public void getStatus(@FormParam("deviceId") String deviceId,
@QueryParam("owner") String owner, @FormParam("owner") String owner,
@QueryParam("sessionId") String sessionId, @FormParam("sessionId") String sessionId,
@Context HttpServletResponse response){ @Context HttpServletResponse response){
log.info("Status : " + deviceId); log.info("Status : " + deviceId);

@ -21,9 +21,6 @@ public class DigitalDisplayConstants {
public final static String DEVICE_TYPE = "digital_display"; public final static String DEVICE_TYPE = "digital_display";
public final static String DEVICE_PLUGIN_DEVICE_NAME = "DEVICE_NAME"; public final static String DEVICE_PLUGIN_DEVICE_NAME = "DEVICE_NAME";
public final static String DEVICE_PLUGIN_DEVICE_ID = "DIGITAL_DISPLAY_DEVICE_ID"; public final static String DEVICE_PLUGIN_DEVICE_ID = "DIGITAL_DISPLAY_DEVICE_ID";
public final static String MQTT_BROKER_END_POINT = "tcp://204.232.188.214:1883";
public final static String SHUTDOWN_DISPLAY_CONSTANT = "shutdown_display"; public final static String SHUTDOWN_DISPLAY_CONSTANT = "shutdown_display";
public final static String RESTART_DISPLAY_CONSTANT = "restart_display"; public final static String RESTART_DISPLAY_CONSTANT = "restart_display";
public final static String REMOVE_DIRECTORY_CONSTANT = "remove_dir_and_content"; public final static String REMOVE_DIRECTORY_CONSTANT = "remove_dir_and_content";
@ -35,7 +32,6 @@ public class DigitalDisplayConstants {
public final static String ADD_NEW_RESOURCE_CONSTANT = "add_new_resource"; public final static String ADD_NEW_RESOURCE_CONSTANT = "add_new_resource";
public final static String REMOVE_RESOURCE_CONSTANT = "remove_resources"; public final static String REMOVE_RESOURCE_CONSTANT = "remove_resources";
public final static String GET_STATUS_CONSTANT = "get_status"; public final static String GET_STATUS_CONSTANT = "get_status";
public final static String PUBLISH_TOPIC = "wso2/iot/%s/digital_display/%s/digital_display_subscriber"; public final static String PUBLISH_TOPIC = "wso2/iot/%s/digital_display/%s/digital_display_subscriber";
} }

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

@ -0,0 +1,88 @@
<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>

@ -0,0 +1,6 @@
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};
}
Loading…
Cancel
Save