summaryrefslogtreecommitdiff
path: root/src/server/api/stream/reversi.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2018-06-17 08:10:54 +0900
committersyuilo <syuilotan@yahoo.co.jp>2018-06-17 08:10:54 +0900
commit1ef66c962a1cea81dee4f5db32cd011feac7de44 (patch)
tree006945b7ae9d437cebb0fabc5eb5a849cff518c5 /src/server/api/stream/reversi.ts
parentAdd missing semicolon (diff)
downloadmisskey-1ef66c962a1cea81dee4f5db32cd011feac7de44.tar.gz
misskey-1ef66c962a1cea81dee4f5db32cd011feac7de44.tar.bz2
misskey-1ef66c962a1cea81dee4f5db32cd011feac7de44.zip
reversi :white_flower: :100:
Diffstat (limited to 'src/server/api/stream/reversi.ts')
-rw-r--r--src/server/api/stream/reversi.ts29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/server/api/stream/reversi.ts b/src/server/api/stream/reversi.ts
new file mode 100644
index 0000000000..35c6167364
--- /dev/null
+++ b/src/server/api/stream/reversi.ts
@@ -0,0 +1,29 @@
+import * as mongo from 'mongodb';
+import * as websocket from 'websocket';
+import * as redis from 'redis';
+import Matching, { pack } from '../../../models/reversi-matching';
+import publishUserStream from '../../../publishers/stream';
+
+export default function(request: websocket.request, connection: websocket.connection, subscriber: redis.RedisClient, user: any): void {
+ // Subscribe reversi stream
+ subscriber.subscribe(`misskey:reversi-stream:${user._id}`);
+ subscriber.on('message', (_, data) => {
+ connection.send(data);
+ });
+
+ connection.on('message', async (data) => {
+ const msg = JSON.parse(data.utf8Data);
+
+ switch (msg.type) {
+ case 'ping':
+ if (msg.id == null) return;
+ const matching = await Matching.findOne({
+ parentId: user._id,
+ childId: new mongo.ObjectID(msg.id)
+ });
+ if (matching == null) return;
+ publishUserStream(matching.childId, 'reversi_invited', await pack(matching, matching.childId));
+ break;
+ }
+ });
+}