test for snyk
This commit is contained in:
parent
2133371677
commit
8bc111d9fa
11
src/helpers/clientHelpers.ts
Normal file
11
src/helpers/clientHelpers.ts
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
module.exports = {
|
||||||
|
clientExists: function (id: number) {
|
||||||
|
for (let client of this.clients) {
|
||||||
|
if (client.id == id) {
|
||||||
|
return client;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
@ -5,12 +5,10 @@ var path = require('path');
|
|||||||
var logPath = './logs/';
|
var logPath = './logs/';
|
||||||
|
|
||||||
const tsFormat = () => (new Date().toISOString());
|
const tsFormat = () => (new Date().toISOString());
|
||||||
|
const logFormat = format.combine(format.timestamp(), format.json())
|
||||||
|
|
||||||
const errorLog = createLogger({
|
const errorLog = createLogger({
|
||||||
format: format.combine(
|
format: logFormat,
|
||||||
format.timestamp(),
|
|
||||||
format.json()
|
|
||||||
),
|
|
||||||
transports: [
|
transports: [
|
||||||
new transports.File({
|
new transports.File({
|
||||||
filename: path.join(logPath, 'errors.log'),
|
filename: path.join(logPath, 'errors.log'),
|
||||||
@ -21,10 +19,7 @@ const errorLog = createLogger({
|
|||||||
});
|
});
|
||||||
|
|
||||||
const accessLog = createLogger({
|
const accessLog = createLogger({
|
||||||
format: format.combine(
|
format: logFormat,
|
||||||
format.timestamp(),
|
|
||||||
format.json()
|
|
||||||
),
|
|
||||||
transports: [
|
transports: [
|
||||||
new transports.File({
|
new transports.File({
|
||||||
filename: path.join(logPath, 'access.log'),
|
filename: path.join(logPath, 'access.log'),
|
||||||
|
@ -29,7 +29,7 @@ application.use('', routes);
|
|||||||
let clientManager = new ClientManager();
|
let clientManager = new ClientManager();
|
||||||
let channelManager = new ChannelManager();
|
let channelManager = new ChannelManager();
|
||||||
|
|
||||||
function startServer() {
|
function connectionListener() {
|
||||||
wss.on('connection', (ws: WebSocket, request: object, args: string) => {
|
wss.on('connection', (ws: WebSocket, request: object, args: string) => {
|
||||||
var data = JSON.parse(args).data
|
var data = JSON.parse(args).data
|
||||||
logger.accessLog.info(`Client Connected: ${data.user_id}`);
|
logger.accessLog.info(`Client Connected: ${data.user_id}`);
|
||||||
@ -54,48 +54,58 @@ function startServer() {
|
|||||||
|
|
||||||
ws.send('Hi there, welcome to braid, Measures Web Socket server.\nConnecting all our services!');
|
ws.send('Hi there, welcome to braid, Measures Web Socket server.\nConnecting all our services!');
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function verifyConnection(request: any) {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
var data = url.parse(request.url, true).query;
|
||||||
|
var token = data.token || (app.environment == 'development' ? app.devToken : '');
|
||||||
|
var accepted = true;
|
||||||
|
var result: string;
|
||||||
|
|
||||||
|
jwt.verify(token, app.secret, app.signOptions, function(err, decoded) {
|
||||||
|
if (err) {
|
||||||
|
console.log(err);
|
||||||
|
accepted = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
result = JSON.stringify(decoded)
|
||||||
|
accepted ? resolve(result) : reject('rejected');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function serverUpgrade() {
|
||||||
server.on('upgrade', async function upgrade(request, socket, head) {
|
server.on('upgrade', async function upgrade(request, socket, head) {
|
||||||
let args: {};
|
let args: {};
|
||||||
|
|
||||||
try {
|
try {
|
||||||
args = await verifyConnection()
|
args = await verifyConnection(request);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
socket.destroy();
|
socket.destroy();
|
||||||
logger.accessLog.info('Connection Terminated');
|
logger.accessLog.info('Connection Terminated');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
function verifyConnection() {
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
var data = url.parse(request.url, true).query;
|
|
||||||
var token = data.token || (app.environment == 'development' ? app.devToken : '');
|
|
||||||
var accepted = true;
|
|
||||||
var result: string;
|
|
||||||
|
|
||||||
jwt.verify(token, app.secret, app.signOptions, function(err, decoded) {
|
|
||||||
if (err) {
|
|
||||||
console.log(err);
|
|
||||||
accepted = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
result = JSON.stringify(decoded)
|
|
||||||
accepted ? resolve(result) : reject('rejected');
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
wss.handleUpgrade(request, socket, head, function done(ws) {
|
wss.handleUpgrade(request, socket, head, function done(ws) {
|
||||||
wss.emit('connection', ws, request, args);
|
wss.emit('connection', ws, request, args);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function listenForConnection() {
|
||||||
server.listen(app.port, () => {
|
server.listen(app.port, () => {
|
||||||
console.log(`Braid v${app.version} is running!\n`);
|
console.log(`Braid v${app.version} is running!\n`);
|
||||||
logger.accessLog.info(`Braid v${app.version} is running!\n`);
|
logger.accessLog.info(`Braid v${app.version} is running!\n`);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function startServer() {
|
||||||
|
connectionListener();
|
||||||
|
serverUpgrade();
|
||||||
|
listenForConnection();
|
||||||
|
}
|
||||||
|
|
||||||
startServer();
|
startServer();
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user