diff options
Diffstat (limited to 'src/remote/activitypub/kernel/delete/note.ts')
| -rw-r--r-- | src/remote/activitypub/kernel/delete/note.ts | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/src/remote/activitypub/kernel/delete/note.ts b/src/remote/activitypub/kernel/delete/note.ts index 9d7574c29b..8fa2285dba 100644 --- a/src/remote/activitypub/kernel/delete/note.ts +++ b/src/remote/activitypub/kernel/delete/note.ts @@ -3,6 +3,7 @@ import deleteNode from '../../../../services/note/delete'; import { apLogger } from '../../logger'; import DbResolver from '../../db-resolver'; import { getApLock } from '../../../../misc/app-lock'; +import { deleteMessage } from '../../../../services/messages/delete'; const logger = apLogger; @@ -16,7 +17,16 @@ export default async function(actor: IRemoteUser, uri: string): Promise<string> const note = await dbResolver.getNoteFromApId(uri); if (note == null) { - return 'note not found'; + const message = await dbResolver.getMessageFromApId(uri); + if (message == null) return 'message not found'; + + if (message.userId !== actor.id) { + return '投稿を削除しようとしているユーザーは投稿の作成者ではありません'; + } + + await deleteMessage(message); + + return 'ok: message deleted'; } if (note.userId !== actor.id) { @@ -24,7 +34,7 @@ export default async function(actor: IRemoteUser, uri: string): Promise<string> } await deleteNode(actor, note); - return 'ok: deleted'; + return 'ok: note deleted'; } finally { unlock(); } |