summaryrefslogtreecommitdiff
path: root/src/server/api/common/read-messaging-message.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/api/common/read-messaging-message.ts')
-rw-r--r--src/server/api/common/read-messaging-message.ts76
1 files changed, 21 insertions, 55 deletions
diff --git a/src/server/api/common/read-messaging-message.ts b/src/server/api/common/read-messaging-message.ts
index 9f1e7e6ab4..2cb5a1f87f 100644
--- a/src/server/api/common/read-messaging-message.ts
+++ b/src/server/api/common/read-messaging-message.ts
@@ -1,77 +1,43 @@
-import * as mongo from 'mongodb';
-import isObjectId from '../../../misc/is-objectid';
-import Message from '../../../models/messaging-message';
-import { IMessagingMessage as IMessage } from '../../../models/messaging-message';
import { publishMainStream } from '../../../services/stream';
import { publishMessagingStream } from '../../../services/stream';
import { publishMessagingIndexStream } from '../../../services/stream';
-import User from '../../../models/user';
+import { User } from '../../../models/entities/user';
+import { MessagingMessage } from '../../../models/entities/messaging-message';
+import { MessagingMessages } from '../../../models';
+import { In } from 'typeorm';
/**
* Mark messages as read
*/
-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 = isObjectId(user)
- ? user
- : new mongo.ObjectID(user);
-
- const otherpartyId = isObjectId(otherparty)
- ? otherparty
- : new mongo.ObjectID(otherparty);
-
- const ids: mongo.ObjectID[] = Array.isArray(message)
- ? isObjectId(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)
- : isObjectId(message)
- ? [(message as mongo.ObjectID)]
- : typeof message === 'string'
- ? [new mongo.ObjectID(message)]
- : [(message as IMessage)._id];
+export default async (
+ userId: User['id'],
+ otherpartyId: User['id'],
+ messageIds: MessagingMessage['id'][]
+) => {
+ if (messageIds.length === 0) return;
// Update documents
- await Message.update({
- _id: { $in: ids },
+ await MessagingMessages.update({
+ id: In(messageIds),
userId: otherpartyId,
recipientId: userId,
isRead: false
}, {
- $set: {
- isRead: true
- }
- }, {
- multi: true
- });
+ isRead: true
+ });
// Publish event
- publishMessagingStream(otherpartyId, userId, 'read', ids.map(id => id.toString()));
- publishMessagingIndexStream(userId, 'read', ids.map(id => id.toString()));
+ publishMessagingStream(otherpartyId, userId, 'read', messageIds);
+ publishMessagingIndexStream(userId, 'read', messageIds);
// Calc count of my unread messages
- const count = await Message
- .count({
- recipientId: userId,
- isRead: false
- }, {
- limit: 1
- });
+ const count = await MessagingMessages.count({
+ recipientId: userId,
+ isRead: false
+ });
if (count == 0) {
- // Update flag
- User.update({ _id: userId }, {
- $set: {
- hasUnreadMessagingMessage: false
- }
- });
-
// 全ての(いままで未読だった)自分宛てのメッセージを(これで)読みましたよというイベントを発行
publishMainStream(userId, 'readAllMessagingMessages');
}
-});
+};