|
|
@ -18,27 +18,31 @@
|
|
|
|
|
|
|
|
|
|
|
|
function onRequest(context) {
|
|
|
|
function onRequest(context) {
|
|
|
|
var log = new Log("stats.js");
|
|
|
|
var log = new Log("stats.js");
|
|
|
|
|
|
|
|
var carbonServer = require("carbon").server;
|
|
|
|
var device = context.unit.params.device;
|
|
|
|
var device = context.unit.params.device;
|
|
|
|
var devicemgtProps = require("/app/modules/conf-reader/main.js")["conf"];
|
|
|
|
var devicemgtProps = require("/app/modules/conf-reader/main.js")["conf"];
|
|
|
|
var constants = require("/app/modules/constants.js");
|
|
|
|
var constants = require("/app/modules/constants.js");
|
|
|
|
|
|
|
|
|
|
|
|
var websocketEndpoint = devicemgtProps["wssURL"].replace("https", "wss");
|
|
|
|
var websocketEndpoint = devicemgtProps["wssURL"].replace("https", "wss");
|
|
|
|
var jwtService = carbon.server.osgiService('org.wso2.carbon.identity.jwt.client.extension.service.JWTClientManagerService');
|
|
|
|
var jwtService = carbonServer.osgiService(
|
|
|
|
|
|
|
|
'org.wso2.carbon.identity.jwt.client.extension.service.JWTClientManagerService');
|
|
|
|
var jwtClient = jwtService.getJWTClient();
|
|
|
|
var jwtClient = jwtService.getJWTClient();
|
|
|
|
var encodedClientKeys = session.get(constants.ENCODED_CLIENT_KEYS_IDENTIFIER);
|
|
|
|
var encodedClientKeys = session.get(constants["ENCODED_TENANT_BASED_CLIENT_APP_CREDENTIALS"]);
|
|
|
|
if (encodedClientKeys) {
|
|
|
|
if (encodedClientKeys) {
|
|
|
|
var tokenUtil = require("/app/modules/util.js").util;
|
|
|
|
var tokenUtil = require("/app/modules/oauth/token-handler-utils.js")["utils"];
|
|
|
|
var resp = tokenUtil.decode(encodedClientKeys).split(",");
|
|
|
|
var resp = tokenUtil.decode(encodedClientKeys).split(":");
|
|
|
|
var user = session.get(constants.USER_SESSION_KEY);
|
|
|
|
log.error(resp);
|
|
|
|
var deviceParam = "{\"scope\":\"stats\",\"deviceIdentifiers\":[{\"id\":\""+device.deviceIdentifier+" \", \"type\":\""+device.type+"\"}]}";
|
|
|
|
var deviceParam = "{\"scope\":\"stats\",\"deviceIdentifiers\":[{\"id\":\"" + device.deviceIdentifier
|
|
|
|
|
|
|
|
+ " \", \"type\":\"" + device.type + "\"}]}";
|
|
|
|
var encodedScope = tokenUtil.encode(deviceParam);
|
|
|
|
var encodedScope = tokenUtil.encode(deviceParam);
|
|
|
|
var tokenPair = jwtClient.getAccessToken(resp[0], resp[1], user.username, null,
|
|
|
|
var tokenPair = jwtClient.getAccessToken(resp[0], resp[1], context.user.username,
|
|
|
|
"{\"device\": \"" +encodedScope+"\"}");
|
|
|
|
"{\"device\": \"" + encodedScope + "\"}");
|
|
|
|
var token = "";
|
|
|
|
var token = "";
|
|
|
|
if (tokenPair) {
|
|
|
|
if (tokenPair) {
|
|
|
|
token = tokenPair.accessToken;
|
|
|
|
token = tokenPair.accessToken;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
websocketEndpoint = websocketEndpoint + "/secured-outputui/org.wso2.iot.devices.temperature/1.0.0?" +
|
|
|
|
websocketEndpoint = websocketEndpoint + "/secured-outputui/org.wso2.iot.devices.temperature/1.0.0?" +
|
|
|
|
"token=" + token + "&deviceId=" + device.deviceIdentifier + "&deviceType=" + device.type;
|
|
|
|
"token=" + token + "&deviceId=" + device.deviceIdentifier + "&deviceType=" + device.type;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return {"device": device, "websocketEndpoint" : websocketEndpoint};
|
|
|
|
return {"device": device, "websocketEndpoint": websocketEndpoint};
|
|
|
|
}
|
|
|
|
}
|