diff options
| author | MeiMei <30769358+mei23@users.noreply.github.com> | 2020-11-01 12:14:42 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-11-01 12:14:42 +0900 |
| commit | cd0b0012d9da9109b0ea4adf0feb84b6c3b43f86 (patch) | |
| tree | 36cd61bc924e3711c05a4608b7829059b7a0d88a /src/services/messages | |
| parent | fix(client): ストリーミングのメモリリークを修正 (diff) | |
| download | misskey-cd0b0012d9da9109b0ea4adf0feb84b6c3b43f86.tar.gz misskey-cd0b0012d9da9109b0ea4adf0feb84b6c3b43f86.tar.bz2 misskey-cd0b0012d9da9109b0ea4adf0feb84b6c3b43f86.zip | |
メッセージ (トーク/チャット) 削除の連合 (#6789)
Diffstat (limited to 'src/services/messages')
| -rw-r--r-- | src/services/messages/delete.ts | 31 |
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); + } +} |