Fix: 自身が送信していないメッセージを削除できる問題

This commit is contained in:
2026-06-05 06:18:51 +09:00
parent e4841bec10
commit d1cef4bd67
2 changed files with 21 additions and 2 deletions
+18 -1
View File
@@ -1,4 +1,4 @@
import { DatabaseError, InputError } from "@/errors";
import { DatabaseError, ErrorBase, InputError } from "@/errors";
import Logger from "@/lib/logger";
import { MessageEntity } from "@/modules/entities/Message";
import type { FastifyInstance } from "fastify";
@@ -23,6 +23,23 @@ export default async function MessageDelete(fastify: FastifyInstance) {
try {
const messageRepo = fastify.orm.em.getRepository(MessageEntity);
const itMessage = await messageRepo.findOne({ id: result.data.id });
if (!itMessage) {
return res.code(400).send(ErrorBase({
bad: "client",
code: "message_not_found",
message: "対象のメッセージが見つかりませんでした。",
}));
}
if (itMessage.createdBy.userid !== req.token.user.userid) {
return res.code(403).send(ErrorBase({
bad: "client",
code: "not_your_message",
message: "あなたの送信したメッセージではありません。",
}));
}
await messageRepo.deleteMessage(result.data.id);
return res.send({