summaryrefslogtreecommitdiff
path: root/src/api/common/read-messaging-message.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/api/common/read-messaging-message.ts')
-rw-r--r--src/api/common/read-messaging-message.ts66
1 files changed, 0 insertions, 66 deletions
diff --git a/src/api/common/read-messaging-message.ts b/src/api/common/read-messaging-message.ts
deleted file mode 100644
index 8e5e5b2b68..0000000000
--- a/src/api/common/read-messaging-message.ts
+++ /dev/null
@@ -1,66 +0,0 @@
-import * as mongo from 'mongodb';
-import Message from '../models/messaging-message';
-import { IMessagingMessage as IMessage } from '../models/messaging-message';
-import publishUserStream from '../event';
-import { publishMessagingStream } from '../event';
-import { publishMessagingIndexStream } from '../event';
-
-/**
- * Mark as read message(s)
- */
-export default (
- user: string | mongo.ObjectID,
- otherparty: string | mongo.ObjectID,
- message: string | string[] | IMessage | IMessage[] | mongo.ObjectID | mongo.ObjectID[]
-) => new Promise<any>(async (resolve, reject) => {
-
- const userId = mongo.ObjectID.prototype.isPrototypeOf(user)
- ? user
- : new mongo.ObjectID(user);
-
- const otherpartyId = mongo.ObjectID.prototype.isPrototypeOf(otherparty)
- ? otherparty
- : new mongo.ObjectID(otherparty);
-
- const ids: mongo.ObjectID[] = Array.isArray(message)
- ? mongo.ObjectID.prototype.isPrototypeOf(message[0])
- ? (message as mongo.ObjectID[])
- : typeof message[0] === 'string'
- ? (message as string[]).map(m => new mongo.ObjectID(m))
- : (message as IMessage[]).map(m => m._id)
- : mongo.ObjectID.prototype.isPrototypeOf(message)
- ? [(message as mongo.ObjectID)]
- : typeof message === 'string'
- ? [new mongo.ObjectID(message)]
- : [(message as IMessage)._id];
-
- // Update documents
- await Message.update({
- _id: { $in: ids },
- user_id: otherpartyId,
- recipient_id: userId,
- is_read: false
- }, {
- $set: {
- is_read: true
- }
- }, {
- multi: true
- });
-
- // Publish event
- publishMessagingStream(otherpartyId, userId, 'read', ids.map(id => id.toString()));
- publishMessagingIndexStream(userId, 'read', ids.map(id => id.toString()));
-
- // Calc count of my unread messages
- const count = await Message
- .count({
- recipient_id: userId,
- is_read: false
- });
-
- if (count == 0) {
- // 全ての(いままで未読だった)自分宛てのメッセージを(これで)読みましたよというイベントを発行
- publishUserStream(userId, 'read_all_messaging_messages');
- }
-});