2016-08-08 16:20:00 +00:00
|
|
|
"use strict";
|
2016-08-09 09:42:21 +00:00
|
|
|
const plugins = require("./smartsocket.plugins");
|
|
|
|
const helpers = require("./smartsocket.helpers");
|
2016-08-15 00:36:17 +00:00
|
|
|
const lik_1 = require("lik");
|
2016-08-09 14:33:56 +00:00
|
|
|
const smartsocket_classes_socketrequest_1 = require("./smartsocket.classes.socketrequest");
|
2016-08-08 16:20:00 +00:00
|
|
|
;
|
2016-08-15 00:36:17 +00:00
|
|
|
;
|
2016-08-09 09:42:21 +00:00
|
|
|
// export classes
|
2016-08-15 00:36:17 +00:00
|
|
|
exports.allSocketConnections = new lik_1.Objectmap();
|
2016-08-09 09:42:21 +00:00
|
|
|
/**
|
|
|
|
* class SocketConnection represents a websocket connection
|
|
|
|
*/
|
2016-08-08 16:20:00 +00:00
|
|
|
class SocketConnection {
|
|
|
|
constructor(optionsArg) {
|
2016-08-14 23:38:28 +00:00
|
|
|
this.authenticated = false;
|
2016-08-08 16:20:00 +00:00
|
|
|
this.alias = optionsArg.alias;
|
|
|
|
this.authenticated = optionsArg.authenticated;
|
|
|
|
this.role = optionsArg.role;
|
2016-08-15 00:36:17 +00:00
|
|
|
this.side = optionsArg.side;
|
2016-09-04 22:34:09 +00:00
|
|
|
this.smartsocketHost = optionsArg.smartsocketHost;
|
2016-08-08 16:20:00 +00:00
|
|
|
this.socket = optionsArg.socket;
|
2016-08-14 01:25:26 +00:00
|
|
|
// standard behaviour that is always true
|
2016-08-15 00:36:17 +00:00
|
|
|
exports.allSocketConnections.add(this);
|
2016-08-14 01:25:26 +00:00
|
|
|
this.socket.on("disconnect", () => {
|
2016-08-15 00:36:17 +00:00
|
|
|
plugins.beautylog.info(`SocketConnection with >alias ${this.alias} on >side ${this.side} disconnected`);
|
|
|
|
exports.allSocketConnections.remove(this);
|
2016-08-14 01:25:26 +00:00
|
|
|
});
|
2016-08-08 16:20:00 +00:00
|
|
|
}
|
2016-08-14 01:25:26 +00:00
|
|
|
;
|
2016-08-12 03:56:40 +00:00
|
|
|
// authenticating --------------------------
|
2016-08-09 09:42:21 +00:00
|
|
|
/**
|
|
|
|
* authenticate the socket
|
|
|
|
*/
|
|
|
|
authenticate() {
|
|
|
|
let done = plugins.q.defer();
|
2016-08-16 02:48:42 +00:00
|
|
|
this.socket.on("dataAuth", (dataArg) => {
|
2016-08-09 09:42:21 +00:00
|
|
|
plugins.beautylog.log("received authentication data. now hashing and comparing...");
|
|
|
|
this.socket.removeListener("dataAuth", () => { });
|
2016-09-04 22:34:09 +00:00
|
|
|
if (helpers.checkPasswordForRole(dataArg, this.smartsocketHost)) {
|
2016-08-09 09:42:21 +00:00
|
|
|
this.alias = dataArg.alias;
|
|
|
|
this.authenticated = true;
|
2016-09-04 22:34:09 +00:00
|
|
|
this.role = helpers.getSocketRoleByName(dataArg.role, this.smartsocketHost);
|
2016-08-09 09:42:21 +00:00
|
|
|
this.socket.emit("authenticated");
|
|
|
|
plugins.beautylog.ok(`socket with >>alias ${this.alias} >>role ${this.role} is authenticated!`);
|
|
|
|
done.resolve(this);
|
|
|
|
}
|
|
|
|
else {
|
2016-08-14 23:38:28 +00:00
|
|
|
this.authenticated = false;
|
2016-08-09 09:42:21 +00:00
|
|
|
this.socket.disconnect();
|
|
|
|
done.reject("not authenticated");
|
|
|
|
}
|
|
|
|
;
|
|
|
|
});
|
|
|
|
this.socket.emit("requestAuth");
|
|
|
|
return done.promise;
|
|
|
|
}
|
|
|
|
;
|
2016-08-12 03:56:40 +00:00
|
|
|
// listening -------------------------------
|
2016-08-09 09:42:21 +00:00
|
|
|
/**
|
|
|
|
* listen to function requests
|
|
|
|
*/
|
|
|
|
listenToFunctionRequests() {
|
|
|
|
let done = plugins.q.defer();
|
|
|
|
if (this.authenticated) {
|
|
|
|
this.socket.on("function", (dataArg) => {
|
2016-08-09 21:37:25 +00:00
|
|
|
// check if requested function is available to the socket's scope
|
2016-08-14 23:38:28 +00:00
|
|
|
plugins.beautylog.log("function request received");
|
2016-08-09 09:42:21 +00:00
|
|
|
let referencedFunction = this.role.allowedFunctions.find((socketFunctionArg) => {
|
2016-08-09 21:37:25 +00:00
|
|
|
return socketFunctionArg.name === dataArg.funcCallData.funcName;
|
2016-08-09 09:42:21 +00:00
|
|
|
});
|
|
|
|
if (referencedFunction !== undefined) {
|
2016-08-14 23:38:28 +00:00
|
|
|
plugins.beautylog.ok("function in access scope");
|
2016-08-09 14:33:56 +00:00
|
|
|
let localSocketRequest = new smartsocket_classes_socketrequest_1.SocketRequest({
|
|
|
|
side: "responding",
|
2016-08-09 21:37:25 +00:00
|
|
|
originSocketConnection: this,
|
|
|
|
shortId: dataArg.shortId,
|
|
|
|
funcCallData: dataArg.funcCallData
|
2016-08-09 14:33:56 +00:00
|
|
|
});
|
2016-08-12 03:56:40 +00:00
|
|
|
localSocketRequest.createResponse(); // takes care of creating response and sending it back
|
2016-08-09 09:42:21 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
plugins.beautylog.warn("function not existent or out of access scope");
|
|
|
|
}
|
|
|
|
;
|
|
|
|
});
|
2016-08-09 14:33:56 +00:00
|
|
|
this.socket.on("functionResponse", (dataArg) => {
|
2016-08-14 23:38:28 +00:00
|
|
|
plugins.beautylog.info(`received response for request with id ${dataArg.shortId}`);
|
2016-08-12 03:56:40 +00:00
|
|
|
let targetSocketRequest = helpers.getSocketRequestById(dataArg.shortId);
|
|
|
|
targetSocketRequest.handleResponse(dataArg);
|
2016-08-09 14:33:56 +00:00
|
|
|
});
|
2016-08-14 23:38:28 +00:00
|
|
|
plugins.beautylog.log(`now listening to function requests for ${this.alias}`);
|
|
|
|
done.resolve(this);
|
2016-08-09 09:42:21 +00:00
|
|
|
}
|
|
|
|
else {
|
2016-08-14 23:38:28 +00:00
|
|
|
let errMessage;
|
|
|
|
plugins.beautylog.error(errMessage);
|
|
|
|
done.reject(errMessage);
|
2016-08-09 09:42:21 +00:00
|
|
|
}
|
|
|
|
;
|
|
|
|
return done.promise;
|
|
|
|
}
|
2016-08-12 03:56:40 +00:00
|
|
|
;
|
2016-08-08 16:20:00 +00:00
|
|
|
}
|
|
|
|
exports.SocketConnection = SocketConnection;
|
|
|
|
;
|
2016-09-04 22:34:09 +00:00
|
|
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRjb25uZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRjb25uZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxNQUFZLE9BQU8sV0FBTSx1QkFBdUIsQ0FBQyxDQUFBO0FBQ2pELE1BQVksT0FBTyxXQUFNLHVCQUF1QixDQUFDLENBQUE7QUFFakQsc0JBQXdCLEtBQUssQ0FBQyxDQUFBO0FBSzlCLG9EQUEyRSxxQ0FBcUMsQ0FBQyxDQUFBO0FBb0JoSCxDQUFDO0FBU0QsQ0FBQztBQUVGLGlCQUFpQjtBQUNOLDRCQUFvQixHQUFHLElBQUksZUFBUyxFQUFvQixDQUFDO0FBRXBFOztHQUVHO0FBQ0g7SUFPSSxZQUFZLFVBQStDO1FBSjNELGtCQUFhLEdBQVksS0FBSyxDQUFDO1FBSzNCLElBQUksQ0FBQyxLQUFLLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQztRQUM5QixJQUFJLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxhQUFhLENBQUM7UUFDOUMsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQzVCLElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQztRQUM1QixJQUFJLENBQUMsZUFBZSxHQUFHLFVBQVUsQ0FBQyxlQUFlLENBQUM7UUFDbEQsSUFBSSxDQUFDLE1BQU0sR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDO1FBRWhDLHlDQUF5QztRQUN6Qyw0QkFBb0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsWUFBWSxFQUFFO1lBQ3pCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGdDQUFnQyxJQUFJLENBQUMsS0FBSyxhQUFhLElBQUksQ0FBQyxJQUFJLGVBQWUsQ0FBQyxDQUFDO1lBQ3hHLDRCQUFvQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN0QyxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7O0lBRUQsNENBQTRDO0lBRTVDOztPQUVHO0lBQ0gsWUFBWTtRQUNSLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsVUFBVSxFQUFFLENBQUMsT0FBNkM7WUFDckUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsNERBQTRELENBQUMsQ0FBQztZQUNwRixJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxVQUFVLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQztZQUNsRCxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsb0JBQW9CLENBQUMsT0FBTyxFQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzdELElBQUksQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQTtnQkFDMUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7Z0JBQzFCLElBQUksQ0FBQyxJQUFJLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO2dCQUMzRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztnQkFDbEMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsdUJBQXVCLElBQUksQ0FBQyxLQUFLLFdBQVcsSUFBSSxDQUFDLElBQUksb0JBQW9CLENBQUMsQ0FBQztnQkFDaEcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN2QixDQUFDO1lBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ0osSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7Z0JBQzNCLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQ3pCLElBQUksQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztZQUNyQyxDQUFDO1lBQUEsQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDaEMsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQzs7SUFFRCw0Q0FBNEM7SUFFNUM7O09BRUc7SUFDSCx3QkFBd0I7UUFDcEIsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUM3QixFQUFFLENBQUEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUEsQ0FBQztZQUNuQixJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxPQUFnQztnQkFDeEQsaUVBQWlFO2dCQUNqRSxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO2dCQUNuRCxJQUFJLGtCQUFrQixHQUFrQixJQUFJLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDLGlCQUFpQjtvQkFDdEYsTUFBTSxDQUFDLGlCQUFpQixDQUFDLElBQUksS0FBSyxPQUFPLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQztnQkFDcEUsQ0FBQyxDQUFDLENBQUM7Z0JBQ0gsRUFBRSxDQUFBLENBQUMsa0JBQWtCLEtBQUssU0FBUyxDQUFDLENBQUEsQ0FBQztvQkFDakMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFHLENBQUMsMEJBQTBCLENBQUMsQ0FBQztvQkFDbEQsSUFBSSxrQkFBa0IsR0FBRyxJQUFJLGlEQUFhLENBQUM7d0JBQ3ZDLElBQUksRUFBQyxZQUFZO3dCQUNqQixzQkFBc0IsRUFBQyxJQUFJO3dCQUMzQixPQUFPLEVBQUMsT0FBTyxDQUFDLE9BQU87d0JBQ3ZCLFlBQVksRUFBQyxPQUFPLENBQUMsWUFBWTtxQkFDcEMsQ0FBQyxDQUFDO29CQUNILGtCQUFrQixDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUMsdURBQXVEO2dCQUNoRyxDQUFDO2dCQUFDLElBQUksQ0FBQyxDQUFDO29CQUNKLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLDhDQUE4QyxDQUFDLENBQUM7Z0JBQzNFLENBQUM7Z0JBQUEsQ0FBQztZQUNOLENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxPQUFnQztnQkFDaEUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMseUNBQXlDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2dCQUNuRixJQUFJLG1CQUFtQixHQUFHLE9BQU8sQ
|