summaryrefslogtreecommitdiff
path: root/src/services/messages
diff options
context:
space:
mode:
authorMeiMei <30769358+mei23@users.noreply.github.com>2020-11-01 12:14:42 +0900
committerGitHub <noreply@github.com>2020-11-01 12:14:42 +0900
commitcd0b0012d9da9109b0ea4adf0feb84b6c3b43f86 (patch)
tree36cd61bc924e3711c05a4608b7829059b7a0d88a /src/services/messages
parentfix(client): ストリーミングのメモリリークを修正 (diff)
downloadmisskey-cd0b0012d9da9109b0ea4adf0feb84b6c3b43f86.tar.gz
misskey-cd0b0012d9da9109b0ea4adf0feb84b6c3b43f86.tar.bz2
misskey-cd0b0012d9da9109b0ea4adf0feb84b6c3b43f86.zip
メッセージ (トーク/チャット) 削除の連合 (#6789)
Diffstat (limited to 'src/services/messages')
-rw-r--r--src/services/messages/delete.ts31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/services/messages/delete.ts b/src/services/messages/delete.ts
new file mode 100644
index 0000000000..0efff85f39
--- /dev/null
+++ b/src/services/messages/delete.ts
@@ -0,0 +1,31 @@
+import config from '../../config';
+import { ensure } from '../../prelude/ensure';
+import { MessagingMessages, Users } from '../../models';
+import { MessagingMessage } from '../../models/entities/messaging-message';
+import { publishGroupMessagingStream, publishMessagingStream } from '../stream';
+import { renderActivity } from '../../remote/activitypub/renderer';
+import renderDelete from '../../remote/activitypub/renderer/delete';
+import renderTombstone from '../../remote/activitypub/renderer/tombstone';
+import { deliver } from '../../queue';
+
+export async function deleteMessage(message: MessagingMessage) {
+ await MessagingMessages.delete(message.id);
+ postDeleteMessage(message);
+}
+
+async function postDeleteMessage(message: MessagingMessage) {
+ if (message.recipientId) {
+ const user = await Users.findOne(message.userId).then(ensure);
+ const recipient = await Users.findOne(message.recipientId).then(ensure);
+
+ if (Users.isLocalUser(user)) publishMessagingStream(message.userId, message.recipientId, 'deleted', message.id);
+ if (Users.isLocalUser(recipient)) publishMessagingStream(message.recipientId, message.userId, 'deleted', message.id);
+
+ if (Users.isLocalUser(user) && Users.isRemoteUser(recipient)) {
+ const activity = renderActivity(renderDelete(renderTombstone(`${config.url}/notes/${message.id}`), user));
+ deliver(user, activity, recipient.inbox);
+ }
+ } else if (message.groupId) {
+ publishGroupMessagingStream(message.groupId, 'deleted', message.id);
+ }
+}