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

90 lines
2.3 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-07-30 07:20:27 +09:00
import Xev from 'xev';
2016-12-29 07:49:51 +09:00
import MainStreamConnection from './stream';
2018-03-29 20:32:18 +09:00
import { ParsedUrlQuery } from 'querystring';
import authenticate from './authenticate';
import { EventEmitter } from 'events';
import config from '../../config';
2016-12-29 07:49:51 +09:00
module.exports = (server: http.Server) => {
// Init websocket server
2016-12-29 07:49:51 +09:00
const ws = new websocket.server({
httpServer: server
});
ws.on('request', async (request) => {
const q = request.resourceURL.query as ParsedUrlQuery;
const [user, app] = await authenticate(q.i as string);
2017-06-09 01:03:54 +09:00
2018-11-12 00:31:09 +09:00
const connection = request.accept();
let ev: EventEmitter;
if (config.redis) {
// Connect to Redis
const subscriber = redis.createClient(
config.redis.port, config.redis.host);
subscriber.subscribe('misskey');
ev = new EventEmitter();
subscriber.on('message', async (_, data) => {
const obj = JSON.parse(data);
ev.emit(obj.channel, obj.message);
});
connection.once('close', () => {
subscriber.unsubscribe();
subscriber.quit();
});
} else {
ev = new Xev();
}
const main = new MainStreamConnection(connection, ev, user, app);
2016-12-29 07:49:51 +09:00
2018-10-07 17:19:52 +09:00
// 後方互換性のため
if (request.resourceURL.pathname !== '/streaming') {
2018-10-08 00:58:10 +09:00
main.sendMessageToWsOverride = (type: string, payload: any) => {
2018-10-07 17:19:52 +09:00
if (type == 'channel') {
type = payload.type;
payload = payload.body;
}
2018-10-08 08:58:12 +09:00
if (type.startsWith('api:')) {
2018-10-08 09:02:11 +09:00
type = type.replace('api:', 'api-res:');
2018-10-08 08:58:12 +09:00
}
2018-10-07 17:19:52 +09:00
connection.send(JSON.stringify({
type: type,
body: payload
}));
};
2018-10-08 00:58:10 +09:00
2018-10-13 19:16:47 +09:00
main.connectChannel(Math.random().toString().substr(2, 8), null,
request.resourceURL.pathname === '/' ? 'homeTimeline' :
request.resourceURL.pathname === '/local-timeline' ? 'localTimeline' :
request.resourceURL.pathname === '/hybrid-timeline' ? 'hybridTimeline' :
request.resourceURL.pathname === '/global-timeline' ? 'globalTimeline' : null);
2018-10-09 03:29:11 +09:00
if (request.resourceURL.pathname === '/') {
2018-10-13 19:16:47 +09:00
main.connectChannel(Math.random().toString().substr(2, 8), null, 'main');
2018-10-09 03:29:11 +09:00
}
2018-10-07 17:19:52 +09:00
}
2018-07-30 07:20:27 +09:00
connection.once('close', () => {
ev.removeAllListeners();
main.dispose();
2016-12-29 07:49:51 +09:00
});
2018-09-17 09:07:46 +09:00
connection.on('message', async (data) => {
if (data.utf8Data == 'ping') {
connection.send('pong');
}
});
2016-12-29 07:49:51 +09:00
});
};