Compare commits
30 Commits
Author | SHA1 | Date | |
---|---|---|---|
fb99848df1 | |||
1bd39d0755 | |||
d24c5f628c | |||
33fbabdd72 | |||
9d26fff986 | |||
41151e5436 | |||
109c5197f3 | |||
c3d47c1f50 | |||
1b45fb45e9 | |||
c22adc9b57 | |||
35e87306dd | |||
1b20aa5992 | |||
a63f14da47 | |||
86cf94c5dc | |||
0d39d6f237 | |||
1856ad5cfc | |||
b5dab810e8 | |||
f145b85b1c | |||
a8c647c5c7 | |||
22472e0adf | |||
333ddb4d9c | |||
126f020bf8 | |||
7677b1bb48 | |||
114379c5b3 | |||
79ae7d2039 | |||
d2cb6a3045 | |||
963619b2ed | |||
976abaaed7 | |||
ef322c32ac | |||
475911a968 |
20
.gitignore
vendored
20
.gitignore
vendored
@ -1,4 +1,22 @@
|
|||||||
node_modules/
|
.nogit/
|
||||||
|
|
||||||
|
# artifacts
|
||||||
coverage/
|
coverage/
|
||||||
|
public/
|
||||||
pages/
|
pages/
|
||||||
|
|
||||||
|
# installs
|
||||||
|
node_modules/
|
||||||
|
|
||||||
|
# caches
|
||||||
|
.yarn/
|
||||||
|
.cache/
|
||||||
|
.rpt2_cache
|
||||||
|
|
||||||
|
# builds
|
||||||
|
dist/
|
||||||
|
dist_web/
|
||||||
|
dist_serve/
|
||||||
|
dist_ts_web/
|
||||||
|
|
||||||
|
# custom
|
@ -1,5 +1,5 @@
|
|||||||
# gitzone standard
|
# gitzone ci_default
|
||||||
image: hosttoday/ht-docker-node:npmci
|
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
|
||||||
cache:
|
cache:
|
||||||
paths:
|
paths:
|
||||||
@ -34,31 +34,6 @@ snyk:
|
|||||||
- docker
|
- docker
|
||||||
- notpriv
|
- notpriv
|
||||||
|
|
||||||
sast:
|
|
||||||
stage: security
|
|
||||||
image: registry.gitlab.com/hosttoday/ht-docker-dbase:npmci
|
|
||||||
variables:
|
|
||||||
DOCKER_DRIVER: overlay2
|
|
||||||
allow_failure: true
|
|
||||||
services:
|
|
||||||
- docker:stable-dind
|
|
||||||
script:
|
|
||||||
- npmci npm prepare
|
|
||||||
- npmci npm install
|
|
||||||
- npmci command npm run build
|
|
||||||
- export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
|
|
||||||
- docker run
|
|
||||||
--env SAST_CONFIDENCE_LEVEL="${SAST_CONFIDENCE_LEVEL:-3}"
|
|
||||||
--volume "$PWD:/code"
|
|
||||||
--volume /var/run/docker.sock:/var/run/docker.sock
|
|
||||||
"registry.gitlab.com/gitlab-org/security-products/sast:$SP_VERSION" /app/bin/run /code
|
|
||||||
artifacts:
|
|
||||||
reports:
|
|
||||||
sast: gl-sast-report.json
|
|
||||||
tags:
|
|
||||||
- docker
|
|
||||||
- priv
|
|
||||||
|
|
||||||
# ====================
|
# ====================
|
||||||
# test stage
|
# test stage
|
||||||
# ====================
|
# ====================
|
||||||
@ -75,13 +50,13 @@ testLTS:
|
|||||||
- docker
|
- docker
|
||||||
- notpriv
|
- notpriv
|
||||||
|
|
||||||
testSTABLE:
|
testBuild:
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- npmci npm prepare
|
- npmci npm prepare
|
||||||
- npmci node install stable
|
- npmci node install lts
|
||||||
- npmci npm install
|
- npmci npm install
|
||||||
- npmci npm test
|
- npmci command npm run build
|
||||||
coverage: /\d+.?\d+?\%\s*coverage/
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
@ -90,7 +65,7 @@ testSTABLE:
|
|||||||
release:
|
release:
|
||||||
stage: release
|
stage: release
|
||||||
script:
|
script:
|
||||||
- npmci node install stable
|
- npmci node install lts
|
||||||
- npmci npm publish
|
- npmci npm publish
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
@ -103,19 +78,11 @@ release:
|
|||||||
# ====================
|
# ====================
|
||||||
codequality:
|
codequality:
|
||||||
stage: metadata
|
stage: metadata
|
||||||
image: docker:stable
|
|
||||||
allow_failure: true
|
allow_failure: true
|
||||||
services:
|
|
||||||
- docker:stable-dind
|
|
||||||
script:
|
script:
|
||||||
- export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
|
- npmci command npm install -g tslint typescript
|
||||||
- docker run
|
- npmci npm install
|
||||||
--env SOURCE_CODE="$PWD"
|
- npmci command "tslint -c tslint.json ./ts/**/*.ts"
|
||||||
--volume "$PWD":/code
|
|
||||||
--volume /var/run/docker.sock:/var/run/docker.sock
|
|
||||||
"registry.gitlab.com/gitlab-org/security-products/codequality:$SP_VERSION" /code
|
|
||||||
artifacts:
|
|
||||||
paths: [codeclimate.json]
|
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
- priv
|
- priv
|
||||||
@ -131,13 +98,15 @@ trigger:
|
|||||||
- notpriv
|
- notpriv
|
||||||
|
|
||||||
pages:
|
pages:
|
||||||
image: hosttoday/ht-docker-node:npmci
|
image: hosttoday/ht-docker-dbase:npmci
|
||||||
|
services:
|
||||||
|
- docker:18-dind
|
||||||
stage: metadata
|
stage: metadata
|
||||||
script:
|
script:
|
||||||
- npmci command npm install -g typedoc typescript
|
- npmci command npm install -g @gitzone/tsdoc
|
||||||
- npmci npm prepare
|
- npmci npm prepare
|
||||||
- npmci npm install
|
- npmci npm install
|
||||||
- npmci command typedoc --module "commonjs" --target "ES2016" --out public/ ts/
|
- npmci command tsdoc
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
- notpriv
|
- notpriv
|
||||||
|
13
.snyk
13
.snyk
@ -1,4 +1,13 @@
|
|||||||
# Snyk (https://snyk.io) policy file, patches or ignores known vulnerabilities.
|
# Snyk (https://snyk.io) policy file, patches or ignores known vulnerabilities.
|
||||||
version: v1.13.3
|
version: v1.13.5
|
||||||
ignore: {}
|
# ignores vulnerabilities until expiry date; change duration by modifying expiry date
|
||||||
|
ignore:
|
||||||
|
SNYK-JS-JSYAML-173999:
|
||||||
|
- '@pushrocks/smartexpress > @pushrocks/smartfile > js-yaml':
|
||||||
|
reason: None given
|
||||||
|
expires: '2019-05-24T15:16:11.291Z'
|
||||||
|
SNYK-JS-JSYAML-174129:
|
||||||
|
- '@pushrocks/smartexpress > @pushrocks/smartfile > js-yaml':
|
||||||
|
reason: None given
|
||||||
|
expires: '2019-05-24T15:16:11.291Z'
|
||||||
patch: {}
|
patch: {}
|
||||||
|
29
.vscode/launch.json
vendored
Normal file
29
.vscode/launch.json
vendored
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
{
|
||||||
|
"version": "0.2.0",
|
||||||
|
"configurations": [
|
||||||
|
{
|
||||||
|
"name": "current file",
|
||||||
|
"type": "node",
|
||||||
|
"request": "launch",
|
||||||
|
"args": [
|
||||||
|
"${relativeFile}"
|
||||||
|
],
|
||||||
|
"runtimeArgs": ["-r", "@gitzone/tsrun"],
|
||||||
|
"cwd": "${workspaceRoot}",
|
||||||
|
"protocol": "inspector",
|
||||||
|
"internalConsoleOptions": "openOnSessionStart"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "test.ts",
|
||||||
|
"type": "node",
|
||||||
|
"request": "launch",
|
||||||
|
"args": [
|
||||||
|
"test/test.ts"
|
||||||
|
],
|
||||||
|
"runtimeArgs": ["-r", "@gitzone/tsrun"],
|
||||||
|
"cwd": "${workspaceRoot}",
|
||||||
|
"protocol": "inspector",
|
||||||
|
"internalConsoleOptions": "openOnSessionStart"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
@ -14,7 +14,7 @@ easy and secure websocket communication
|
|||||||
[](https://snyk.io/test/npm/@pushrocks/smartsocket)
|
[](https://snyk.io/test/npm/@pushrocks/smartsocket)
|
||||||
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
||||||
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
||||||
[](http://standardjs.com/)
|
[](https://prettier.io/)
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
@ -106,6 +106,6 @@ mySmartsocketClient.serverCall('function', functionCallData).then(functionRespon
|
|||||||
For further information read the linked docs at the top of this readme.
|
For further information read the linked docs at the top of this readme.
|
||||||
|
|
||||||
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
||||||
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy.html)
|
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
|
||||||
|
|
||||||
[](https://maintainedby.lossless.com)
|
[](https://maintainedby.lossless.com)
|
||||||
|
5
dist/index.d.ts
vendored
5
dist/index.d.ts
vendored
@ -1,5 +0,0 @@
|
|||||||
export * from './smartsocket.classes.smartsocket';
|
|
||||||
export * from './smartsocket.classes.smartsocketclient';
|
|
||||||
export * from './smartsocket.classes.socketfunction';
|
|
||||||
export * from './smartsocket.classes.socketrole';
|
|
||||||
export * from './smartsocket.classes.socketconnection';
|
|
13
dist/index.js
vendored
13
dist/index.js
vendored
@ -1,13 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
function __export(m) {
|
|
||||||
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
|
|
||||||
}
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
// export main classes
|
|
||||||
__export(require("./smartsocket.classes.smartsocket"));
|
|
||||||
__export(require("./smartsocket.classes.smartsocketclient"));
|
|
||||||
// export further classes and objects
|
|
||||||
__export(require("./smartsocket.classes.socketfunction"));
|
|
||||||
__export(require("./smartsocket.classes.socketrole"));
|
|
||||||
__export(require("./smartsocket.classes.socketconnection"));
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUVBLHNCQUFzQjtBQUN0Qix1REFBa0Q7QUFDbEQsNkRBQXdEO0FBRXhELHFDQUFxQztBQUNyQywwREFBcUQ7QUFDckQsc0RBQWlEO0FBQ2pELDREQUF1RCJ9
|
|
37
dist/smartsocket.classes.smartsocket.d.ts
vendored
37
dist/smartsocket.classes.smartsocket.d.ts
vendored
@ -1,37 +0,0 @@
|
|||||||
/// <reference types="socket.io" />
|
|
||||||
import * as plugins from './smartsocket.plugins';
|
|
||||||
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
|
||||||
import { SocketRole } from './smartsocket.classes.socketrole';
|
|
||||||
import * as SocketIO from 'socket.io';
|
|
||||||
export interface ISmartsocketConstructorOptions {
|
|
||||||
port: number;
|
|
||||||
}
|
|
||||||
export declare class Smartsocket {
|
|
||||||
options: ISmartsocketConstructorOptions;
|
|
||||||
io: SocketIO.Server;
|
|
||||||
openSockets: plugins.lik.Objectmap<SocketConnection>;
|
|
||||||
socketRoles: plugins.lik.Objectmap<SocketRole>;
|
|
||||||
private socketServer;
|
|
||||||
constructor(optionsArg: ISmartsocketConstructorOptions);
|
|
||||||
setExternalServer: (serverType: "express" | "http", serverArg: any) => Promise<void>;
|
|
||||||
/**
|
|
||||||
* starts smartsocket
|
|
||||||
*/
|
|
||||||
start(): Promise<void>;
|
|
||||||
/**
|
|
||||||
* stops smartsocket
|
|
||||||
*/
|
|
||||||
stop(): Promise<void>;
|
|
||||||
/**
|
|
||||||
* allows call to specific client.
|
|
||||||
*/
|
|
||||||
clientCall(functionNameArg: string, dataArg: any, targetSocketConnectionArg: SocketConnection): Promise<{}>;
|
|
||||||
/**
|
|
||||||
* adds socketRoles
|
|
||||||
*/
|
|
||||||
addSocketRoles(socketRolesArray: SocketRole[]): void;
|
|
||||||
/**
|
|
||||||
* the standard handler for new socket connections
|
|
||||||
*/
|
|
||||||
private _handleSocketConnection(socketArg);
|
|
||||||
}
|
|
111
dist/smartsocket.classes.smartsocket.js
vendored
111
dist/smartsocket.classes.smartsocket.js
vendored
@ -1,111 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
|
||||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
||||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
||||||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
||||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
||||||
});
|
|
||||||
};
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./smartsocket.plugins");
|
|
||||||
// classes
|
|
||||||
const lik_1 = require("lik");
|
|
||||||
const smartsocket_classes_socketconnection_1 = require("./smartsocket.classes.socketconnection");
|
|
||||||
const smartsocket_classes_socketrequest_1 = require("./smartsocket.classes.socketrequest");
|
|
||||||
const smartsocket_classes_socketserver_1 = require("./smartsocket.classes.socketserver");
|
|
||||||
class Smartsocket {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.openSockets = new lik_1.Objectmap();
|
|
||||||
this.socketRoles = new lik_1.Objectmap();
|
|
||||||
this.socketServer = new smartsocket_classes_socketserver_1.SocketServer(this);
|
|
||||||
// tslint:disable-next-line:member-ordering
|
|
||||||
this.setExternalServer = this.socketServer.setExternalServer;
|
|
||||||
this.options = optionsArg;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* starts smartsocket
|
|
||||||
*/
|
|
||||||
start() {
|
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
|
||||||
this.io = plugins.socketIo(this.socketServer.getServerForSocketIo());
|
|
||||||
yield this.socketServer.start();
|
|
||||||
this.io.on('connection', socketArg => {
|
|
||||||
this._handleSocketConnection(socketArg);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* stops smartsocket
|
|
||||||
*/
|
|
||||||
stop() {
|
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
|
||||||
yield plugins.smartdelay.delayFor(1000);
|
|
||||||
this.openSockets.forEach((socketObjectArg) => {
|
|
||||||
plugins.beautylog.log(`disconnect socket with >>alias ${socketObjectArg.alias}`);
|
|
||||||
socketObjectArg.socket.disconnect();
|
|
||||||
});
|
|
||||||
this.openSockets.wipe();
|
|
||||||
this.io.close();
|
|
||||||
// stop the corresponging server
|
|
||||||
this.socketServer.stop();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
// communication
|
|
||||||
/**
|
|
||||||
* allows call to specific client.
|
|
||||||
*/
|
|
||||||
clientCall(functionNameArg, dataArg, targetSocketConnectionArg) {
|
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
|
||||||
const done = plugins.smartq.defer();
|
|
||||||
const socketRequest = new smartsocket_classes_socketrequest_1.SocketRequest({
|
|
||||||
funcCallData: {
|
|
||||||
funcDataArg: dataArg,
|
|
||||||
funcName: functionNameArg
|
|
||||||
},
|
|
||||||
originSocketConnection: targetSocketConnectionArg,
|
|
||||||
shortId: plugins.shortid.generate(),
|
|
||||||
side: 'requesting'
|
|
||||||
});
|
|
||||||
socketRequest.dispatch().then((dataArg) => {
|
|
||||||
done.resolve(dataArg.funcDataArg);
|
|
||||||
});
|
|
||||||
const result = yield done.promise;
|
|
||||||
return result;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* adds socketRoles
|
|
||||||
*/
|
|
||||||
addSocketRoles(socketRolesArray) {
|
|
||||||
for (const socketRole of socketRolesArray) {
|
|
||||||
this.socketRoles.add(socketRole);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* the standard handler for new socket connections
|
|
||||||
*/
|
|
||||||
_handleSocketConnection(socketArg) {
|
|
||||||
const socketConnection = new smartsocket_classes_socketconnection_1.SocketConnection({
|
|
||||||
alias: undefined,
|
|
||||||
authenticated: false,
|
|
||||||
role: undefined,
|
|
||||||
side: 'server',
|
|
||||||
smartsocketHost: this,
|
|
||||||
socket: socketArg
|
|
||||||
});
|
|
||||||
plugins.beautylog.log('Socket connected. Trying to authenticate...');
|
|
||||||
this.openSockets.add(socketConnection);
|
|
||||||
socketConnection
|
|
||||||
.authenticate()
|
|
||||||
.then(() => {
|
|
||||||
return socketConnection.listenToFunctionRequests();
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
console.log(err);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.Smartsocket = Smartsocket;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zbWFydHNvY2tldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c29ja2V0LmNsYXNzZXMuc21hcnRzb2NrZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLGlEQUFpRDtBQUdqRCxVQUFVO0FBQ1YsNkJBQWdDO0FBQ2hDLGlHQUEwRTtBQUUxRSwyRkFBb0U7QUFFcEUseUZBQWtFO0FBU2xFO0lBUUUsWUFBWSxVQUEwQztRQUwvQyxnQkFBVyxHQUFHLElBQUksZUFBUyxFQUFvQixDQUFDO1FBQ2hELGdCQUFXLEdBQUcsSUFBSSxlQUFTLEVBQWMsQ0FBQztRQUV6QyxpQkFBWSxHQUFHLElBQUksK0NBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQU05QywyQ0FBMkM7UUFDcEMsc0JBQWlCLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxpQkFBaUIsQ0FBQztRQUo3RCxJQUFJLENBQUMsT0FBTyxHQUFHLFVBQVUsQ0FBQztJQUM1QixDQUFDO0lBS0Q7O09BRUc7SUFDVSxLQUFLOztZQUNoQixJQUFJLENBQUMsRUFBRSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLENBQUM7WUFDckUsTUFBTSxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2hDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLFlBQVksRUFBRSxTQUFTLENBQUMsRUFBRTtnQkFDbkMsSUFBSSxDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQzFDLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztLQUFBO0lBRUQ7O09BRUc7SUFDVSxJQUFJOztZQUNmLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDeEMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxlQUFpQyxFQUFFLEVBQUU7Z0JBQzdELE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGtDQUFrQyxlQUFlLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztnQkFDakYsZUFBZSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUN0QyxDQUFDLENBQUMsQ0FBQztZQUNILElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUVoQixnQ0FBZ0M7WUFDaEMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUMzQixDQUFDO0tBQUE7SUFFRCxnQkFBZ0I7SUFFaEI7O09BRUc7SUFDVSxVQUFVLENBQ3JCLGVBQXVCLEVBQ3ZCLE9BQVksRUFDWix5QkFBMkM7O1lBRTNDLE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDcEMsTUFBTSxhQUFhLEdBQUcsSUFBSSxpREFBYSxDQUFDO2dCQUN0QyxZQUFZLEVBQUU7b0JBQ1osV0FBVyxFQUFFLE9BQU87b0JBQ3BCLFFBQVEsRUFBRSxlQUFlO2lCQUMxQjtnQkFDRCxzQkFBc0IsRUFBRSx5QkFBeUI7Z0JBQ2pELE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRTtnQkFDbkMsSUFBSSxFQUFFLFlBQVk7YUFDbkIsQ0FBQyxDQUFDO1lBQ0gsYUFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLE9BQTRCLEVBQUUsRUFBRTtnQkFDN0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDcEMsQ0FBQyxDQUFDLENBQUM7WUFDSCxNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxPQUFPLENBQUM7WUFDbEMsTUFBTSxDQUFDLE1BQU0sQ0FBQztRQUNoQixDQUFDO0tBQUE7SUFFRDs7T0FFRztJQUNJLGNBQWMsQ0FBQyxnQkFBOEI7UUFDbEQsR0FBRyxDQUFDLENBQUMsTUFBTSxVQUFVLElBQUksZ0JBQWdCLENBQUMsQ0FBQyxDQUFDO1lBQzFDLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ25DLENBQUM7UUFDRCxNQUFNLENBQUM7SUFDVCxDQUFDO0lBRUQ7O09BRUc7SUFDSyx1QkFBdUIsQ0FBQyxTQUFTO1FBQ3ZDLE1BQU0sZ0JBQWdCLEdBQXFCLElBQUksdURBQWdCLENBQUM7WUFDOUQsS0FBSyxFQUFFLFNBQVM7WUFDaEIsYUFBYSxFQUFFLEtBQUs7WUFDcEIsSUFBSSxFQUFFLFNBQVM7WUFDZixJQUFJLEVBQUUsUUFBUTtZQUNkLGVBQWUsRUFBRSxJQUFJO1lBQ3JCLE1BQU0sRUFBRSxTQUFTO1NBQ2xCLENBQUMsQ0FBQztRQUNILE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLDZDQUE2QyxDQUFDLENBQUM7UUFDckUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUN2QyxnQkFBZ0I7YUFDYixZQUFZLEVBQUU7YUFDZCxJQUFJLENBQUMsR0FBRyxFQUFFO1lBQ1QsTUFBTSxDQUFDLGdCQUFnQixDQUFDLHdCQUF3QixFQUFFLENBQUM7UUFDckQsQ0FBQyxDQUFDO2FBQ0QsS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ1gsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNuQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDRjtBQXRHRCxrQ0FzR0MifQ==
|
|
26
dist/smartsocket.classes.smartsocketclient.d.ts
vendored
26
dist/smartsocket.classes.smartsocketclient.d.ts
vendored
@ -1,26 +0,0 @@
|
|||||||
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
|
||||||
/**
|
|
||||||
* interface for class SmartsocketClient
|
|
||||||
*/
|
|
||||||
export interface ISmartsocketClientOptions {
|
|
||||||
port: number;
|
|
||||||
url: string;
|
|
||||||
alias: string;
|
|
||||||
role: string;
|
|
||||||
password: string;
|
|
||||||
}
|
|
||||||
export declare class SmartsocketClient {
|
|
||||||
alias: string;
|
|
||||||
role: string;
|
|
||||||
socketConnection: SocketConnection;
|
|
||||||
serverUrl: string;
|
|
||||||
serverPort: number;
|
|
||||||
serverPassword: string;
|
|
||||||
constructor(optionsArg: ISmartsocketClientOptions);
|
|
||||||
/**
|
|
||||||
* connect the client to the server
|
|
||||||
*/
|
|
||||||
connect(): Promise<{}>;
|
|
||||||
disconnect(): Promise<{}>;
|
|
||||||
serverCall(functionNameArg: string, dataArg: any): Promise<{}>;
|
|
||||||
}
|
|
71
dist/smartsocket.classes.smartsocketclient.js
vendored
71
dist/smartsocket.classes.smartsocketclient.js
vendored
@ -1,71 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./smartsocket.plugins");
|
|
||||||
const smartsocket_classes_socketconnection_1 = require("./smartsocket.classes.socketconnection");
|
|
||||||
const smartsocket_classes_socketrequest_1 = require("./smartsocket.classes.socketrequest");
|
|
||||||
class SmartsocketClient {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.alias = optionsArg.alias;
|
|
||||||
this.role = optionsArg.role;
|
|
||||||
this.serverUrl = optionsArg.url;
|
|
||||||
this.serverPort = optionsArg.port;
|
|
||||||
this.serverPassword = optionsArg.password;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* connect the client to the server
|
|
||||||
*/
|
|
||||||
connect() {
|
|
||||||
let done = plugins.smartq.defer();
|
|
||||||
plugins.beautylog.log('trying to connect...');
|
|
||||||
let socketUrl = `${this.serverUrl}:${this.serverPort}`;
|
|
||||||
this.socketConnection = new smartsocket_classes_socketconnection_1.SocketConnection({
|
|
||||||
alias: this.alias,
|
|
||||||
authenticated: false,
|
|
||||||
role: undefined,
|
|
||||||
side: 'client',
|
|
||||||
smartsocketHost: null,
|
|
||||||
socket: plugins.socketIoClient(socketUrl, { multiplex: false })
|
|
||||||
});
|
|
||||||
this.socketConnection.socket.on('requestAuth', () => {
|
|
||||||
console.log('server requested authentication');
|
|
||||||
this.socketConnection.socket.emit('dataAuth', {
|
|
||||||
role: this.role,
|
|
||||||
password: this.serverPassword,
|
|
||||||
alias: this.alias
|
|
||||||
});
|
|
||||||
this.socketConnection.socket.on('authenticated', () => {
|
|
||||||
console.log('client is authenticated');
|
|
||||||
this.socketConnection.authenticated = true;
|
|
||||||
this.socketConnection.listenToFunctionRequests();
|
|
||||||
done.resolve();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
disconnect() {
|
|
||||||
let done = plugins.smartq.defer();
|
|
||||||
this.socketConnection.socket.disconnect();
|
|
||||||
this.socketConnection = undefined;
|
|
||||||
plugins.beautylog.ok('disconnected!');
|
|
||||||
done.resolve();
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
serverCall(functionNameArg, dataArg) {
|
|
||||||
let done = plugins.smartq.defer();
|
|
||||||
let socketRequest = new smartsocket_classes_socketrequest_1.SocketRequest({
|
|
||||||
side: 'requesting',
|
|
||||||
originSocketConnection: this.socketConnection,
|
|
||||||
shortId: plugins.shortid.generate(),
|
|
||||||
funcCallData: {
|
|
||||||
funcName: functionNameArg,
|
|
||||||
funcDataArg: dataArg
|
|
||||||
}
|
|
||||||
});
|
|
||||||
socketRequest.dispatch().then((dataArg) => {
|
|
||||||
done.resolve(dataArg.funcDataArg);
|
|
||||||
});
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.SmartsocketClient = SmartsocketClient;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zbWFydHNvY2tldGNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c29ja2V0LmNsYXNzZXMuc21hcnRzb2NrZXRjbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxpREFBaUQ7QUFFakQsaUdBQTBFO0FBRTFFLDJGQUE4RjtBQWE5RjtJQU9FLFlBQVksVUFBcUM7UUFDL0MsSUFBSSxDQUFDLEtBQUssR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDO1FBQzlCLElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQztRQUM1QixJQUFJLENBQUMsU0FBUyxHQUFHLFVBQVUsQ0FBQyxHQUFHLENBQUM7UUFDaEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQ2xDLElBQUksQ0FBQyxjQUFjLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQztJQUM1QyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxPQUFPO1FBQ0wsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNsQyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO1FBQzlDLElBQUksU0FBUyxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDdkQsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksdURBQWdCLENBQUM7WUFDM0MsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ2pCLGFBQWEsRUFBRSxLQUFLO1lBQ3BCLElBQUksRUFBRSxTQUFTO1lBQ2YsSUFBSSxFQUFFLFFBQVE7WUFDZCxlQUFlLEVBQUUsSUFBSTtZQUNyQixNQUFNLEVBQUUsT0FBTyxDQUFDLGNBQWMsQ0FBQyxTQUFTLEVBQUUsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLENBQUM7U0FDaEUsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLEdBQUcsRUFBRTtZQUNsRCxPQUFPLENBQUMsR0FBRyxDQUFDLGlDQUFpQyxDQUFDLENBQUM7WUFDL0MsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFO2dCQUM1QyxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7Z0JBQ2YsUUFBUSxFQUFFLElBQUksQ0FBQyxjQUFjO2dCQUM3QixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7YUFDbEIsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsZUFBZSxFQUFFLEdBQUcsRUFBRTtnQkFDcEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO2dCQUN2QyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQztnQkFDM0MsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHdCQUF3QixFQUFFLENBQUM7Z0JBQ2pELElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVELFVBQVU7UUFDUixJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2xDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDMUMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFNBQVMsQ0FBQztRQUNsQyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUN0QyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDZixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRUQsVUFBVSxDQUFDLGVBQXVCLEVBQUUsT0FBWTtRQUM5QyxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2xDLElBQUksYUFBYSxHQUFHLElBQUksaURBQWEsQ0FBQztZQUNwQyxJQUFJLEVBQUUsWUFBWTtZQUNsQixzQkFBc0IsRUFBRSxJQUFJLENBQUMsZ0JBQWdCO1lBQzdDLE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRTtZQUNuQyxZQUFZLEVBQUU7Z0JBQ1osUUFBUSxFQUFFLGVBQWU7Z0JBQ3pCLFdBQVcsRUFBRSxPQUFPO2FBQ3JCO1NBQ0YsQ0FBQyxDQUFDO1FBQ0gsYUFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLE9BQTRCLEVBQUUsRUFBRTtZQUM3RCxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNwQyxDQUFDLENBQUMsQ0FBQztRQUNILE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7Q0FDRjtBQXhFRCw4Q0F3RUMifQ==
|
|
50
dist/smartsocket.classes.socketconnection.d.ts
vendored
50
dist/smartsocket.classes.socketconnection.d.ts
vendored
@ -1,50 +0,0 @@
|
|||||||
/// <reference types="socket.io" />
|
|
||||||
/// <reference types="socket.io-client" />
|
|
||||||
import * as plugins from './smartsocket.plugins';
|
|
||||||
import { Smartsocket } from './smartsocket.classes.smartsocket';
|
|
||||||
import { SocketRole } from './smartsocket.classes.socketrole';
|
|
||||||
import * as SocketIO from 'socket.io';
|
|
||||||
/**
|
|
||||||
* defines is a SocketConnection is server or client side. Important for mesh setups.
|
|
||||||
*/
|
|
||||||
export declare type TSocketConnectionSide = 'server' | 'client';
|
|
||||||
/**
|
|
||||||
* interface for constructor of class SocketConnection
|
|
||||||
*/
|
|
||||||
export interface ISocketConnectionConstructorOptions {
|
|
||||||
alias: string;
|
|
||||||
authenticated: boolean;
|
|
||||||
role: SocketRole;
|
|
||||||
side: TSocketConnectionSide;
|
|
||||||
smartsocketHost: Smartsocket;
|
|
||||||
socket: SocketIO.Socket | SocketIOClient.Socket;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* interface for authentication data
|
|
||||||
*/
|
|
||||||
export interface ISocketConnectionAuthenticationObject {
|
|
||||||
role: 'coreflowContainer';
|
|
||||||
password: 'somePassword';
|
|
||||||
alias: 'coreflow1';
|
|
||||||
}
|
|
||||||
export declare let allSocketConnections: plugins.lik.Objectmap<SocketConnection>;
|
|
||||||
/**
|
|
||||||
* class SocketConnection represents a websocket connection
|
|
||||||
*/
|
|
||||||
export declare class SocketConnection {
|
|
||||||
alias: string;
|
|
||||||
side: TSocketConnectionSide;
|
|
||||||
authenticated: boolean;
|
|
||||||
role: SocketRole;
|
|
||||||
smartsocketHost: Smartsocket;
|
|
||||||
socket: any;
|
|
||||||
constructor(optionsArg: ISocketConnectionConstructorOptions);
|
|
||||||
/**
|
|
||||||
* authenticate the socket
|
|
||||||
*/
|
|
||||||
authenticate(): Promise<{}>;
|
|
||||||
/**
|
|
||||||
* listen to function requests
|
|
||||||
*/
|
|
||||||
listenToFunctionRequests(): Promise<{}>;
|
|
||||||
}
|
|
100
dist/smartsocket.classes.socketconnection.js
vendored
100
dist/smartsocket.classes.socketconnection.js
vendored
@ -1,100 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./smartsocket.plugins");
|
|
||||||
const helpers = require("./smartsocket.helpers");
|
|
||||||
const lik_1 = require("lik");
|
|
||||||
const smartsocket_classes_socketrequest_1 = require("./smartsocket.classes.socketrequest");
|
|
||||||
// export classes
|
|
||||||
exports.allSocketConnections = new lik_1.Objectmap();
|
|
||||||
/**
|
|
||||||
* class SocketConnection represents a websocket connection
|
|
||||||
*/
|
|
||||||
class SocketConnection {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.authenticated = false;
|
|
||||||
this.alias = optionsArg.alias;
|
|
||||||
this.authenticated = optionsArg.authenticated;
|
|
||||||
this.role = optionsArg.role;
|
|
||||||
this.side = optionsArg.side;
|
|
||||||
this.smartsocketHost = optionsArg.smartsocketHost;
|
|
||||||
this.socket = optionsArg.socket;
|
|
||||||
// standard behaviour that is always true
|
|
||||||
exports.allSocketConnections.add(this);
|
|
||||||
this.socket.on('disconnect', () => {
|
|
||||||
plugins.beautylog.info(`SocketConnection with >alias ${this.alias} on >side ${this.side} disconnected`);
|
|
||||||
this.socket.disconnect();
|
|
||||||
exports.allSocketConnections.remove(this);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
// authenticating --------------------------
|
|
||||||
/**
|
|
||||||
* authenticate the socket
|
|
||||||
*/
|
|
||||||
authenticate() {
|
|
||||||
let done = plugins.smartq.defer();
|
|
||||||
this.socket.on('dataAuth', (dataArg) => {
|
|
||||||
plugins.beautylog.log('received authentication data. now hashing and comparing...');
|
|
||||||
this.socket.removeListener('dataAuth', () => { });
|
|
||||||
if (helpers.checkPasswordForRole(dataArg, this.smartsocketHost)) {
|
|
||||||
// TODO: authenticate password
|
|
||||||
this.alias = dataArg.alias;
|
|
||||||
this.authenticated = true;
|
|
||||||
this.role = helpers.getSocketRoleByName(dataArg.role, this.smartsocketHost);
|
|
||||||
this.socket.emit('authenticated');
|
|
||||||
plugins.beautylog.ok(`socket with >>alias ${this.alias} >>role ${this.role} is authenticated!`);
|
|
||||||
done.resolve(this);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
this.authenticated = false;
|
|
||||||
this.socket.disconnect();
|
|
||||||
done.reject('not authenticated');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
this.socket.emit('requestAuth');
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
// listening -------------------------------
|
|
||||||
/**
|
|
||||||
* listen to function requests
|
|
||||||
*/
|
|
||||||
listenToFunctionRequests() {
|
|
||||||
let done = plugins.smartq.defer();
|
|
||||||
if (this.authenticated) {
|
|
||||||
this.socket.on('function', (dataArg) => {
|
|
||||||
// check if requested function is available to the socket's scope
|
|
||||||
plugins.beautylog.log('function request received');
|
|
||||||
let referencedFunction = this.role.allowedFunctions.find(socketFunctionArg => {
|
|
||||||
return socketFunctionArg.name === dataArg.funcCallData.funcName;
|
|
||||||
});
|
|
||||||
if (referencedFunction !== undefined) {
|
|
||||||
plugins.beautylog.ok('function in access scope');
|
|
||||||
let localSocketRequest = new smartsocket_classes_socketrequest_1.SocketRequest({
|
|
||||||
side: 'responding',
|
|
||||||
originSocketConnection: this,
|
|
||||||
shortId: dataArg.shortId,
|
|
||||||
funcCallData: dataArg.funcCallData
|
|
||||||
});
|
|
||||||
localSocketRequest.createResponse(); // takes care of creating response and sending it back
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
plugins.beautylog.warn('function not existent or out of access scope');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
this.socket.on('functionResponse', (dataArg) => {
|
|
||||||
plugins.beautylog.info(`received response for request with id ${dataArg.shortId}`);
|
|
||||||
let targetSocketRequest = helpers.getSocketRequestById(dataArg.shortId);
|
|
||||||
targetSocketRequest.handleResponse(dataArg);
|
|
||||||
});
|
|
||||||
plugins.beautylog.log(`now listening to function requests for ${this.alias}`);
|
|
||||||
done.resolve(this);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
let errMessage;
|
|
||||||
plugins.beautylog.error(errMessage);
|
|
||||||
done.reject(errMessage);
|
|
||||||
}
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.SocketConnection = SocketConnection;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRjb25uZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRjb25uZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQWlEO0FBQ2pELGlEQUFpRDtBQUVqRCw2QkFBZ0M7QUFLaEMsMkZBSTZDO0FBa0M3QyxpQkFBaUI7QUFDTixRQUFBLG9CQUFvQixHQUFHLElBQUksZUFBUyxFQUFvQixDQUFDO0FBRXBFOztHQUVHO0FBQ0g7SUFPRSxZQUFZLFVBQStDO1FBSjNELGtCQUFhLEdBQVksS0FBSyxDQUFDO1FBSzdCLElBQUksQ0FBQyxLQUFLLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQztRQUM5QixJQUFJLENBQUMsYUFBYSxHQUFHLFVBQVUsQ0FBQyxhQUFhLENBQUM7UUFDOUMsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQzVCLElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQztRQUM1QixJQUFJLENBQUMsZUFBZSxHQUFHLFVBQVUsQ0FBQyxlQUFlLENBQUM7UUFDbEQsSUFBSSxDQUFDLE1BQU0sR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDO1FBRWhDLHlDQUF5QztRQUN6Qyw0QkFBb0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsWUFBWSxFQUFFLEdBQUcsRUFBRTtZQUNoQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FDcEIsZ0NBQWdDLElBQUksQ0FBQyxLQUFLLGFBQWEsSUFBSSxDQUFDLElBQUksZUFBZSxDQUNoRixDQUFDO1lBQ0YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUN6Qiw0QkFBb0IsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFD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
|
|
44
dist/smartsocket.classes.socketfunction.d.ts
vendored
44
dist/smartsocket.classes.socketfunction.d.ts
vendored
@ -1,44 +0,0 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
|
||||||
import { SocketRole } from './smartsocket.classes.socketrole';
|
|
||||||
/**
|
|
||||||
* interface of the contructor options of class SocketFunction
|
|
||||||
*/
|
|
||||||
export interface ISocketFunctionConstructorOptions {
|
|
||||||
funcName: string;
|
|
||||||
funcDef: any;
|
|
||||||
allowedRoles: SocketRole[];
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* interface of the Socket Function call, in other words the object that routes a call to a function
|
|
||||||
*/
|
|
||||||
export interface ISocketFunctionCall {
|
|
||||||
funcName: string;
|
|
||||||
funcDataArg: any;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* interface for function definition of SocketFunction
|
|
||||||
*/
|
|
||||||
export interface IFuncDef {
|
|
||||||
(dataArg: any): PromiseLike<any>;
|
|
||||||
}
|
|
||||||
export declare let allSocketFunctions: plugins.lik.Objectmap<SocketFunction>;
|
|
||||||
/**
|
|
||||||
* class that respresents a function that can be transparently called using a SocketConnection
|
|
||||||
*/
|
|
||||||
export declare class SocketFunction {
|
|
||||||
name: string;
|
|
||||||
funcDef: IFuncDef;
|
|
||||||
roles: SocketRole[];
|
|
||||||
/**
|
|
||||||
* the constructor for SocketFunction
|
|
||||||
*/
|
|
||||||
constructor(optionsArg: ISocketFunctionConstructorOptions);
|
|
||||||
/**
|
|
||||||
* invokes the function of this SocketFunction
|
|
||||||
*/
|
|
||||||
invoke(dataArg: ISocketFunctionCall): Promise<any>;
|
|
||||||
/**
|
|
||||||
* notifies a role about access to this SocketFunction
|
|
||||||
*/
|
|
||||||
private _notifyRole(socketRoleArg);
|
|
||||||
}
|
|
52
dist/smartsocket.classes.socketfunction.js
vendored
52
dist/smartsocket.classes.socketfunction.js
vendored
@ -1,52 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./smartsocket.plugins");
|
|
||||||
// import classes
|
|
||||||
const lik_1 = require("lik");
|
|
||||||
// export objects
|
|
||||||
exports.allSocketFunctions = new lik_1.Objectmap();
|
|
||||||
// export classes
|
|
||||||
/**
|
|
||||||
* class that respresents a function that can be transparently called using a SocketConnection
|
|
||||||
*/
|
|
||||||
class SocketFunction {
|
|
||||||
/**
|
|
||||||
* the constructor for SocketFunction
|
|
||||||
*/
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.name = optionsArg.funcName;
|
|
||||||
this.funcDef = optionsArg.funcDef;
|
|
||||||
this.roles = optionsArg.allowedRoles;
|
|
||||||
for (let socketRoleArg of this.roles) {
|
|
||||||
this._notifyRole(socketRoleArg);
|
|
||||||
}
|
|
||||||
exports.allSocketFunctions.add(this); // map instance with Objectmap
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* invokes the function of this SocketFunction
|
|
||||||
*/
|
|
||||||
invoke(dataArg) {
|
|
||||||
let done = plugins.smartq.defer();
|
|
||||||
if (dataArg.funcName === this.name) {
|
|
||||||
this.funcDef(dataArg.funcDataArg).then((resultData) => {
|
|
||||||
let funcResponseData = {
|
|
||||||
funcName: this.name,
|
|
||||||
funcDataArg: resultData
|
|
||||||
};
|
|
||||||
done.resolve(funcResponseData);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
throw new Error("SocketFunction.name does not match the data argument's .name!");
|
|
||||||
}
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* notifies a role about access to this SocketFunction
|
|
||||||
*/
|
|
||||||
_notifyRole(socketRoleArg) {
|
|
||||||
socketRoleArg.addSocketFunction(this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.SocketFunction = SocketFunction;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRmdW5jdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c29ja2V0LmNsYXNzZXMuc29ja2V0ZnVuY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxpREFBaUQ7QUFFakQsaUJBQWlCO0FBQ2pCLDZCQUFnQztBQTZCaEMsaUJBQWlCO0FBQ04sUUFBQSxrQkFBa0IsR0FBRyxJQUFJLGVBQVMsRUFBa0IsQ0FBQztBQUVoRSxpQkFBaUI7QUFFakI7O0dBRUc7QUFDSDtJQUtFOztPQUVHO0lBQ0gsWUFBWSxVQUE2QztRQUN2RCxJQUFJLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUM7UUFDaEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDO1FBQ2xDLElBQUksQ0FBQyxLQUFLLEdBQUcsVUFBVSxDQUFDLFlBQVksQ0FBQztRQUNyQyxHQUFHLENBQUMsQ0FBQyxJQUFJLGFBQWEsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUNyQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2xDLENBQUM7UUFDRCwwQkFBa0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyw4QkFBOEI7SUFDOUQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsTUFBTSxDQUFDLE9BQTRCO1FBQ2pDLElBQUksSUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDbEMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLFFBQVEsS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUNuQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxVQUFlLEVBQUUsRUFBRTtnQkFDekQsSUFBSSxnQkFBZ0IsR0FBd0I7b0JBQzFDLFFBQVEsRUFBRSxJQUFJLENBQUMsSUFBSTtvQkFDbkIsV0FBVyxFQUFFLFVBQVU7aUJBQ3hCLENBQUM7Z0JBQ0YsSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQ2pDLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUFDLElBQUksQ0FBQyxDQUFDO1lBQ04sTUFBTSxJQUFJLEtBQUssQ0FBQywrREFBK0QsQ0FBQyxDQUFDO1FBQ25GLENBQUM7UUFDRCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRUQ7O09BRUc7SUFDSyxXQUFXLENBQUMsYUFBeUI7UUFDM0MsYUFBYSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hDLENBQUM7Q0FDRjtBQTNDRCx3Q0EyQ0MifQ==
|
|
44
dist/smartsocket.classes.socketrequest.d.ts
vendored
44
dist/smartsocket.classes.socketrequest.d.ts
vendored
@ -1,44 +0,0 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
|
||||||
import { ISocketFunctionCall } from './smartsocket.classes.socketfunction';
|
|
||||||
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
|
||||||
export declare type TSocketRequestStatus = 'new' | 'pending' | 'finished';
|
|
||||||
export declare type TSocketRequestSide = 'requesting' | 'responding';
|
|
||||||
/**
|
|
||||||
* interface of constructor of class SocketRequest
|
|
||||||
*/
|
|
||||||
export interface SocketRequestConstructorOptions {
|
|
||||||
side: TSocketRequestSide;
|
|
||||||
originSocketConnection: SocketConnection;
|
|
||||||
shortId: string;
|
|
||||||
funcCallData?: ISocketFunctionCall;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* request object that is sent initially and may or may not receive a response
|
|
||||||
*/
|
|
||||||
export interface ISocketRequestDataObject {
|
|
||||||
funcCallData: ISocketFunctionCall;
|
|
||||||
shortId: string;
|
|
||||||
responseTimeout?: number;
|
|
||||||
}
|
|
||||||
export declare let allSocketRequests: plugins.lik.Objectmap<SocketRequest>;
|
|
||||||
export declare class SocketRequest {
|
|
||||||
status: TSocketRequestStatus;
|
|
||||||
side: TSocketRequestSide;
|
|
||||||
shortid: string;
|
|
||||||
originSocketConnection: SocketConnection;
|
|
||||||
funcCallData: ISocketFunctionCall;
|
|
||||||
done: plugins.smartq.Deferred<{}>;
|
|
||||||
constructor(optionsArg: SocketRequestConstructorOptions);
|
|
||||||
/**
|
|
||||||
* dispatches a socketrequest from the requesting to the receiving side
|
|
||||||
*/
|
|
||||||
dispatch(): Promise<{}>;
|
|
||||||
/**
|
|
||||||
* handles the response that is received by the requesting side
|
|
||||||
*/
|
|
||||||
handleResponse(responseDataArg: ISocketRequestDataObject): void;
|
|
||||||
/**
|
|
||||||
* creates the response on the responding side
|
|
||||||
*/
|
|
||||||
createResponse(): void;
|
|
||||||
}
|
|
59
dist/smartsocket.classes.socketrequest.js
vendored
59
dist/smartsocket.classes.socketrequest.js
vendored
@ -1,59 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./smartsocket.plugins");
|
|
||||||
const helpers = require("./smartsocket.helpers");
|
|
||||||
// import classes
|
|
||||||
const lik_1 = require("lik");
|
|
||||||
// export objects
|
|
||||||
exports.allSocketRequests = new lik_1.Objectmap();
|
|
||||||
// export classes
|
|
||||||
class SocketRequest {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.status = 'new';
|
|
||||||
this.done = plugins.smartq.defer();
|
|
||||||
this.side = optionsArg.side;
|
|
||||||
this.shortid = optionsArg.shortId;
|
|
||||||
this.funcCallData = optionsArg.funcCallData;
|
|
||||||
this.originSocketConnection = optionsArg.originSocketConnection;
|
|
||||||
exports.allSocketRequests.add(this);
|
|
||||||
}
|
|
||||||
// requesting --------------------------
|
|
||||||
/**
|
|
||||||
* dispatches a socketrequest from the requesting to the receiving side
|
|
||||||
*/
|
|
||||||
dispatch() {
|
|
||||||
let requestData = {
|
|
||||||
funcCallData: this.funcCallData,
|
|
||||||
shortId: this.shortid
|
|
||||||
};
|
|
||||||
this.originSocketConnection.socket.emit('function', requestData);
|
|
||||||
return this.done.promise;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* handles the response that is received by the requesting side
|
|
||||||
*/
|
|
||||||
handleResponse(responseDataArg) {
|
|
||||||
plugins.beautylog.log('handling response!');
|
|
||||||
this.done.resolve(responseDataArg.funcCallData);
|
|
||||||
exports.allSocketRequests.remove(this);
|
|
||||||
}
|
|
||||||
// responding --------------------------
|
|
||||||
/**
|
|
||||||
* creates the response on the responding side
|
|
||||||
*/
|
|
||||||
createResponse() {
|
|
||||||
let targetSocketFunction = helpers.getSocketFunctionByName(this.funcCallData.funcName);
|
|
||||||
plugins.beautylog.info(`invoking ${targetSocketFunction.name}`);
|
|
||||||
targetSocketFunction.invoke(this.funcCallData).then(resultData => {
|
|
||||||
plugins.beautylog.log('got resultData. Sending it to requesting party.');
|
|
||||||
let requestData = {
|
|
||||||
funcCallData: resultData,
|
|
||||||
shortId: this.shortid
|
|
||||||
};
|
|
||||||
this.originSocketConnection.socket.emit('functionResponse', requestData);
|
|
||||||
exports.allSocketRequests.remove(this);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.SocketRequest = SocketRequest;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRyZXF1ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRyZXF1ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQWlEO0FBQ2pELGlEQUFpRDtBQUtqRCxpQkFBaUI7QUFDakIsNkJBQWdDO0FBMkJoQyxpQkFBaUI7QUFDTixRQUFBLGlCQUFpQixHQUFHLElBQUksZUFBUyxFQUFpQixDQUFDO0FBRTlELGlCQUFpQjtBQUNqQjtJQU9FLFlBQVksVUFBMkM7UUFOdkQsV0FBTSxHQUF5QixLQUFLLENBQUM7UUFLckMsU0FBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7UUFFNUIsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQzVCLElBQUksQ0FBQyxPQUFPLEdBQUcsVUFBVSxDQUFDLE9BQU8sQ0FBQztRQUNsQyxJQUFJLENBQUMsWUFBWSxHQUFHLFVBQVUsQ0FBQyxZQUFZLENBQUM7UUFDNUMsSUFBSSxDQUFDLHNCQUFzQixHQUFHLFVBQVUsQ0FBQyxzQkFBc0IsQ0FBQztRQUNoRSx5QkFBaUIsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVELHdDQUF3QztJQUV4Qzs7T0FFRztJQUNILFFBQVE7UUFDTixJQUFJLFdBQVcsR0FBNkI7WUFDMUMsWUFBWSxFQUFFLElBQUksQ0FBQyxZQUFZO1lBQy9CLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztTQUN0QixDQUFDO1FBQ0YsSUFBSSxDQUFDLHNCQUFzQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQ2pFLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUMzQixDQUFDO0lBRUQ7O09BRUc7SUFDSCxjQUFjLENBQUMsZUFBeUM7UUFDdEQsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUM1QyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDaEQseUJBQWlCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRCx3Q0FBd0M7SUFFeEM7O09BRUc7SUFDSCxjQUFjO1FBQ1osSUFBSSxvQkFBb0IsR0FBbUIsT0FBTyxDQUFDLHVCQUF1QixDQUN4RSxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FDM0IsQ0FBQztRQUNGLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksb0JBQW9CLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNoRSxvQkFBb0IsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUMvRCxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxpREFBaUQsQ0FBQyxDQUFDO1lBQ3pFLElBQUksV0FBVyxHQUE2QjtnQkFDMUMsWUFBWSxFQUFFLFVBQVU7Z0JBQ3hCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTzthQUN0QixDQUFDO1lBQ0YsSUFBSSxDQUFDLHNCQUFzQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsV0FBVyxDQUFDLENBQUM7WUFDekUseUJBQWlCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBMURELHNDQTBEQyJ9
|
|
19
dist/smartsocket.classes.socketrole.d.ts
vendored
19
dist/smartsocket.classes.socketrole.d.ts
vendored
@ -1,19 +0,0 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
|
||||||
import { SocketFunction } from './smartsocket.classes.socketfunction';
|
|
||||||
/**
|
|
||||||
* interface for class SocketRole
|
|
||||||
*/
|
|
||||||
export interface SocketRoleOptions {
|
|
||||||
name: string;
|
|
||||||
passwordHash: string;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* A socketrole defines access to certain routines.
|
|
||||||
*/
|
|
||||||
export declare class SocketRole {
|
|
||||||
name: string;
|
|
||||||
passwordHash: string;
|
|
||||||
allowedFunctions: plugins.lik.Objectmap<SocketFunction>;
|
|
||||||
constructor(optionsArg: SocketRoleOptions);
|
|
||||||
addSocketFunction(socketFunctionArg: SocketFunction): void;
|
|
||||||
}
|
|
19
dist/smartsocket.classes.socketrole.js
vendored
19
dist/smartsocket.classes.socketrole.js
vendored
@ -1,19 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
// import classes
|
|
||||||
const lik_1 = require("lik");
|
|
||||||
/**
|
|
||||||
* A socketrole defines access to certain routines.
|
|
||||||
*/
|
|
||||||
class SocketRole {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.allowedFunctions = new lik_1.Objectmap();
|
|
||||||
this.name = optionsArg.name;
|
|
||||||
this.passwordHash = optionsArg.passwordHash;
|
|
||||||
}
|
|
||||||
addSocketFunction(socketFunctionArg) {
|
|
||||||
this.allowedFunctions.add(socketFunctionArg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.SocketRole = SocketRole;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRyb2xlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRyb2xlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsaUJBQWlCO0FBQ2pCLDZCQUFnQztBQVdoQzs7R0FFRztBQUNIO0lBSUUsWUFBWSxVQUE2QjtRQUR6QyxxQkFBZ0IsR0FBRyxJQUFJLGVBQVMsRUFBa0IsQ0FBQztRQUVqRCxJQUFJLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUM7UUFDNUIsSUFBSSxDQUFDLFlBQVksR0FBRyxVQUFVLENBQUMsWUFBWSxDQUFDO0lBQzlDLENBQUM7SUFDRCxpQkFBaUIsQ0FBQyxpQkFBaUM7UUFDakQsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQy9DLENBQUM7Q0FDRjtBQVhELGdDQVdDIn0=
|
|
29
dist/smartsocket.classes.socketserver.d.ts
vendored
29
dist/smartsocket.classes.socketserver.d.ts
vendored
@ -1,29 +0,0 @@
|
|||||||
import { Smartsocket } from './smartsocket.classes.smartsocket';
|
|
||||||
/**
|
|
||||||
* class socketServer
|
|
||||||
* handles the attachment of socketIo to whatever server is in play
|
|
||||||
*/
|
|
||||||
export declare class SocketServer {
|
|
||||||
private smartsocket;
|
|
||||||
private httpServer;
|
|
||||||
private standaloneServer;
|
|
||||||
private expressServer;
|
|
||||||
constructor(smartSocketInstance: Smartsocket);
|
|
||||||
/**
|
|
||||||
* starts the server with another server
|
|
||||||
* also works with an express style server
|
|
||||||
*/
|
|
||||||
setExternalServer(serverType: 'express' | 'http', serverArg: any): Promise<void>;
|
|
||||||
/**
|
|
||||||
* gets the server for socket.io
|
|
||||||
*/
|
|
||||||
getServerForSocketIo(): any;
|
|
||||||
/**
|
|
||||||
* starts listening to incoming sockets:
|
|
||||||
*/
|
|
||||||
start(): Promise<void>;
|
|
||||||
/**
|
|
||||||
* closes the server
|
|
||||||
*/
|
|
||||||
stop(): Promise<void>;
|
|
||||||
}
|
|
86
dist/smartsocket.classes.socketserver.js
vendored
86
dist/smartsocket.classes.socketserver.js
vendored
@ -1,86 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
|
||||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
||||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
||||||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
||||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
||||||
});
|
|
||||||
};
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./smartsocket.plugins");
|
|
||||||
// used in case no other server is supplied
|
|
||||||
const http = require("http");
|
|
||||||
/**
|
|
||||||
* class socketServer
|
|
||||||
* handles the attachment of socketIo to whatever server is in play
|
|
||||||
*/
|
|
||||||
class SocketServer {
|
|
||||||
constructor(smartSocketInstance) {
|
|
||||||
// wether httpServer is standalone
|
|
||||||
this.standaloneServer = false;
|
|
||||||
this.smartsocket = smartSocketInstance;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* starts the server with another server
|
|
||||||
* also works with an express style server
|
|
||||||
*/
|
|
||||||
setExternalServer(serverType, serverArg) {
|
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
|
||||||
if (serverType === 'http') {
|
|
||||||
this.httpServer = serverArg;
|
|
||||||
}
|
|
||||||
else if (serverType === 'express') {
|
|
||||||
this.expressServer = serverArg;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* gets the server for socket.io
|
|
||||||
*/
|
|
||||||
getServerForSocketIo() {
|
|
||||||
if (this.httpServer) {
|
|
||||||
return this.httpServer;
|
|
||||||
}
|
|
||||||
else if (this.expressServer) {
|
|
||||||
return this.expressServer;
|
|
||||||
}
|
|
||||||
else if (!this.httpServer && !this.expressServer) {
|
|
||||||
this.httpServer = new http.Server();
|
|
||||||
this.standaloneServer = true;
|
|
||||||
return this.httpServer;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
throw new Error('no server specified!');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* starts listening to incoming sockets:
|
|
||||||
*/
|
|
||||||
start() {
|
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
|
||||||
const done = plugins.smartq.defer();
|
|
||||||
// handle http servers
|
|
||||||
if (this.httpServer && this.standaloneServer) {
|
|
||||||
this.httpServer.listen(this.smartsocket.options.port, () => {
|
|
||||||
console.log(`Server started in standalone mode on ${this.smartsocket.options.port}`);
|
|
||||||
done.resolve();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
done.resolve();
|
|
||||||
}
|
|
||||||
// nothing else to do if express server is set
|
|
||||||
yield done.promise;
|
|
||||||
return;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* closes the server
|
|
||||||
*/
|
|
||||||
stop() {
|
|
||||||
return __awaiter(this, void 0, void 0, function* () { });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.SocketServer = SocketServer;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuY2xhc3Nlcy5zb2NrZXRzZXJ2ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9zbWFydHNvY2tldC5jbGFzc2VzLnNvY2tldHNlcnZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBQUEsaURBQWlEO0FBRWpELDJDQUEyQztBQUMzQyw2QkFBNkI7QUFHN0I7OztHQUdHO0FBQ0g7SUFPRSxZQUFZLG1CQUFnQztRQUo1QyxrQ0FBa0M7UUFDMUIscUJBQWdCLEdBQUcsS0FBSyxDQUFDO1FBSS9CLElBQUksQ0FBQyxXQUFXLEdBQUcsbUJBQW1CLENBQUM7SUFDekMsQ0FBQztJQUVEOzs7T0FHRztJQUNVLGlCQUFpQixDQUFDLFVBQThCLEVBQUUsU0FBYzs7WUFDM0UsRUFBRSxDQUFDLENBQUMsVUFBVSxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUM7Z0JBQzFCLElBQUksQ0FBQyxVQUFVLEdBQUcsU0FBUyxDQUFDO1lBQzlCLENBQUM7WUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsVUFBVSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3BDLElBQUksQ0FBQyxhQUFhLEdBQUcsU0FBUyxDQUFDO1lBQ2pDLENBQUM7UUFDSCxDQUFDO0tBQUE7SUFFRDs7T0FFRztJQUNJLG9CQUFvQjtRQUN6QixFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztZQUNwQixNQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztRQUN6QixDQUFDO1FBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO1lBQzlCLE1BQU0sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDO1FBQzVCLENBQUM7UUFBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7WUFDbkQsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNwQyxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO1lBQzdCLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO1FBQ3pCLENBQUM7UUFBQyxJQUFJLENBQUMsQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLENBQUMsQ0FBQztRQUMxQyxDQUFDO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ1UsS0FBSzs7WUFDaEIsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUVwQyxzQkFBc0I7WUFDdEIsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDO2dCQUM3QyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFO29CQUN6RCxPQUFPLENBQUMsR0FBRyxDQUFDLHdDQUF3QyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO29CQUNyRixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQ2pCLENBQUMsQ0FBQyxDQUFDO1lBQ0wsQ0FBQztZQUFDLElBQUksQ0FBQyxDQUFDO2dCQUNOLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixDQUFDO1lBRUQsOENBQThDO1lBQzlDLE1BQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQztZQUNuQixNQUFNLENBQUM7UUFDVCxDQUFDO0tBQUE7SUFFRDs7T0FFRztJQUNVLElBQUk7OERBQUksQ0FBQztLQUFBO0NBQ3ZCO0FBakVELG9DQWlFQyJ9
|
|
15
dist/smartsocket.helpers.d.ts
vendored
15
dist/smartsocket.helpers.d.ts
vendored
@ -1,15 +0,0 @@
|
|||||||
import { Smartsocket } from './smartsocket.classes.smartsocket';
|
|
||||||
import { SocketFunction } from './smartsocket.classes.socketfunction';
|
|
||||||
import { ISocketConnectionAuthenticationObject } from './smartsocket.classes.socketconnection';
|
|
||||||
import { SocketRequest, TSocketRequestSide } from './smartsocket.classes.socketrequest';
|
|
||||||
import { SocketRole } from './smartsocket.classes.socketrole';
|
|
||||||
export declare let checkPasswordForRole: (dataArg: ISocketConnectionAuthenticationObject, referenceSmartsocket: Smartsocket) => boolean;
|
|
||||||
export declare let getSocketFunctionByName: (functionNameArg: string) => SocketFunction;
|
|
||||||
/**
|
|
||||||
* get corresponding Socketrequest instance by shortId
|
|
||||||
*/
|
|
||||||
export declare let getSocketRequestById: (shortIdArg: string, requestSide?: TSocketRequestSide) => SocketRequest;
|
|
||||||
/**
|
|
||||||
* get corresponding SocketRole instance by name
|
|
||||||
*/
|
|
||||||
export declare let getSocketRoleByName: (socketRoleNameArg: string, referenceSmartsocket: Smartsocket) => SocketRole;
|
|
36
dist/smartsocket.helpers.js
vendored
36
dist/smartsocket.helpers.js
vendored
@ -1,36 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./smartsocket.plugins");
|
|
||||||
const smartsocket_classes_socketfunction_1 = require("./smartsocket.classes.socketfunction");
|
|
||||||
const smartsocket_classes_socketrequest_1 = require("./smartsocket.classes.socketrequest");
|
|
||||||
// SocketConnection helpers
|
|
||||||
exports.checkPasswordForRole = (dataArg, referenceSmartsocket) => {
|
|
||||||
let targetPasswordHash = exports.getSocketRoleByName(dataArg.role, referenceSmartsocket).passwordHash;
|
|
||||||
let computedCompareHash = plugins.nodehash.sha256FromStringSync(dataArg.password);
|
|
||||||
return targetPasswordHash === computedCompareHash;
|
|
||||||
};
|
|
||||||
// SocketFunction helpers
|
|
||||||
exports.getSocketFunctionByName = (functionNameArg) => {
|
|
||||||
return smartsocket_classes_socketfunction_1.allSocketFunctions.find(socketFunctionArg => {
|
|
||||||
return socketFunctionArg.name === functionNameArg;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
// SocketRequest helpers
|
|
||||||
/**
|
|
||||||
* get corresponding Socketrequest instance by shortId
|
|
||||||
*/
|
|
||||||
exports.getSocketRequestById = (shortIdArg, requestSide) => {
|
|
||||||
return smartsocket_classes_socketrequest_1.allSocketRequests.find(socketRequestArg => {
|
|
||||||
return socketRequestArg.shortid === shortIdArg;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
// SocketRole helpers
|
|
||||||
/**
|
|
||||||
* get corresponding SocketRole instance by name
|
|
||||||
*/
|
|
||||||
exports.getSocketRoleByName = (socketRoleNameArg, referenceSmartsocket) => {
|
|
||||||
return referenceSmartsocket.socketRoles.find(socketRoleArg => {
|
|
||||||
return socketRoleArg.name === socketRoleNameArg;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQuaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c29ja2V0LmhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxpREFBaUQ7QUFJakQsNkZBQTBGO0FBSzFGLDJGQUk2QztBQUc3QywyQkFBMkI7QUFDaEIsUUFBQSxvQkFBb0IsR0FBRyxDQUNoQyxPQUE4QyxFQUM5QyxvQkFBaUMsRUFDeEIsRUFBRTtJQUNYLElBQUksa0JBQWtCLEdBQUcsMkJBQW1CLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxvQkFBb0IsQ0FBQyxDQUFDLFlBQVksQ0FBQztJQUM5RixJQUFJLG1CQUFtQixHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2xGLE1BQU0sQ0FBQyxrQkFBa0IsS0FBSyxtQkFBbUIsQ0FBQztBQUNwRCxDQUFDLENBQUM7QUFFRix5QkFBeUI7QUFDZCxRQUFBLHVCQUF1QixHQUFHLENBQUMsZUFBdUIsRUFBa0IsRUFBRTtJQUMvRSxNQUFNLENBQUMsdURBQWtCLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEVBQUU7UUFDakQsTUFBTSxDQUFDLGlCQUFpQixDQUFDLElBQUksS0FBSyxlQUFlLENBQUM7SUFDcEQsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUM7QUFFRix3QkFBd0I7QUFFeEI7O0dBRUc7QUFDUSxRQUFBLG9CQUFvQixHQUFHLENBQ2hDLFVBQWtCLEVBQ2xCLFdBQWdDLEVBQ2pCLEVBQUU7SUFDakIsTUFBTSxDQUFDLHFEQUFpQixDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFO1FBQy9DLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLEtBQUssVUFBVSxDQUFDO0lBQ2pELENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDO0FBRUYscUJBQXFCO0FBRXJCOztHQUVHO0FBQ1EsUUFBQSxtQkFBbUIsR0FBRyxDQUMvQixpQkFBeUIsRUFDekIsb0JBQWlDLEVBQ3JCLEVBQUU7SUFDZCxNQUFNLENBQUMsb0JBQW9CLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsRUFBRTtRQUMzRCxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksS0FBSyxpQkFBaUIsQ0FBQztJQUNsRCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyJ9
|
|
8
dist/smartsocket.plugins.d.ts
vendored
8
dist/smartsocket.plugins.d.ts
vendored
@ -1,8 +0,0 @@
|
|||||||
export import beautylog = require('beautylog');
|
|
||||||
export import lik = require('lik');
|
|
||||||
export import nodehash = require('nodehash');
|
|
||||||
export import smartdelay = require('smartdelay');
|
|
||||||
export import smartq = require('smartq');
|
|
||||||
export import shortid = require('shortid');
|
|
||||||
export import socketIo = require('socket.io');
|
|
||||||
export import socketIoClient = require('socket.io-client');
|
|
11
dist/smartsocket.plugins.js
vendored
11
dist/smartsocket.plugins.js
vendored
@ -1,11 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
exports.beautylog = require("beautylog");
|
|
||||||
exports.lik = require("lik");
|
|
||||||
exports.nodehash = require("nodehash");
|
|
||||||
exports.smartdelay = require("smartdelay");
|
|
||||||
exports.smartq = require("smartq");
|
|
||||||
exports.shortid = require("shortid");
|
|
||||||
exports.socketIo = require("socket.io");
|
|
||||||
exports.socketIoClient = require("socket.io-client");
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRzb2NrZXQucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0c29ja2V0LnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5Q0FBK0M7QUFDL0MsNkJBQW1DO0FBQ25DLHVDQUE2QztBQUM3QywyQ0FBaUQ7QUFDakQsbUNBQXlDO0FBQ3pDLHFDQUEyQztBQUMzQyx3Q0FBOEM7QUFDOUMscURBQTJEIn0=
|
|
1978
package-lock.json
generated
1978
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
40
package.json
40
package.json
@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "@pushrocks/smartsocket",
|
"name": "@pushrocks/smartsocket",
|
||||||
"version": "1.1.26",
|
"version": "1.1.41",
|
||||||
"description": "easy and secure websocket communication",
|
"description": "easy and secure websocket communication",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"typings": "dist/index.d.ts",
|
"typings": "dist/index.d.ts",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "tstest test/",
|
"test": "tstest test/",
|
||||||
"build": "echo \"Not needed for now\""
|
"build": "tsbuild"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
@ -19,11 +19,12 @@
|
|||||||
},
|
},
|
||||||
"homepage": "https://gitlab.com/pushrocks/smartsocket#README",
|
"homepage": "https://gitlab.com/pushrocks/smartsocket#README",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@pushrocks/lik": "^3.0.4",
|
"@pushrocks/lik": "^3.0.10",
|
||||||
"@pushrocks/smartdelay": "^2.0.2",
|
"@pushrocks/smartdelay": "^2.0.3",
|
||||||
"@pushrocks/smarthash": "^2.0.4",
|
"@pushrocks/smartexpress": "^3.0.38",
|
||||||
"@pushrocks/smartlog": "^2.0.16",
|
"@pushrocks/smarthash": "^2.0.6",
|
||||||
"@pushrocks/smartpromise": "^2.0.5",
|
"@pushrocks/smartlog": "^2.0.19",
|
||||||
|
"@pushrocks/smartpromise": "^3.0.2",
|
||||||
"@types/shortid": "0.0.29",
|
"@types/shortid": "0.0.29",
|
||||||
"@types/socket.io": "^2.1.2",
|
"@types/socket.io": "^2.1.2",
|
||||||
"@types/socket.io-client": "^1.4.32",
|
"@types/socket.io-client": "^1.4.32",
|
||||||
@ -32,11 +33,24 @@
|
|||||||
"socket.io-client": "^2.2.0"
|
"socket.io-client": "^2.2.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@gitzone/tsbuild": "^2.1.8",
|
"@gitzone/tsbuild": "^2.1.11",
|
||||||
"@gitzone/tsrun": "^1.1.17",
|
"@gitzone/tsrun": "^1.2.8",
|
||||||
"@gitzone/tstest": "^1.0.18",
|
"@gitzone/tstest": "^1.0.24",
|
||||||
"@pushrocks/tapbundle": "^3.0.7",
|
"@pushrocks/tapbundle": "^3.0.11",
|
||||||
"@types/node": "^10.12.19"
|
"@types/node": "^12.7.1",
|
||||||
|
"tslint": "^5.18.0",
|
||||||
|
"tslint-config-prettier": "^1.18.0"
|
||||||
},
|
},
|
||||||
"private": false
|
"private": false,
|
||||||
|
"files": [
|
||||||
|
"ts/*",
|
||||||
|
"ts_web/*",
|
||||||
|
"dist/*",
|
||||||
|
"dist_web/*",
|
||||||
|
"dist_ts_web/*",
|
||||||
|
"assets/*",
|
||||||
|
"cli.js",
|
||||||
|
"npmextra.json",
|
||||||
|
"readme.md"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
1
test/common/test.ts
Normal file
1
test/common/test.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
console.log('TODO');
|
106
test/test.expressserver.ts
Normal file
106
test/test.expressserver.ts
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
// tslint:disable-next-line:no-implicit-dependencies
|
||||||
|
import { expect, tap } from '@pushrocks/tapbundle';
|
||||||
|
|
||||||
|
import * as smarthash from '@pushrocks/smarthash';
|
||||||
|
import * as smartpromise from '@pushrocks/smartpromise';
|
||||||
|
import * as smartexpress from '@pushrocks/smartexpress';
|
||||||
|
|
||||||
|
import socketIoClient = require('socket.io-client');
|
||||||
|
import smartsocket = require('../ts/index');
|
||||||
|
|
||||||
|
let testSmartsocket: smartsocket.Smartsocket;
|
||||||
|
let testSmartsocketClient: smartsocket.SmartsocketClient;
|
||||||
|
let testSocketRole1: smartsocket.SocketRole;
|
||||||
|
let testSocketFunction1: smartsocket.SocketFunction;
|
||||||
|
let myseServer: smartexpress.Server;
|
||||||
|
|
||||||
|
const testConfig = {
|
||||||
|
port: 3000
|
||||||
|
};
|
||||||
|
|
||||||
|
// class smartsocket
|
||||||
|
tap.test('should create a new smartsocket', async () => {
|
||||||
|
testSmartsocket = new smartsocket.Smartsocket({ port: testConfig.port });
|
||||||
|
expect(testSmartsocket).be.instanceOf(smartsocket.Smartsocket);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('Should accept an smartExpressServer as server', async () => {
|
||||||
|
myseServer = new smartexpress.Server({
|
||||||
|
cors: true,
|
||||||
|
forceSsl: false,
|
||||||
|
port: testConfig.port
|
||||||
|
});
|
||||||
|
|
||||||
|
testSmartsocket.setExternalServer('smartexpress', myseServer);
|
||||||
|
|
||||||
|
await myseServer.start();
|
||||||
|
});
|
||||||
|
|
||||||
|
// class socketrole
|
||||||
|
tap.test('should add a socketrole', async () => {
|
||||||
|
testSocketRole1 = new smartsocket.SocketRole({
|
||||||
|
name: 'testRole1',
|
||||||
|
passwordHash: smarthash.sha256FromStringSync('testPassword')
|
||||||
|
});
|
||||||
|
testSmartsocket.addSocketRoles([testSocketRole1]);
|
||||||
|
});
|
||||||
|
|
||||||
|
// class SocketFunction
|
||||||
|
tap.test('should register a new Function', async () => {
|
||||||
|
testSocketFunction1 = new smartsocket.SocketFunction({
|
||||||
|
allowedRoles: [testSocketRole1],
|
||||||
|
funcDef: async (dataArg, socketConnectionArg) => {
|
||||||
|
return dataArg;
|
||||||
|
},
|
||||||
|
funcName: 'testFunction1'
|
||||||
|
});
|
||||||
|
testSmartsocket.addSocketFunction(testSocketFunction1);
|
||||||
|
console.log(testSmartsocket.socketFunctions);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('should start listening when .started is called', async () => {
|
||||||
|
await testSmartsocket.start();
|
||||||
|
});
|
||||||
|
|
||||||
|
// class SmartsocketClient
|
||||||
|
tap.test('should react to a new websocket connection from client', async () => {
|
||||||
|
testSmartsocketClient = new smartsocket.SmartsocketClient({
|
||||||
|
port: testConfig.port,
|
||||||
|
url: 'http://localhost',
|
||||||
|
password: 'testPassword',
|
||||||
|
alias: 'testClient1',
|
||||||
|
role: 'testRole1'
|
||||||
|
});
|
||||||
|
testSmartsocketClient.addSocketFunction(testSocketFunction1);
|
||||||
|
console.log(testSmartsocketClient.socketFunctions);
|
||||||
|
await testSmartsocketClient.connect();
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('client should disconnect and reconnect', async tools => {
|
||||||
|
await testSmartsocketClient.disconnect();
|
||||||
|
await tools.delayFor(100);
|
||||||
|
await testSmartsocketClient.connect();
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('2 clients should connect in parallel', async () => {
|
||||||
|
// TODO: implement parallel test
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('should be able to make a functionCall from client to server', async () => {
|
||||||
|
const response = await testSmartsocketClient.serverCall('testFunction1', {
|
||||||
|
value1: 'hello'
|
||||||
|
});
|
||||||
|
console.log(response);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('should be able to make a functionCall from server to client', async () => {
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
// terminate
|
||||||
|
tap.test('should close the server', async () => {
|
||||||
|
await testSmartsocket.stop();
|
||||||
|
await myseServer.stop();
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.start();
|
76
test/test.ts
76
test/test.ts
@ -1,8 +1,8 @@
|
|||||||
// tslint:disable-next-line:no-implicit-dependencies
|
// tslint:disable-next-line:no-implicit-dependencies
|
||||||
import { expect, tap } from '@pushrocks/tapbundle';
|
import { expect, tap } from '@pushrocks/tapbundle';
|
||||||
|
|
||||||
import * as nodehash from '@pushrocks/smarthash';
|
import * as smarthash from '@pushrocks/smarthash';
|
||||||
import * as smartq from '@pushrocks/smartpromise';
|
import * as smartpromise from '@pushrocks/smartpromise';
|
||||||
|
|
||||||
import socketIoClient = require('socket.io-client');
|
import socketIoClient = require('socket.io-client');
|
||||||
import smartsocket = require('../ts/index');
|
import smartsocket = require('../ts/index');
|
||||||
@ -22,15 +22,11 @@ tap.test('should create a new smartsocket', async () => {
|
|||||||
expect(testSmartsocket).be.instanceOf(smartsocket.Smartsocket);
|
expect(testSmartsocket).be.instanceOf(smartsocket.Smartsocket);
|
||||||
});
|
});
|
||||||
|
|
||||||
tap.test('should start listening when .started is called', async () => {
|
|
||||||
await testSmartsocket.start();
|
|
||||||
});
|
|
||||||
|
|
||||||
// class socketrole
|
// class socketrole
|
||||||
tap.test('should add a socketrole', async () => {
|
tap.test('should add a socketrole', async () => {
|
||||||
testSocketRole1 = new smartsocket.SocketRole({
|
testSocketRole1 = new smartsocket.SocketRole({
|
||||||
name: 'testRole1',
|
name: 'testRole1',
|
||||||
passwordHash: nodehash.sha256FromStringSync('testPassword')
|
passwordHash: smarthash.sha256FromStringSync('testPassword')
|
||||||
});
|
});
|
||||||
testSmartsocket.addSocketRoles([testSocketRole1]);
|
testSmartsocket.addSocketRoles([testSocketRole1]);
|
||||||
});
|
});
|
||||||
@ -39,16 +35,21 @@ tap.test('should add a socketrole', async () => {
|
|||||||
tap.test('should register a new Function', async () => {
|
tap.test('should register a new Function', async () => {
|
||||||
testSocketFunction1 = new smartsocket.SocketFunction({
|
testSocketFunction1 = new smartsocket.SocketFunction({
|
||||||
allowedRoles: [testSocketRole1],
|
allowedRoles: [testSocketRole1],
|
||||||
funcDef: async dataArg => {
|
funcDef: async (dataArg, socketConnectionArg) => {
|
||||||
return dataArg;
|
return dataArg;
|
||||||
},
|
},
|
||||||
funcName: 'testFunction1'
|
funcName: 'testFunction1'
|
||||||
});
|
});
|
||||||
|
testSmartsocket.addSocketFunction(testSocketFunction1);
|
||||||
|
console.log(testSmartsocket.socketFunctions);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('should start listening when .started is called', async () => {
|
||||||
|
await testSmartsocket.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
// class SmartsocketClient
|
// class SmartsocketClient
|
||||||
tap.test('should react to a new websocket connection from client', async () => {
|
tap.test('should react to a new websocket connection from client', async () => {
|
||||||
const done = smartq.defer();
|
|
||||||
testSmartsocketClient = new smartsocket.SmartsocketClient({
|
testSmartsocketClient = new smartsocket.SmartsocketClient({
|
||||||
port: testConfig.port,
|
port: testConfig.port,
|
||||||
url: 'http://localhost',
|
url: 'http://localhost',
|
||||||
@ -56,26 +57,15 @@ tap.test('should react to a new websocket connection from client', async () => {
|
|||||||
alias: 'testClient1',
|
alias: 'testClient1',
|
||||||
role: 'testRole1'
|
role: 'testRole1'
|
||||||
});
|
});
|
||||||
testSmartsocketClient.connect().then(() => {
|
testSmartsocketClient.addSocketFunction(testSocketFunction1);
|
||||||
done.resolve();
|
console.log(testSmartsocketClient.socketFunctions);
|
||||||
|
await testSmartsocketClient.connect();
|
||||||
});
|
});
|
||||||
await done.promise;
|
|
||||||
});
|
tap.test('client should disconnect and reconnect', async tools => {
|
||||||
tap.test('client should disconnect and reconnect', async () => {
|
await testSmartsocketClient.disconnect();
|
||||||
let done = smartq.defer();
|
await tools.delayFor(100);
|
||||||
testSmartsocketClient
|
await testSmartsocketClient.connect();
|
||||||
.disconnect()
|
|
||||||
.then(() => {
|
|
||||||
let done = smartq.defer();
|
|
||||||
setTimeout(() => {
|
|
||||||
testSmartsocketClient.connect().then(done.resolve);
|
|
||||||
}, 0);
|
|
||||||
return done.promise;
|
|
||||||
})
|
|
||||||
.then(() => {
|
|
||||||
done.resolve();
|
|
||||||
});
|
|
||||||
await done.promise;
|
|
||||||
});
|
});
|
||||||
|
|
||||||
tap.test('2 clients should connect in parallel', async () => {
|
tap.test('2 clients should connect in parallel', async () => {
|
||||||
@ -83,37 +73,17 @@ tap.test('2 clients should connect in parallel', async () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
tap.test('should be able to make a functionCall from client to server', async () => {
|
tap.test('should be able to make a functionCall from client to server', async () => {
|
||||||
let done = smartq.defer();
|
const response = await testSmartsocketClient.serverCall('testFunction1', {
|
||||||
testSmartsocketClient
|
|
||||||
.serverCall('testFunction1', {
|
|
||||||
value1: 'hello'
|
value1: 'hello'
|
||||||
})
|
|
||||||
.then(dataArg => {
|
|
||||||
console.log(dataArg);
|
|
||||||
done.resolve();
|
|
||||||
});
|
});
|
||||||
await done.promise;
|
console.log(response);
|
||||||
});
|
});
|
||||||
|
|
||||||
tap.test('should be able to make a functionCall from server to client', async () => {
|
tap.test('should be able to make a functionCall from server to client', async () => {
|
||||||
let done = smartq.defer();
|
const response = await testSmartsocketClient.serverCall('testFunction1', {
|
||||||
let targetSocket = (() => {
|
hi: 'hi there from client'
|
||||||
return smartsocket.allSocketConnections.find(socketConnectionArg => {
|
|
||||||
return socketConnectionArg.alias === 'testClient1';
|
|
||||||
});
|
|
||||||
})();
|
|
||||||
testSmartsocket
|
|
||||||
.clientCall(
|
|
||||||
'testFunction1',
|
|
||||||
{
|
|
||||||
value1: 'helloFromServer'
|
|
||||||
},
|
|
||||||
targetSocket
|
|
||||||
)
|
|
||||||
.then(dataArg => {
|
|
||||||
console.log(dataArg);
|
|
||||||
done.resolve();
|
|
||||||
});
|
});
|
||||||
|
console.log(response);
|
||||||
});
|
});
|
||||||
|
|
||||||
// terminate
|
// terminate
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
import * as plugins from './smartsocket.plugins';
|
||||||
import * as helpers from './smartsocket.helpers';
|
|
||||||
|
|
||||||
// classes
|
// classes
|
||||||
import { Objectmap } from '@pushrocks/lik';
|
import { Objectmap } from '@pushrocks/lik';
|
||||||
@ -13,7 +12,7 @@ import { SocketServer } from './smartsocket.classes.socketserver';
|
|||||||
import * as SocketIO from 'socket.io';
|
import * as SocketIO from 'socket.io';
|
||||||
|
|
||||||
export interface ISmartsocketConstructorOptions {
|
export interface ISmartsocketConstructorOptions {
|
||||||
port: number;
|
port?: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Smartsocket {
|
export class Smartsocket {
|
||||||
@ -21,6 +20,8 @@ export class Smartsocket {
|
|||||||
public io: SocketIO.Server;
|
public io: SocketIO.Server;
|
||||||
public openSockets = new Objectmap<SocketConnection>();
|
public openSockets = new Objectmap<SocketConnection>();
|
||||||
public socketRoles = new Objectmap<SocketRole>();
|
public socketRoles = new Objectmap<SocketRole>();
|
||||||
|
public socketFunctions = new Objectmap<SocketFunction>();
|
||||||
|
public socketRequests = new Objectmap<SocketRequest>();
|
||||||
|
|
||||||
private socketServer = new SocketServer(this);
|
private socketServer = new SocketServer(this);
|
||||||
|
|
||||||
@ -29,7 +30,9 @@ export class Smartsocket {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// tslint:disable-next-line:member-ordering
|
// tslint:disable-next-line:member-ordering
|
||||||
public setExternalServer = this.socketServer.setExternalServer;
|
public async setExternalServer(serverType: 'smartexpress', serverArg: any) {
|
||||||
|
await this.socketServer.setExternalServer(serverType, serverArg);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* starts smartsocket
|
* starts smartsocket
|
||||||
@ -72,7 +75,7 @@ export class Smartsocket {
|
|||||||
targetSocketConnectionArg: SocketConnection
|
targetSocketConnectionArg: SocketConnection
|
||||||
) {
|
) {
|
||||||
const done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
const socketRequest = new SocketRequest({
|
const socketRequest = new SocketRequest(this, {
|
||||||
funcCallData: {
|
funcCallData: {
|
||||||
funcDataArg: dataArg,
|
funcDataArg: dataArg,
|
||||||
funcName: functionNameArg
|
funcName: functionNameArg
|
||||||
@ -81,8 +84,8 @@ export class Smartsocket {
|
|||||||
shortId: plugins.shortid.generate(),
|
shortId: plugins.shortid.generate(),
|
||||||
side: 'requesting'
|
side: 'requesting'
|
||||||
});
|
});
|
||||||
socketRequest.dispatch().then((dataArg: ISocketFunctionCall) => {
|
socketRequest.dispatch().then((dataArg2: ISocketFunctionCall) => {
|
||||||
done.resolve(dataArg.funcDataArg);
|
done.resolve(dataArg2.funcDataArg);
|
||||||
});
|
});
|
||||||
const result = await done.promise;
|
const result = await done.promise;
|
||||||
return result;
|
return result;
|
||||||
@ -98,6 +101,10 @@ export class Smartsocket {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public addSocketFunction(socketFunction: SocketFunction) {
|
||||||
|
this.socketFunctions.add(socketFunction);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the standard handler for new socket connections
|
* the standard handler for new socket connections
|
||||||
*/
|
*/
|
||||||
|
@ -3,6 +3,7 @@ import * as plugins from './smartsocket.plugins';
|
|||||||
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
||||||
import { ISocketFunctionCall, SocketFunction } from './smartsocket.classes.socketfunction';
|
import { ISocketFunctionCall, SocketFunction } from './smartsocket.classes.socketfunction';
|
||||||
import { ISocketRequestDataObject, SocketRequest } from './smartsocket.classes.socketrequest';
|
import { ISocketRequestDataObject, SocketRequest } from './smartsocket.classes.socketrequest';
|
||||||
|
import { SocketRole } from './smartsocket.classes.socketrole';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* interface for class SmartsocketClient
|
* interface for class SmartsocketClient
|
||||||
@ -16,12 +17,17 @@ export interface ISmartsocketClientOptions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export class SmartsocketClient {
|
export class SmartsocketClient {
|
||||||
alias: string;
|
public alias: string;
|
||||||
role: string;
|
public role: string;
|
||||||
socketConnection: SocketConnection;
|
public socketConnection: SocketConnection;
|
||||||
serverUrl: string;
|
public serverUrl: string;
|
||||||
serverPort: number;
|
public serverPort: number;
|
||||||
serverPassword: string;
|
public serverPassword: string;
|
||||||
|
|
||||||
|
public socketFunctions = new plugins.lik.Objectmap<SocketFunction>();
|
||||||
|
public socketRequests = new plugins.lik.Objectmap<SocketRequest>();
|
||||||
|
public socketRoles = new plugins.lik.Objectmap<SocketRole>();
|
||||||
|
|
||||||
constructor(optionsArg: ISmartsocketClientOptions) {
|
constructor(optionsArg: ISmartsocketClientOptions) {
|
||||||
this.alias = optionsArg.alias;
|
this.alias = optionsArg.alias;
|
||||||
this.role = optionsArg.role;
|
this.role = optionsArg.role;
|
||||||
@ -30,19 +36,23 @@ export class SmartsocketClient {
|
|||||||
this.serverPassword = optionsArg.password;
|
this.serverPassword = optionsArg.password;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public addSocketFunction(socketFunction: SocketFunction) {
|
||||||
|
this.socketFunctions.add(socketFunction);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* connect the client to the server
|
* connect the client to the server
|
||||||
*/
|
*/
|
||||||
connect() {
|
public connect() {
|
||||||
let done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
plugins.smartlog.defaultLogger.log('info', 'trying to connect...');
|
plugins.smartlog.defaultLogger.log('info', 'trying to connect...');
|
||||||
let socketUrl = `${this.serverUrl}:${this.serverPort}`;
|
const socketUrl = `${this.serverUrl}:${this.serverPort}`;
|
||||||
this.socketConnection = new SocketConnection({
|
this.socketConnection = new SocketConnection({
|
||||||
alias: this.alias,
|
alias: this.alias,
|
||||||
authenticated: false,
|
authenticated: false,
|
||||||
role: undefined,
|
role: undefined,
|
||||||
side: 'client',
|
side: 'client',
|
||||||
smartsocketHost: null,
|
smartsocketHost: this,
|
||||||
socket: plugins.socketIoClient(socketUrl, { multiplex: false })
|
socket: plugins.socketIoClient(socketUrl, { multiplex: false })
|
||||||
});
|
});
|
||||||
this.socketConnection.socket.on('requestAuth', () => {
|
this.socketConnection.socket.on('requestAuth', () => {
|
||||||
@ -62,8 +72,8 @@ export class SmartsocketClient {
|
|||||||
return done.promise;
|
return done.promise;
|
||||||
}
|
}
|
||||||
|
|
||||||
disconnect() {
|
public disconnect() {
|
||||||
let done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
this.socketConnection.socket.disconnect();
|
this.socketConnection.socket.disconnect();
|
||||||
this.socketConnection = undefined;
|
this.socketConnection = undefined;
|
||||||
plugins.smartlog.defaultLogger.log('ok', 'disconnected!');
|
plugins.smartlog.defaultLogger.log('ok', 'disconnected!');
|
||||||
@ -71,9 +81,9 @@ export class SmartsocketClient {
|
|||||||
return done.promise;
|
return done.promise;
|
||||||
}
|
}
|
||||||
|
|
||||||
serverCall(functionNameArg: string, dataArg: any) {
|
public serverCall(functionNameArg: string, dataArg: any) {
|
||||||
let done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
let socketRequest = new SocketRequest({
|
const socketRequest = new SocketRequest(this, {
|
||||||
side: 'requesting',
|
side: 'requesting',
|
||||||
originSocketConnection: this.socketConnection,
|
originSocketConnection: this.socketConnection,
|
||||||
shortId: plugins.shortid.generate(),
|
shortId: plugins.shortid.generate(),
|
||||||
@ -82,8 +92,8 @@ export class SmartsocketClient {
|
|||||||
funcDataArg: dataArg
|
funcDataArg: dataArg
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
socketRequest.dispatch().then((dataArg: ISocketFunctionCall) => {
|
socketRequest.dispatch().then((dataArg2: ISocketFunctionCall) => {
|
||||||
done.resolve(dataArg.funcDataArg);
|
done.resolve(dataArg2.funcDataArg);
|
||||||
});
|
});
|
||||||
return done.promise;
|
return done.promise;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
import * as plugins from './smartsocket.plugins';
|
||||||
import * as helpers from './smartsocket.helpers';
|
|
||||||
|
|
||||||
import { Objectmap } from '@pushrocks/lik';
|
import { Objectmap } from '@pushrocks/lik';
|
||||||
|
|
||||||
@ -9,12 +8,12 @@ import { SocketFunction } from './smartsocket.classes.socketfunction';
|
|||||||
import {
|
import {
|
||||||
SocketRequest,
|
SocketRequest,
|
||||||
ISocketRequestDataObject,
|
ISocketRequestDataObject,
|
||||||
allSocketRequests
|
|
||||||
} from './smartsocket.classes.socketrequest';
|
} from './smartsocket.classes.socketrequest';
|
||||||
import { SocketRole } from './smartsocket.classes.socketrole';
|
import { SocketRole } from './smartsocket.classes.socketrole';
|
||||||
|
|
||||||
// socket.io
|
// socket.io
|
||||||
import * as SocketIO from 'socket.io';
|
import * as SocketIO from 'socket.io';
|
||||||
|
import { SmartsocketClient } from './smartsocket.classes.smartsocketclient';
|
||||||
|
|
||||||
// export interfaces
|
// export interfaces
|
||||||
|
|
||||||
@ -31,7 +30,7 @@ export interface ISocketConnectionConstructorOptions {
|
|||||||
authenticated: boolean;
|
authenticated: boolean;
|
||||||
role: SocketRole;
|
role: SocketRole;
|
||||||
side: TSocketConnectionSide;
|
side: TSocketConnectionSide;
|
||||||
smartsocketHost: Smartsocket;
|
smartsocketHost: Smartsocket | SmartsocketClient;
|
||||||
socket: SocketIO.Socket | SocketIOClient.Socket;
|
socket: SocketIO.Socket | SocketIOClient.Socket;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,18 +50,18 @@ export let allSocketConnections = new Objectmap<SocketConnection>();
|
|||||||
* class SocketConnection represents a websocket connection
|
* class SocketConnection represents a websocket connection
|
||||||
*/
|
*/
|
||||||
export class SocketConnection {
|
export class SocketConnection {
|
||||||
alias: string;
|
public alias: string;
|
||||||
side: TSocketConnectionSide;
|
public side: TSocketConnectionSide;
|
||||||
authenticated: boolean = false;
|
public authenticated: boolean = false;
|
||||||
role: SocketRole;
|
public role: SocketRole;
|
||||||
smartsocketHost: Smartsocket;
|
public smartsocketRef: Smartsocket | SmartsocketClient;
|
||||||
socket: any; // SocketIO.Socket | SocketIOClient.Socket
|
public socket: SocketIO.Socket | SocketIOClient.Socket;
|
||||||
constructor(optionsArg: ISocketConnectionConstructorOptions) {
|
constructor(optionsArg: ISocketConnectionConstructorOptions) {
|
||||||
this.alias = optionsArg.alias;
|
this.alias = optionsArg.alias;
|
||||||
this.authenticated = optionsArg.authenticated;
|
this.authenticated = optionsArg.authenticated;
|
||||||
this.role = optionsArg.role;
|
this.role = optionsArg.role;
|
||||||
this.side = optionsArg.side;
|
this.side = optionsArg.side;
|
||||||
this.smartsocketHost = optionsArg.smartsocketHost;
|
this.smartsocketRef = optionsArg.smartsocketHost;
|
||||||
this.socket = optionsArg.socket;
|
this.socket = optionsArg.socket;
|
||||||
|
|
||||||
// standard behaviour that is always true
|
// standard behaviour that is always true
|
||||||
@ -82,19 +81,19 @@ export class SocketConnection {
|
|||||||
/**
|
/**
|
||||||
* authenticate the socket
|
* authenticate the socket
|
||||||
*/
|
*/
|
||||||
authenticate() {
|
public authenticate() {
|
||||||
let done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
this.socket.on('dataAuth', (dataArg: ISocketConnectionAuthenticationObject) => {
|
this.socket.on('dataAuth', (dataArg: ISocketConnectionAuthenticationObject) => {
|
||||||
plugins.smartlog.defaultLogger.log(
|
plugins.smartlog.defaultLogger.log(
|
||||||
'info',
|
'info',
|
||||||
'received authentication data. now hashing and comparing...'
|
'received authentication data. now hashing and comparing...'
|
||||||
);
|
);
|
||||||
this.socket.removeListener('dataAuth', () => {});
|
this.socket.removeListener('dataAuth', () => {});
|
||||||
if (helpers.checkPasswordForRole(dataArg, this.smartsocketHost)) {
|
if (SocketRole.checkPasswordForRole(dataArg, this.smartsocketRef)) {
|
||||||
// TODO: authenticate password
|
// TODO: authenticate password
|
||||||
this.alias = dataArg.alias;
|
this.alias = dataArg.alias;
|
||||||
this.authenticated = true;
|
this.authenticated = true;
|
||||||
this.role = helpers.getSocketRoleByName(dataArg.role, this.smartsocketHost);
|
this.role = SocketRole.getSocketRoleByName(this.smartsocketRef, dataArg.role);
|
||||||
this.socket.emit('authenticated');
|
this.socket.emit('authenticated');
|
||||||
plugins.smartlog.defaultLogger.log(
|
plugins.smartlog.defaultLogger.log(
|
||||||
'ok',
|
'ok',
|
||||||
@ -116,20 +115,20 @@ export class SocketConnection {
|
|||||||
/**
|
/**
|
||||||
* listen to function requests
|
* listen to function requests
|
||||||
*/
|
*/
|
||||||
listenToFunctionRequests() {
|
public listenToFunctionRequests() {
|
||||||
let done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
if (this.authenticated) {
|
if (this.authenticated) {
|
||||||
this.socket.on('function', (dataArg: ISocketRequestDataObject) => {
|
this.socket.on('function', (dataArg: ISocketRequestDataObject) => {
|
||||||
// check if requested function is available to the socket's scope
|
// check if requested function is available to the socket's scope
|
||||||
plugins.smartlog.defaultLogger.log('info', 'function request received');
|
plugins.smartlog.defaultLogger.log('info', 'function request received');
|
||||||
let referencedFunction: SocketFunction = this.role.allowedFunctions.find(
|
const referencedFunction: SocketFunction = this.role.allowedFunctions.find(
|
||||||
socketFunctionArg => {
|
socketFunctionArg => {
|
||||||
return socketFunctionArg.name === dataArg.funcCallData.funcName;
|
return socketFunctionArg.name === dataArg.funcCallData.funcName;
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
if (referencedFunction !== undefined) {
|
if (referencedFunction !== undefined) {
|
||||||
plugins.smartlog.defaultLogger.log('ok', 'function in access scope');
|
plugins.smartlog.defaultLogger.log('ok', 'function in access scope');
|
||||||
let localSocketRequest = new SocketRequest({
|
const localSocketRequest = new SocketRequest(this.smartsocketRef, {
|
||||||
side: 'responding',
|
side: 'responding',
|
||||||
originSocketConnection: this,
|
originSocketConnection: this,
|
||||||
shortId: dataArg.shortId,
|
shortId: dataArg.shortId,
|
||||||
@ -148,7 +147,7 @@ export class SocketConnection {
|
|||||||
'info',
|
'info',
|
||||||
`received response for request with id ${dataArg.shortId}`
|
`received response for request with id ${dataArg.shortId}`
|
||||||
);
|
);
|
||||||
let targetSocketRequest = helpers.getSocketRequestById(dataArg.shortId);
|
const targetSocketRequest = SocketRequest.getSocketRequestById(this.smartsocketRef, dataArg.shortId);
|
||||||
targetSocketRequest.handleResponse(dataArg);
|
targetSocketRequest.handleResponse(dataArg);
|
||||||
});
|
});
|
||||||
plugins.smartlog.defaultLogger.log(
|
plugins.smartlog.defaultLogger.log(
|
||||||
@ -157,7 +156,7 @@ export class SocketConnection {
|
|||||||
);
|
);
|
||||||
done.resolve(this);
|
done.resolve(this);
|
||||||
} else {
|
} else {
|
||||||
let errMessage: 'socket needs to be authenticated first';
|
const errMessage = 'socket needs to be authenticated first';
|
||||||
plugins.smartlog.defaultLogger.log('error', errMessage);
|
plugins.smartlog.defaultLogger.log('error', errMessage);
|
||||||
done.reject(errMessage);
|
done.reject(errMessage);
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,9 @@ import * as plugins from './smartsocket.plugins';
|
|||||||
// import classes
|
// import classes
|
||||||
import { Objectmap } from '@pushrocks/lik';
|
import { Objectmap } from '@pushrocks/lik';
|
||||||
import { SocketRole } from './smartsocket.classes.socketrole';
|
import { SocketRole } from './smartsocket.classes.socketrole';
|
||||||
|
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
||||||
|
import { Smartsocket } from './smartsocket.classes.smartsocket';
|
||||||
|
import { SmartsocketClient } from './smartsocket.classes.smartsocketclient';
|
||||||
|
|
||||||
// export interfaces
|
// export interfaces
|
||||||
|
|
||||||
@ -11,7 +14,7 @@ import { SocketRole } from './smartsocket.classes.socketrole';
|
|||||||
*/
|
*/
|
||||||
export interface ISocketFunctionConstructorOptions {
|
export interface ISocketFunctionConstructorOptions {
|
||||||
funcName: string;
|
funcName: string;
|
||||||
funcDef: any;
|
funcDef: TFuncDef;
|
||||||
allowedRoles: SocketRole[]; // all roles that are allowed to execute a SocketFunction
|
allowedRoles: SocketRole[]; // all roles that are allowed to execute a SocketFunction
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -26,12 +29,7 @@ export interface ISocketFunctionCall {
|
|||||||
/**
|
/**
|
||||||
* interface for function definition of SocketFunction
|
* interface for function definition of SocketFunction
|
||||||
*/
|
*/
|
||||||
export interface IFuncDef {
|
export type TFuncDef = (dataArg: any, connectionArg: SocketConnection) => PromiseLike<any>;
|
||||||
(dataArg: any): PromiseLike<any>;
|
|
||||||
}
|
|
||||||
|
|
||||||
// export objects
|
|
||||||
export let allSocketFunctions = new Objectmap<SocketFunction>();
|
|
||||||
|
|
||||||
// export classes
|
// export classes
|
||||||
|
|
||||||
@ -39,9 +37,18 @@ export let allSocketFunctions = new Objectmap<SocketFunction>();
|
|||||||
* class that respresents a function that can be transparently called using a SocketConnection
|
* class that respresents a function that can be transparently called using a SocketConnection
|
||||||
*/
|
*/
|
||||||
export class SocketFunction {
|
export class SocketFunction {
|
||||||
name: string;
|
// STATIC
|
||||||
funcDef: IFuncDef;
|
public static getSocketFunctionByName (smartsocketRefArg: Smartsocket | SmartsocketClient, functionNameArg: string): SocketFunction {
|
||||||
roles: SocketRole[];
|
console.log(smartsocketRefArg.socketFunctions);
|
||||||
|
return smartsocketRefArg.socketFunctions.find(socketFunctionArg => {
|
||||||
|
return socketFunctionArg.name === functionNameArg;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// INSTANCE
|
||||||
|
public name: string;
|
||||||
|
public funcDef: TFuncDef;
|
||||||
|
public roles: SocketRole[];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the constructor for SocketFunction
|
* the constructor for SocketFunction
|
||||||
@ -50,20 +57,19 @@ export class SocketFunction {
|
|||||||
this.name = optionsArg.funcName;
|
this.name = optionsArg.funcName;
|
||||||
this.funcDef = optionsArg.funcDef;
|
this.funcDef = optionsArg.funcDef;
|
||||||
this.roles = optionsArg.allowedRoles;
|
this.roles = optionsArg.allowedRoles;
|
||||||
for (let socketRoleArg of this.roles) {
|
for (const socketRoleArg of this.roles) {
|
||||||
this._notifyRole(socketRoleArg);
|
this._notifyRole(socketRoleArg);
|
||||||
}
|
}
|
||||||
allSocketFunctions.add(this); // map instance with Objectmap
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* invokes the function of this SocketFunction
|
* invokes the function of this SocketFunction
|
||||||
*/
|
*/
|
||||||
invoke(dataArg: ISocketFunctionCall): Promise<any> {
|
public invoke(dataArg: ISocketFunctionCall, socketConnectionArg: SocketConnection): Promise<any> {
|
||||||
let done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
if (dataArg.funcName === this.name) {
|
if (dataArg.funcName === this.name) {
|
||||||
this.funcDef(dataArg.funcDataArg).then((resultData: any) => {
|
this.funcDef(dataArg.funcDataArg, socketConnectionArg).then((resultData: any) => {
|
||||||
let funcResponseData: ISocketFunctionCall = {
|
const funcResponseData: ISocketFunctionCall = {
|
||||||
funcName: this.name,
|
funcName: this.name,
|
||||||
funcDataArg: resultData
|
funcDataArg: resultData
|
||||||
};
|
};
|
||||||
|
@ -1,13 +1,14 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
import * as plugins from './smartsocket.plugins';
|
||||||
import * as helpers from './smartsocket.helpers';
|
|
||||||
|
|
||||||
// import interfaces
|
// import interfaces
|
||||||
import { ISocketFunctionCall } from './smartsocket.classes.socketfunction';
|
import { SocketFunction, ISocketFunctionCall } from './smartsocket.classes.socketfunction';
|
||||||
|
|
||||||
// import classes
|
// import classes
|
||||||
import { Objectmap } from '@pushrocks/lik';
|
import { Objectmap } from '@pushrocks/lik';
|
||||||
import { SocketFunction } from './smartsocket.classes.socketfunction';
|
|
||||||
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
import { SocketConnection } from './smartsocket.classes.socketconnection';
|
||||||
|
import { defaultLogger } from '@pushrocks/smartlog';
|
||||||
|
import { Smartsocket } from './smartsocket.classes.smartsocket';
|
||||||
|
import { SmartsocketClient } from './smartsocket.classes.smartsocketclient';
|
||||||
|
|
||||||
// export interfaces
|
// export interfaces
|
||||||
export type TSocketRequestStatus = 'new' | 'pending' | 'finished';
|
export type TSocketRequestStatus = 'new' | 'pending' | 'finished';
|
||||||
@ -32,23 +33,36 @@ export interface ISocketRequestDataObject {
|
|||||||
responseTimeout?: number;
|
responseTimeout?: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
// export objects
|
|
||||||
export let allSocketRequests = new Objectmap<SocketRequest>();
|
|
||||||
|
|
||||||
// export classes
|
// export classes
|
||||||
export class SocketRequest {
|
export class SocketRequest {
|
||||||
status: TSocketRequestStatus = 'new';
|
// STATIC
|
||||||
side: TSocketRequestSide;
|
public static getSocketRequestById(
|
||||||
shortid: string;
|
smartsocketRef: Smartsocket | SmartsocketClient,
|
||||||
originSocketConnection: SocketConnection;
|
shortIdArg: string
|
||||||
funcCallData: ISocketFunctionCall;
|
): SocketRequest {
|
||||||
done = plugins.smartpromise.defer();
|
return smartsocketRef.socketRequests.find(socketRequestArg => {
|
||||||
constructor(optionsArg: SocketRequestConstructorOptions) {
|
return socketRequestArg.shortid === shortIdArg;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// INSTANCE
|
||||||
|
public status: TSocketRequestStatus = 'new';
|
||||||
|
public side: TSocketRequestSide;
|
||||||
|
public shortid: string;
|
||||||
|
public originSocketConnection: SocketConnection;
|
||||||
|
public funcCallData: ISocketFunctionCall;
|
||||||
|
public done = plugins.smartpromise.defer();
|
||||||
|
|
||||||
|
public smartsocketRef: Smartsocket | SmartsocketClient;
|
||||||
|
|
||||||
|
|
||||||
|
constructor(smartsocketRefArg: Smartsocket | SmartsocketClient, optionsArg: SocketRequestConstructorOptions) {
|
||||||
|
this.smartsocketRef = smartsocketRefArg;
|
||||||
this.side = optionsArg.side;
|
this.side = optionsArg.side;
|
||||||
this.shortid = optionsArg.shortId;
|
this.shortid = optionsArg.shortId;
|
||||||
this.funcCallData = optionsArg.funcCallData;
|
this.funcCallData = optionsArg.funcCallData;
|
||||||
this.originSocketConnection = optionsArg.originSocketConnection;
|
this.originSocketConnection = optionsArg.originSocketConnection;
|
||||||
allSocketRequests.add(this);
|
this.smartsocketRef.socketRequests.add(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// requesting --------------------------
|
// requesting --------------------------
|
||||||
@ -56,8 +70,8 @@ export class SocketRequest {
|
|||||||
/**
|
/**
|
||||||
* dispatches a socketrequest from the requesting to the receiving side
|
* dispatches a socketrequest from the requesting to the receiving side
|
||||||
*/
|
*/
|
||||||
dispatch() {
|
public dispatch() {
|
||||||
let requestData: ISocketRequestDataObject = {
|
const requestData: ISocketRequestDataObject = {
|
||||||
funcCallData: this.funcCallData,
|
funcCallData: this.funcCallData,
|
||||||
shortId: this.shortid
|
shortId: this.shortid
|
||||||
};
|
};
|
||||||
@ -68,10 +82,10 @@ export class SocketRequest {
|
|||||||
/**
|
/**
|
||||||
* handles the response that is received by the requesting side
|
* handles the response that is received by the requesting side
|
||||||
*/
|
*/
|
||||||
handleResponse(responseDataArg: ISocketRequestDataObject) {
|
public handleResponse(responseDataArg: ISocketRequestDataObject) {
|
||||||
plugins.smartlog.defaultLogger.log('info', 'handling response!');
|
plugins.smartlog.defaultLogger.log('info', 'handling response!');
|
||||||
this.done.resolve(responseDataArg.funcCallData);
|
this.done.resolve(responseDataArg.funcCallData);
|
||||||
allSocketRequests.remove(this);
|
this.smartsocketRef.socketRequests.remove(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// responding --------------------------
|
// responding --------------------------
|
||||||
@ -79,19 +93,29 @@ export class SocketRequest {
|
|||||||
/**
|
/**
|
||||||
* creates the response on the responding side
|
* creates the response on the responding side
|
||||||
*/
|
*/
|
||||||
createResponse() {
|
public async createResponse(): Promise<void> {
|
||||||
let targetSocketFunction: SocketFunction = helpers.getSocketFunctionByName(
|
const targetSocketFunction: SocketFunction = SocketFunction.getSocketFunctionByName(
|
||||||
|
this.smartsocketRef,
|
||||||
this.funcCallData.funcName
|
this.funcCallData.funcName
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (!targetSocketFunction) {
|
||||||
|
defaultLogger.log(
|
||||||
|
'warn',
|
||||||
|
`There is no SocketFunction defined for ${this.funcCallData.funcName}`
|
||||||
|
);
|
||||||
|
defaultLogger.log('warn', `So now response is being sent.`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
plugins.smartlog.defaultLogger.log('info', `invoking ${targetSocketFunction.name}`);
|
plugins.smartlog.defaultLogger.log('info', `invoking ${targetSocketFunction.name}`);
|
||||||
targetSocketFunction.invoke(this.funcCallData).then(resultData => {
|
targetSocketFunction.invoke(this.funcCallData, this.originSocketConnection).then(resultData => {
|
||||||
plugins.smartlog.defaultLogger.log('info', 'got resultData. Sending it to requesting party.');
|
plugins.smartlog.defaultLogger.log('info', 'got resultData. Sending it to requesting party.');
|
||||||
let requestData: ISocketRequestDataObject = {
|
const requestData: ISocketRequestDataObject = {
|
||||||
funcCallData: resultData,
|
funcCallData: resultData,
|
||||||
shortId: this.shortid
|
shortId: this.shortid
|
||||||
};
|
};
|
||||||
this.originSocketConnection.socket.emit('functionResponse', requestData);
|
this.originSocketConnection.socket.emit('functionResponse', requestData);
|
||||||
allSocketRequests.remove(this);
|
this.smartsocketRef.socketRequests.remove(this);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,12 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
import * as plugins from './smartsocket.plugins';
|
||||||
|
|
||||||
|
|
||||||
// import classes
|
// import classes
|
||||||
import { Objectmap } from '@pushrocks/lik';
|
import { Objectmap } from '@pushrocks/lik';
|
||||||
import { SocketFunction } from './smartsocket.classes.socketfunction';
|
import { SocketFunction } from './smartsocket.classes.socketfunction';
|
||||||
|
import { Smartsocket } from './smartsocket.classes.smartsocket';
|
||||||
|
import { SmartsocketClient } from './smartsocket.classes.smartsocketclient';
|
||||||
|
import { ISocketConnectionAuthenticationObject } from './smartsocket.classes.socketconnection';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* interface for class SocketRole
|
* interface for class SocketRole
|
||||||
@ -16,14 +20,34 @@ export interface SocketRoleOptions {
|
|||||||
* A socketrole defines access to certain routines.
|
* A socketrole defines access to certain routines.
|
||||||
*/
|
*/
|
||||||
export class SocketRole {
|
export class SocketRole {
|
||||||
name: string;
|
// STATIC
|
||||||
passwordHash: string;
|
public static getSocketRoleByName(
|
||||||
allowedFunctions = new Objectmap<SocketFunction>();
|
referenceSmartsocket: Smartsocket | SmartsocketClient,
|
||||||
|
socketRoleNameArg: string,
|
||||||
|
): SocketRole{
|
||||||
|
return referenceSmartsocket.socketRoles.find(socketRoleArg => {
|
||||||
|
return socketRoleArg.name === socketRoleNameArg;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public static checkPasswordForRole (
|
||||||
|
dataArg: ISocketConnectionAuthenticationObject,
|
||||||
|
referenceSmartsocket: Smartsocket | SmartsocketClient
|
||||||
|
): boolean {
|
||||||
|
const targetPasswordHash = SocketRole.getSocketRoleByName(referenceSmartsocket, dataArg.role).passwordHash;
|
||||||
|
const computedCompareHash = plugins.smarthash.sha256FromStringSync(dataArg.password);
|
||||||
|
return targetPasswordHash === computedCompareHash;
|
||||||
|
}
|
||||||
|
|
||||||
|
// INSTANCE
|
||||||
|
public name: string;
|
||||||
|
public passwordHash: string;
|
||||||
|
public allowedFunctions = new Objectmap<SocketFunction>();
|
||||||
constructor(optionsArg: SocketRoleOptions) {
|
constructor(optionsArg: SocketRoleOptions) {
|
||||||
this.name = optionsArg.name;
|
this.name = optionsArg.name;
|
||||||
this.passwordHash = optionsArg.passwordHash;
|
this.passwordHash = optionsArg.passwordHash;
|
||||||
}
|
}
|
||||||
addSocketFunction(socketFunctionArg: SocketFunction) {
|
public addSocketFunction(socketFunctionArg: SocketFunction) {
|
||||||
this.allowedFunctions.add(socketFunctionArg);
|
this.allowedFunctions.add(socketFunctionArg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,12 +23,12 @@ export class SocketServer {
|
|||||||
* starts the server with another server
|
* starts the server with another server
|
||||||
* also works with an express style server
|
* also works with an express style server
|
||||||
*/
|
*/
|
||||||
public async setExternalServer(serverType: 'express' | 'http', serverArg: any) {
|
public async setExternalServer(
|
||||||
if (serverType === 'http') {
|
serverType: 'smartexpress',
|
||||||
this.httpServer = serverArg;
|
serverArg: plugins.smartexpress.Server
|
||||||
} else if (serverType === 'express') {
|
) {
|
||||||
this.expressServer = serverArg;
|
await serverArg.startedPromise;
|
||||||
}
|
this.httpServer = serverArg.httpServer;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -37,14 +37,10 @@ export class SocketServer {
|
|||||||
public getServerForSocketIo() {
|
public getServerForSocketIo() {
|
||||||
if (this.httpServer) {
|
if (this.httpServer) {
|
||||||
return this.httpServer;
|
return this.httpServer;
|
||||||
} else if (this.expressServer) {
|
} else {
|
||||||
return this.expressServer;
|
|
||||||
} else if (!this.httpServer && !this.expressServer) {
|
|
||||||
this.httpServer = new http.Server();
|
this.httpServer = new http.Server();
|
||||||
this.standaloneServer = true;
|
this.standaloneServer = true;
|
||||||
return this.httpServer;
|
return this.httpServer;
|
||||||
} else {
|
|
||||||
throw new Error('no server specified!');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -55,7 +51,12 @@ export class SocketServer {
|
|||||||
const done = plugins.smartpromise.defer();
|
const done = plugins.smartpromise.defer();
|
||||||
|
|
||||||
// handle http servers
|
// handle http servers
|
||||||
|
// in case an external server has been set "this.standaloneServer" should be false
|
||||||
if (this.httpServer && this.standaloneServer) {
|
if (this.httpServer && this.standaloneServer) {
|
||||||
|
if (!this.smartsocket.options.port) {
|
||||||
|
console.log('there should be a port specifed for smartsocket!');
|
||||||
|
throw new Error('there should be a port specified for smartsocket');
|
||||||
|
}
|
||||||
this.httpServer.listen(this.smartsocket.options.port, () => {
|
this.httpServer.listen(this.smartsocket.options.port, () => {
|
||||||
console.log(`Server started in standalone mode on ${this.smartsocket.options.port}`);
|
console.log(`Server started in standalone mode on ${this.smartsocket.options.port}`);
|
||||||
done.resolve();
|
done.resolve();
|
||||||
|
@ -1,60 +0,0 @@
|
|||||||
import * as plugins from './smartsocket.plugins';
|
|
||||||
|
|
||||||
// classes
|
|
||||||
import { Smartsocket } from './smartsocket.classes.smartsocket';
|
|
||||||
import { SocketFunction, allSocketFunctions } from './smartsocket.classes.socketfunction';
|
|
||||||
import {
|
|
||||||
SocketConnection,
|
|
||||||
ISocketConnectionAuthenticationObject
|
|
||||||
} from './smartsocket.classes.socketconnection';
|
|
||||||
import {
|
|
||||||
SocketRequest,
|
|
||||||
allSocketRequests,
|
|
||||||
TSocketRequestSide
|
|
||||||
} from './smartsocket.classes.socketrequest';
|
|
||||||
import { SocketRole } from './smartsocket.classes.socketrole';
|
|
||||||
|
|
||||||
// SocketConnection helpers
|
|
||||||
export let checkPasswordForRole = (
|
|
||||||
dataArg: ISocketConnectionAuthenticationObject,
|
|
||||||
referenceSmartsocket: Smartsocket
|
|
||||||
): boolean => {
|
|
||||||
let targetPasswordHash = getSocketRoleByName(dataArg.role, referenceSmartsocket).passwordHash;
|
|
||||||
let computedCompareHash = plugins.smarthash.sha256FromStringSync(dataArg.password);
|
|
||||||
return targetPasswordHash === computedCompareHash;
|
|
||||||
};
|
|
||||||
|
|
||||||
// SocketFunction helpers
|
|
||||||
export let getSocketFunctionByName = (functionNameArg: string): SocketFunction => {
|
|
||||||
return allSocketFunctions.find(socketFunctionArg => {
|
|
||||||
return socketFunctionArg.name === functionNameArg;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
// SocketRequest helpers
|
|
||||||
|
|
||||||
/**
|
|
||||||
* get corresponding Socketrequest instance by shortId
|
|
||||||
*/
|
|
||||||
export let getSocketRequestById = (
|
|
||||||
shortIdArg: string,
|
|
||||||
requestSide?: TSocketRequestSide
|
|
||||||
): SocketRequest => {
|
|
||||||
return allSocketRequests.find(socketRequestArg => {
|
|
||||||
return socketRequestArg.shortid === shortIdArg;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
// SocketRole helpers
|
|
||||||
|
|
||||||
/**
|
|
||||||
* get corresponding SocketRole instance by name
|
|
||||||
*/
|
|
||||||
export let getSocketRoleByName = (
|
|
||||||
socketRoleNameArg: string,
|
|
||||||
referenceSmartsocket: Smartsocket
|
|
||||||
): SocketRole => {
|
|
||||||
return referenceSmartsocket.socketRoles.find(socketRoleArg => {
|
|
||||||
return socketRoleArg.name === socketRoleNameArg;
|
|
||||||
});
|
|
||||||
};
|
|
@ -2,9 +2,20 @@ import * as lik from '@pushrocks/lik';
|
|||||||
import * as smartlog from '@pushrocks/smartlog';
|
import * as smartlog from '@pushrocks/smartlog';
|
||||||
import * as smarthash from '@pushrocks/smarthash';
|
import * as smarthash from '@pushrocks/smarthash';
|
||||||
import * as smartdelay from '@pushrocks/smartdelay';
|
import * as smartdelay from '@pushrocks/smartdelay';
|
||||||
|
import * as smartexpress from '@pushrocks/smartexpress';
|
||||||
import * as smartpromise from '@pushrocks/smartpromise';
|
import * as smartpromise from '@pushrocks/smartpromise';
|
||||||
import * as shortid from 'shortid';
|
import * as shortid from 'shortid';
|
||||||
import * as socketIo from 'socket.io';
|
import socketIo from 'socket.io';
|
||||||
import * as socketIoClient from 'socket.io-client';
|
import socketIoClient from 'socket.io-client';
|
||||||
|
|
||||||
export { lik, smartlog, smarthash, smartdelay, smartpromise, shortid, socketIo, socketIoClient };
|
export {
|
||||||
|
lik,
|
||||||
|
smartlog,
|
||||||
|
smarthash,
|
||||||
|
smartdelay,
|
||||||
|
smartexpress,
|
||||||
|
smartpromise,
|
||||||
|
shortid,
|
||||||
|
socketIo,
|
||||||
|
socketIoClient
|
||||||
|
};
|
||||||
|
Reference in New Issue
Block a user