summaryrefslogtreecommitdiff
path: root/src/server/api
diff options
context:
space:
mode:
authorfuyu <54523771+mfmfuyu@users.noreply.github.com>2020-07-04 10:45:36 +0900
committerGitHub <noreply@github.com>2020-07-04 10:45:36 +0900
commit37c16e5b4536ea2db72b7853a8515df6ceb490a3 (patch)
treec3633b4892121dd01fa2cf9523ed5ee071f8a1d5 /src/server/api
parent投稿詳細でTwitterウィジェットが表示されなくなっている... (diff)
downloadsharkey-37c16e5b4536ea2db72b7853a8515df6ceb490a3.tar.gz
sharkey-37c16e5b4536ea2db72b7853a8515df6ceb490a3.tar.bz2
sharkey-37c16e5b4536ea2db72b7853a8515df6ceb490a3.zip
「すべて既読にする」でグループメッセージが既読にならない問題を修正 (#6476)
Diffstat (limited to 'src/server/api')
-rw-r--r--src/server/api/endpoints/i/read-all-messaging-messages.ts13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/server/api/endpoints/i/read-all-messaging-messages.ts b/src/server/api/endpoints/i/read-all-messaging-messages.ts
index 036ec02d6b..e47ef16bd9 100644
--- a/src/server/api/endpoints/i/read-all-messaging-messages.ts
+++ b/src/server/api/endpoints/i/read-all-messaging-messages.ts
@@ -1,6 +1,6 @@
import { publishMainStream } from '../../../../services/stream';
import define from '../../define';
-import { MessagingMessages } from '../../../../models';
+import { MessagingMessages, UserGroupJoinings } from '../../../../models';
export const meta = {
desc: {
@@ -27,5 +27,16 @@ export default define(meta, async (ps, user) => {
isRead: true
});
+ const joinings = await UserGroupJoinings.find({ userId: user.id });
+
+ await Promise.all(joinings.map(j => MessagingMessages.createQueryBuilder().update()
+ .set({
+ reads: (() => `array_append("reads", '${user.id}')`) as any
+ })
+ .where(`groupId = :groupId`, { groupId: j.userGroupId })
+ .andWhere('userId != :userId', { userId: user.id })
+ .andWhere('NOT (:userId = ANY(reads))', { userId: user.id })
+ .execute()));
+
publishMainStream(user.id, 'readAllMessagingMessages');
});