|
|
@ -1,5 +1,5 @@
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
|
|
|
* Copyright (c) 2016, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* WSO2 Inc. licenses this file to you under the Apache License,
|
|
|
|
* WSO2 Inc. licenses this file to you under the Apache License,
|
|
|
|
* Version 2.0 (the "License"); you may not use this file except
|
|
|
|
* Version 2.0 (the "License"); you may not use this file except
|
|
|
@ -50,6 +50,9 @@ import java.security.cert.X509Certificate;
|
|
|
|
import java.util.concurrent.CountDownLatch;
|
|
|
|
import java.util.concurrent.CountDownLatch;
|
|
|
|
import java.util.concurrent.Future;
|
|
|
|
import java.util.concurrent.Future;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
*/
|
|
|
|
public class VirtualFireAlarmServiceUtils {
|
|
|
|
public class VirtualFireAlarmServiceUtils {
|
|
|
|
private static final Log log = LogFactory.getLog(VirtualFireAlarmServiceUtils.class);
|
|
|
|
private static final Log log = LogFactory.getLog(VirtualFireAlarmServiceUtils.class);
|
|
|
|
|
|
|
|
|
|
|
@ -59,8 +62,12 @@ public class VirtualFireAlarmServiceUtils {
|
|
|
|
private static final String JSON_MESSAGE_KEY = "Msg";
|
|
|
|
private static final String JSON_MESSAGE_KEY = "Msg";
|
|
|
|
private static final String JSON_SIGNATURE_KEY = "Sig";
|
|
|
|
private static final String JSON_SIGNATURE_KEY = "Sig";
|
|
|
|
|
|
|
|
|
|
|
|
public static CertificateManagementService getCertificateManagementService() throws
|
|
|
|
/**
|
|
|
|
VirtualFireAlarmException {
|
|
|
|
*
|
|
|
|
|
|
|
|
* @return
|
|
|
|
|
|
|
|
* @throws VirtualFireAlarmException
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
public static CertificateManagementService getCertificateManagementService() throws VirtualFireAlarmException {
|
|
|
|
|
|
|
|
|
|
|
|
PrivilegedCarbonContext ctx = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
PrivilegedCarbonContext ctx = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
CertificateManagementService certificateManagementService = (CertificateManagementService)
|
|
|
|
CertificateManagementService certificateManagementService = (CertificateManagementService)
|
|
|
@ -76,8 +83,16 @@ public class VirtualFireAlarmServiceUtils {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static String sendCommandViaHTTP(final String deviceHTTPEndpoint, String urlContext,
|
|
|
|
/**
|
|
|
|
boolean fireAndForgot) throws DeviceManagementException {
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param deviceHTTPEndpoint
|
|
|
|
|
|
|
|
* @param urlContext
|
|
|
|
|
|
|
|
* @param fireAndForgot
|
|
|
|
|
|
|
|
* @return
|
|
|
|
|
|
|
|
* @throws DeviceManagementException
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
public static String sendCommandViaHTTP(final String deviceHTTPEndpoint, String urlContext, boolean fireAndForgot)
|
|
|
|
|
|
|
|
throws DeviceManagementException {
|
|
|
|
|
|
|
|
|
|
|
|
String responseMsg = "";
|
|
|
|
String responseMsg = "";
|
|
|
|
String urlString = VirtualFireAlarmConstants.URL_PREFIX + deviceHTTPEndpoint + urlContext;
|
|
|
|
String urlString = VirtualFireAlarmConstants.URL_PREFIX + deviceHTTPEndpoint + urlContext;
|
|
|
@ -156,8 +171,13 @@ public class VirtualFireAlarmServiceUtils {
|
|
|
|
|
|
|
|
|
|
|
|
/* This methods creates and returns a http connection object */
|
|
|
|
/* This methods creates and returns a http connection object */
|
|
|
|
|
|
|
|
|
|
|
|
public static HttpURLConnection getHttpConnection(String urlString) throws
|
|
|
|
/**
|
|
|
|
DeviceManagementException {
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param urlString
|
|
|
|
|
|
|
|
* @return
|
|
|
|
|
|
|
|
* @throws DeviceManagementException
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
public static HttpURLConnection getHttpConnection(String urlString) throws DeviceManagementException {
|
|
|
|
|
|
|
|
|
|
|
|
URL connectionUrl = null;
|
|
|
|
URL connectionUrl = null;
|
|
|
|
HttpURLConnection httpConnection;
|
|
|
|
HttpURLConnection httpConnection;
|
|
|
@ -221,6 +241,13 @@ public class VirtualFireAlarmServiceUtils {
|
|
|
|
return completeResponse.toString();
|
|
|
|
return completeResponse.toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param owner
|
|
|
|
|
|
|
|
* @param deviceId
|
|
|
|
|
|
|
|
* @param temperature
|
|
|
|
|
|
|
|
* @return
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static boolean publishToDAS(String owner, String deviceId, float temperature) {
|
|
|
|
public static boolean publishToDAS(String owner, String deviceId, float temperature) {
|
|
|
|
PrivilegedCarbonContext.startTenantFlow();
|
|
|
|
PrivilegedCarbonContext.startTenantFlow();
|
|
|
|
PrivilegedCarbonContext ctx = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
PrivilegedCarbonContext ctx = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
@ -242,8 +269,14 @@ public class VirtualFireAlarmServiceUtils {
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param message
|
|
|
|
|
|
|
|
* @param encryptionKey
|
|
|
|
|
|
|
|
* @param signatureKey
|
|
|
|
|
|
|
|
* @return
|
|
|
|
|
|
|
|
* @throws VirtualFireAlarmException
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static String prepareSecurePayLoad(String message, Key encryptionKey, PrivateKey signatureKey)
|
|
|
|
public static String prepareSecurePayLoad(String message, Key encryptionKey, PrivateKey signatureKey)
|
|
|
|
throws VirtualFireAlarmException {
|
|
|
|
throws VirtualFireAlarmException {
|
|
|
|
String encryptedMsg = SecurityManager.encryptMessage(message, encryptionKey);
|
|
|
|
String encryptedMsg = SecurityManager.encryptMessage(message, encryptionKey);
|
|
|
@ -256,7 +289,14 @@ public class VirtualFireAlarmServiceUtils {
|
|
|
|
return jsonPayload.toString();
|
|
|
|
return jsonPayload.toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param message
|
|
|
|
|
|
|
|
* @param decryptionKey
|
|
|
|
|
|
|
|
* @param verifySignatureKey
|
|
|
|
|
|
|
|
* @return
|
|
|
|
|
|
|
|
* @throws VirtualFireAlarmException
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static String extractMessageFromPayload(String message, Key decryptionKey, PublicKey verifySignatureKey)
|
|
|
|
public static String extractMessageFromPayload(String message, Key decryptionKey, PublicKey verifySignatureKey)
|
|
|
|
throws VirtualFireAlarmException {
|
|
|
|
throws VirtualFireAlarmException {
|
|
|
|
String actualMessage;
|
|
|
|
String actualMessage;
|
|
|
@ -282,7 +322,12 @@ public class VirtualFireAlarmServiceUtils {
|
|
|
|
return actualMessage;
|
|
|
|
return actualMessage;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param deviceId
|
|
|
|
|
|
|
|
* @return
|
|
|
|
|
|
|
|
* @throws VirtualFireAlarmException
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static PublicKey getDevicePublicKey(String deviceId) throws VirtualFireAlarmException {
|
|
|
|
public static PublicKey getDevicePublicKey(String deviceId) throws VirtualFireAlarmException {
|
|
|
|
PublicKey clientPublicKey;
|
|
|
|
PublicKey clientPublicKey;
|
|
|
|
String alias = "";
|
|
|
|
String alias = "";
|
|
|
|