Sharkey/src/server/api/streaming.ts

121 lines
3 KiB
TypeScript
Raw Normal View History

2016-12-29 00:49:51 +02:00
import * as http from 'http';
import * as websocket from 'websocket';
import * as redis from 'redis';
2018-04-02 07:15:53 +03:00
import config from '../../config';
2018-03-29 14:32:18 +03:00
import { default as User, IUser } from '../../models/user';
import AccessToken from '../../models/access-token';
2017-01-06 04:07:42 +02:00
import isNativeToken from './common/is-native-token';
2016-12-29 00:49:51 +02:00
import homeStream from './stream/home';
2017-11-16 16:46:36 +02:00
import driveStream from './stream/drive';
2016-12-29 00:49:51 +02:00
import messagingStream from './stream/messaging';
2017-11-13 17:54:16 +02:00
import messagingIndexStream from './stream/messaging-index';
2018-03-07 04:40:40 +02:00
import othelloGameStream from './stream/othello-game';
2018-03-07 10:48:32 +02:00
import othelloStream from './stream/othello';
2017-06-08 19:03:54 +03:00
import serverStream from './stream/server';
2017-11-13 12:58:29 +02:00
import requestsStream from './stream/requests';
2017-10-31 20:17:14 +02:00
import channelStream from './stream/channel';
2018-03-29 14:32:18 +03:00
import { ParsedUrlQuery } from 'querystring';
2016-12-29 00:49:51 +02:00
module.exports = (server: http.Server) => {
/**
* Init websocket server
*/
const ws = new websocket.server({
httpServer: server
});
ws.on('request', async (request) => {
const connection = request.accept();
2017-06-08 19:03:54 +03:00
if (request.resourceURL.pathname === '/server') {
serverStream(request, connection);
return;
}
2017-11-13 12:58:29 +02:00
if (request.resourceURL.pathname === '/requests') {
requestsStream(request, connection);
return;
}
2016-12-29 00:49:51 +02:00
// Connect to Redis
const subscriber = redis.createClient(
config.redis.port, config.redis.host);
connection.on('close', () => {
subscriber.unsubscribe();
subscriber.quit();
});
2017-10-31 20:17:14 +02:00
if (request.resourceURL.pathname === '/channel') {
channelStream(request, connection, subscriber);
return;
}
2018-03-29 14:32:18 +03:00
const q = request.resourceURL.query as ParsedUrlQuery;
const user = await authenticate(q.i as string);
2017-10-31 20:17:14 +02:00
2018-03-13 21:37:20 +02:00
if (request.resourceURL.pathname === '/othello-game') {
othelloGameStream(request, connection, subscriber, user);
return;
}
2017-10-31 20:17:14 +02:00
if (user == null) {
connection.send('authentication-failed');
connection.close();
return;
}
2016-12-29 00:49:51 +02:00
const channel =
request.resourceURL.pathname === '/' ? homeStream :
2017-11-16 16:46:36 +02:00
request.resourceURL.pathname === '/drive' ? driveStream :
2016-12-29 00:49:51 +02:00
request.resourceURL.pathname === '/messaging' ? messagingStream :
2017-11-13 17:54:16 +02:00
request.resourceURL.pathname === '/messaging-index' ? messagingIndexStream :
2018-03-07 10:48:32 +02:00
request.resourceURL.pathname === '/othello' ? othelloStream :
2016-12-29 00:49:51 +02:00
null;
if (channel !== null) {
channel(request, connection, subscriber, user);
} else {
connection.close();
}
});
};
2017-09-16 08:30:44 +03:00
/**
*
* @param token
*/
function authenticate(token: string): Promise<IUser> {
2017-01-21 00:45:49 +02:00
if (token == null) {
return Promise.resolve(null);
}
return new Promise(async (resolve, reject) => {
2017-01-06 04:07:42 +02:00
if (isNativeToken(token)) {
2016-12-29 00:49:51 +02:00
// Fetch user
2017-09-16 08:30:44 +03:00
const user: IUser = await User
2016-12-29 00:49:51 +02:00
.findOne({
2018-03-27 10:51:12 +03:00
host: null,
2018-04-07 21:58:11 +03:00
'token': token
2016-12-29 00:49:51 +02:00
});
resolve(user);
} else {
const accessToken = await AccessToken.findOne({
2017-01-06 04:50:46 +02:00
hash: token
});
if (accessToken == null) {
2017-01-06 05:30:35 +02:00
return reject('invalid signature');
2016-12-29 00:49:51 +02:00
}
// Fetch user
2017-09-16 08:30:44 +03:00
const user: IUser = await User
2018-03-29 08:48:47 +03:00
.findOne({ _id: accessToken.userId });
2016-12-29 00:49:51 +02:00
resolve(user);
}
2016-12-29 00:49:51 +02:00
});
}