1
0
mirror of https://github.com/hotomoe/hotomoe synced 2025-01-10 20:02:53 +09:00
hotomoe/src/server/api/streaming.ts

84 lines
2.6 KiB
TypeScript
Raw Normal View History

2016-12-29 07:49:51 +09:00
import * as http from 'http';
import * as websocket from 'websocket';
import * as redis from 'redis';
2018-04-02 13:15:53 +09:00
import config from '../../config';
2016-12-29 07:49:51 +09:00
import homeStream from './stream/home';
import localTimelineStream from './stream/local-timeline';
2018-07-11 14:33:03 +09:00
import hybridTimelineStream from './stream/hybrid-timeline';
import globalTimelineStream from './stream/global-timeline';
2018-04-26 11:02:15 +09:00
import userListStream from './stream/user-list';
2017-11-16 23:46:36 +09:00
import driveStream from './stream/drive';
2016-12-29 07:49:51 +09:00
import messagingStream from './stream/messaging';
2017-11-14 00:54:16 +09:00
import messagingIndexStream from './stream/messaging-index';
2018-07-09 21:15:49 +09:00
import reversiGameStream from './stream/games/reversi-game';
import reversiStream from './stream/games/reversi';
2018-06-09 04:14:26 +09:00
import serverStatsStream from './stream/server-stats';
import notesStatsStream from './stream/notes-stats';
2018-03-29 20:32:18 +09:00
import { ParsedUrlQuery } from 'querystring';
import authenticate from './authenticate';
2016-12-29 07:49:51 +09: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();
2018-06-09 04:14:26 +09:00
if (request.resourceURL.pathname === '/server-stats') {
serverStatsStream(request, connection);
return;
}
if (request.resourceURL.pathname === '/notes-stats') {
notesStatsStream(request, connection);
2017-06-09 01:03:54 +09:00
return;
}
2016-12-29 07:49:51 +09:00
// Connect to Redis
const subscriber = redis.createClient(
config.redis.port, config.redis.host);
connection.on('close', () => {
subscriber.unsubscribe();
subscriber.quit();
});
2018-03-29 20:32:18 +09:00
const q = request.resourceURL.query as ParsedUrlQuery;
const [user, app] = await authenticate(q.i as string);
2017-11-01 03:17:14 +09:00
2018-07-09 21:15:49 +09:00
if (request.resourceURL.pathname === '/games/reversi-game') {
2018-06-17 08:10:54 +09:00
reversiGameStream(request, connection, subscriber, user);
2018-03-14 04:37:20 +09:00
return;
}
2017-11-01 03:17:14 +09:00
if (user == null) {
connection.send('authentication-failed');
connection.close();
return;
}
const channel: any =
2016-12-29 07:49:51 +09:00
request.resourceURL.pathname === '/' ? homeStream :
request.resourceURL.pathname === '/local-timeline' ? localTimelineStream :
2018-07-11 14:33:03 +09:00
request.resourceURL.pathname === '/hybrid-timeline' ? hybridTimelineStream :
request.resourceURL.pathname === '/global-timeline' ? globalTimelineStream :
2018-04-26 11:02:15 +09:00
request.resourceURL.pathname === '/user-list' ? userListStream :
2017-11-16 23:46:36 +09:00
request.resourceURL.pathname === '/drive' ? driveStream :
2016-12-29 07:49:51 +09:00
request.resourceURL.pathname === '/messaging' ? messagingStream :
2017-11-14 00:54:16 +09:00
request.resourceURL.pathname === '/messaging-index' ? messagingIndexStream :
2018-07-09 21:15:49 +09:00
request.resourceURL.pathname === '/games/reversi' ? reversiStream :
2016-12-29 07:49:51 +09:00
null;
if (channel !== null) {
channel(request, connection, subscriber, user, app);
2016-12-29 07:49:51 +09:00
} else {
connection.close();
}
});
};