1
0
mirror of https://github.com/hotomoe/hotomoe synced 2024-12-29 05:58:06 +09:00
hotomoe/src/server/api/streaming.ts

90 lines
2.7 KiB
TypeScript
Raw Normal View History

2016-12-29 07:49:51 +09:00
import * as http from 'http';
import * as websocket from 'websocket';
2018-07-30 07:20:27 +09:00
import Xev from 'xev';
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';
import hashtagStream from './stream/hashtag';
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;
}
2018-07-30 07:20:27 +09:00
const ev = new Xev();
2016-12-29 07:49:51 +09:00
2018-07-30 07:20:27 +09:00
connection.once('close', () => {
ev.removeAllListeners();
2016-12-29 07:49:51 +09:00
});
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-07-30 07:20:27 +09:00
reversiGameStream(request, connection, ev, user);
2018-03-14 04:37:20 +09:00
return;
}
if (request.resourceURL.pathname === '/local-timeline') {
localTimelineStream(request, connection, ev, user);
return;
}
if (request.resourceURL.pathname === '/hashtag') {
hashtagStream(request, connection, ev, user);
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 :
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) {
2018-07-30 07:20:27 +09:00
channel(request, connection, ev, user, app);
2016-12-29 07:49:51 +09:00
} else {
connection.close();
}
});
};