Merge pull request #56 from Shabirmean/IoTS-1.0.0-M1

Fixing the agent download issue
Ruwan 9 years ago
commit b67cae64f4

@ -18,8 +18,12 @@
package org.wso2.carbon.device.mgt.iot.virtualfirealarm.service; package org.wso2.carbon.device.mgt.iot.virtualfirealarm.service;
import org.apache.commons.io.FileUtils;
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.apache.cxf.helpers.IOUtils;
import org.apache.http.Header;
import org.apache.woden.wsdl20.extensions.http.HTTPHeader;
import org.wso2.carbon.certificate.mgt.core.dto.SCEPResponse; import org.wso2.carbon.certificate.mgt.core.dto.SCEPResponse;
import org.wso2.carbon.certificate.mgt.core.exception.KeystoreException; import org.wso2.carbon.certificate.mgt.core.exception.KeystoreException;
import org.wso2.carbon.certificate.mgt.core.service.CertificateManagementService; import org.wso2.carbon.certificate.mgt.core.service.CertificateManagementService;
@ -65,7 +69,11 @@ import javax.ws.rs.QueryParam;
import javax.ws.rs.core.Context; import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response; import javax.ws.rs.core.Response;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStream;
import java.nio.ByteBuffer; import java.nio.ByteBuffer;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.ArrayList; import java.util.ArrayList;
@ -325,13 +333,13 @@ public class VirtualFireAlarmService {
public Response downloadSketch(@QueryParam("owner") String owner, public Response downloadSketch(@QueryParam("owner") String owner,
@QueryParam("deviceName") String customDeviceName, @QueryParam("deviceName") String customDeviceName,
@PathParam("sketch_type") String sketchType) { @PathParam("sketch_type") String sketchType) {
//TODO:: null check customDeviceName at UI level
try { try {
ZipArchive zipFile = createDownloadFile(owner, customDeviceName, sketchType); ZipArchive zipFile = createDownloadFile(owner, customDeviceName, sketchType);
Response.ResponseBuilder rb = Response.ok(zipFile.getZipFile()); Response.ResponseBuilder response = Response.ok(FileUtils.readFileToByteArray(zipFile.getZipFile()));
rb.header("Content-Disposition", response.type(MediaType.MULTIPART_FORM_DATA_TYPE);
"attachment; filename=\"" + zipFile.getFileName() + "\""); response.header("Content-Disposition", "attachment; filename=\"" + zipFile.getFileName() + "\"");
return rb.build(); return response.build();
} catch (IllegalArgumentException ex) { } catch (IllegalArgumentException ex) {
return Response.status(400).entity(ex.getMessage()).build();//bad request return Response.status(400).entity(ex.getMessage()).build();//bad request
} catch (DeviceManagementException ex) { } catch (DeviceManagementException ex) {
@ -340,8 +348,9 @@ public class VirtualFireAlarmService {
return Response.status(500).entity(ex.getMessage()).build(); return Response.status(500).entity(ex.getMessage()).build();
} catch (DeviceControllerException ex) { } catch (DeviceControllerException ex) {
return Response.status(500).entity(ex.getMessage()).build(); return Response.status(500).entity(ex.getMessage()).build();
} catch (IOException ex) {
return Response.status(500).entity(ex.getMessage()).build();
} }
} }
@Path("manager/device/{sketch_type}/generate_link") @Path("manager/device/{sketch_type}/generate_link")

@ -73,7 +73,9 @@ public class VirtualFireAlarmXMPPConnector extends XmppConnector {
String deviceId = from.substring(0, indexOfAt); String deviceId = from.substring(0, indexOfAt);
String owner = from.substring(indexOfSlash + 1, from.length()); String owner = from.substring(indexOfSlash + 1, from.length());
log.info("Received XMPP message for: {OWNER-" + owner + "} & {DEVICE.ID-" + deviceId + "}"); if (log.isDebugEnabled()) {
log.debug("Received XMPP message for: {OWNER-" + owner + "} & {DEVICE.ID-" + deviceId + "}");
}
if (subject != null) { if (subject != null) {
switch (subject) { switch (subject) {
@ -98,7 +100,9 @@ public class VirtualFireAlarmXMPPConnector extends XmppConnector {
tempVal, Calendar.getInstance().getTimeInMillis()); tempVal, Calendar.getInstance().getTimeInMillis());
break; break;
default: default:
log.info("Unknown XMPP Message [" + message + "] from [" + from + "] received"); if (log.isDebugEnabled()) {
log.warn("Unknown XMPP Message [" + message + "] from [" + from + "] received");
}
break; break;
} }
} }

Loading…
Cancel
Save