change digital display files

NuwanSameera 9 years ago
parent 65da5afe80
commit bfeb8e5500

@ -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);
@ -171,21 +169,20 @@ public class DigitalDisplayControllerService {
* @param newValue page is used to replace path * @param newValue page is used to replace path
*/ */
@Path("/edit-content") @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,
@QueryParam("path") String path, @FormParam("attribute") String attribute,
@QueryParam("attribute") String attribute, @FormParam("new-value") String newValue,
@QueryParam("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);
@ -210,20 +207,20 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/add-resource") @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,
@QueryParam("type") String type, @FormParam("type") String type,
@QueryParam("time") String time, @FormParam("time") String time,
@QueryParam("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);
@ -248,22 +245,22 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/add-resource-before") @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,
@QueryParam("type") String type, @FormParam("type") String type,
@QueryParam("time") String time, @FormParam("time") String time,
@QueryParam("path") String path, @FormParam("path") String path,
@QueryParam("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);
@ -289,22 +286,22 @@ public class DigitalDisplayControllerService {
*/ */
@Path("/add-resource-next") @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,
@QueryParam("type") String type, @FormParam("type") String type,
@QueryParam("time") String time, @FormParam("time") String time,
@QueryParam("path") String path, @FormParam("path") String path,
@QueryParam("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);
@ -325,19 +322,18 @@ public class DigitalDisplayControllerService {
* @param path path of the page no need to delete * @param path path of the page no need to delete
*/ */
@Path("/remove-resource") @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,
@QueryParam("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);
@ -359,18 +355,17 @@ public class DigitalDisplayControllerService {
* @param directoryName path of the folder need to delete * @param directoryName path of the folder need to delete
*/ */
@Path("/remove-directory") @Path("/remove-directory")
@DELETE @POST
@Produces(MediaType.APPLICATION_JSON) public void removeDirectory(@FormParam("directory-name") String directoryName,
public void removeDirectory(@QueryParam("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);
@ -393,19 +388,18 @@ public class DigitalDisplayControllerService {
* @param response response type of the method * @param response response type of the method
*/ */
@Path("/remove-content") @Path("/remove-content")
@DELETE @POST
@Produces(MediaType.APPLICATION_JSON) public void removeContent(@FormParam("directory-name") String directoryName,
public void removeContent(@QueryParam("directory_name") String directoryName, @FormParam("content") String content,
@QueryParam("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";
} }

@ -1,3 +1,4 @@
{{unit "cdmf.unit.lib.service-invoker-utility"}} {{unit "cdmf.unit.lib.service-invoker-utility"}}
{{unit "cdmf.unit.lib.handlebars"}} {{unit "cdmf.unit.lib.handlebars"}}
{{#defineZone "device-detail-top"}} {{#defineZone "device-detail-top"}}
@ -41,7 +42,7 @@
{{/defineZone}} {{/defineZone}}
<div style="background: #11375B; color: #fff; padding: 10px; margin-bottom: 5px">Operations</div> <div style="background: #11375B; color: #fff; padding: 10px; margin-bottom: 5px">Operations</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>
</div> </div>
</div> </div>

@ -0,0 +1,88 @@
<style>
::-webkit-input-placeholder { color:#f00; }
::-moz-placeholder { color:#f00; } /* firefox 19+ */
:-ms-input-placeholder { color:#f00; } /* ie */
input:-moz-placeholder { color:#f00; }
</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="number" name="path"
placeholder="path">
<input type="number" name="attribute"
placeholder="attribute">
<input type="number" name="new-value"
placeholder="new-value">
{{/if}}
{{#if add}}
<input type="number" name="type"
placeholder="type">
<input type="number" name="time"
placeholder="time">
<input type="number" name="path"
placeholder="path">
{{/if}}
{{#if before}}
<input type="number" name="next-page"
placeholder="next-page">
{{/if}}
{{#if after}}
<input type="number" name="before-page"
placeholder="before-page">
{{/if}}
{{#if removeresource}}
<input type="number" name="path"
placeholder="path">
{{/if}}
{{#if remove}}
<input type="number" name="directory-name"
placeholder="directory-name">
{{/if}}
{{#if content}}
<input type="number" 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