mirror of
https://github.com/Akif9748/akf-forum.git
synced 2024-11-26 13:20:41 +03:00
113 lines
No EOL
3.2 KiB
JavaScript
113 lines
No EOL
3.2 KiB
JavaScript
const { MessageModel, ThreadModel } = require("../../../models");
|
|
const { RL } = require('../../../lib');
|
|
const { Router } = require("express")
|
|
|
|
const app = Router();
|
|
|
|
app.param("id", async (req, res, next, id) => {
|
|
req.message = await MessageModel.get(id);
|
|
|
|
if (!req.message) return res.error(404, `We don't have any message with id ${id}.`);
|
|
|
|
if (req.message.deleted && !req.user?.admin)
|
|
return res.error(404, `You do not have permissions to view this message with id ${id}.`)
|
|
|
|
next();
|
|
});
|
|
|
|
|
|
app.get("/:id", async (req, res) => res.complate(req.message));
|
|
|
|
app.delete("/:id/", async (req, res) => {
|
|
|
|
|
|
const { message, user } = req;
|
|
|
|
if (user.id != message.authorID && !user.admin)
|
|
return res.error(403, "You have not got permission for this.");
|
|
if (message.deleted) return res.error(404, "This message is already deleted.");
|
|
|
|
message.deleted = true;
|
|
await message.save()
|
|
res.complate(message);
|
|
|
|
});
|
|
|
|
app.patch("/:id/", async (req, res) => {
|
|
|
|
|
|
const { message, user } = req;
|
|
|
|
if (user.id !== message.authorID && !user.admin) return res.error(403, "You have not got permission for this.");
|
|
if (!Object.values(req.body).some(Boolean)) return res.error(400, "Missing message informations for update in request body.");
|
|
const { content, deleted } = req.body;
|
|
|
|
const limits = req.app.get("limits");
|
|
if (content.length < 5 || content.length > limits.message) return res.error(400, `content must be between 5 - ${limits.message} characters`);
|
|
|
|
if (deleted === false) message.deleted = false;
|
|
|
|
message.content = content;
|
|
|
|
if (!message.oldContents.includes(content))
|
|
message.oldContents.push(content);
|
|
|
|
message.edited = true;
|
|
|
|
await message.save();
|
|
res.complate(message);
|
|
|
|
})
|
|
|
|
app.post("/", RL(), async (req, res) => {
|
|
|
|
const { threadID, content } = req.body;
|
|
if (!content) return res.error(400, "Missing message content in request body.");
|
|
const limits = req.app.get("limits");
|
|
|
|
if (content.length < 5 || content.length > limits.message) return res.error(400, `content must be between ${limits.message} characters`);
|
|
|
|
const thread = await ThreadModel.get(threadID);
|
|
|
|
if (!thread) return res.error(404, `We don't have any thread with id ${threadID}.`);
|
|
|
|
const message = await new MessageModel({ content, author: req.user, threadID: thread.id }).takeId();
|
|
await message.save();
|
|
await thread.push(message.id).save();
|
|
|
|
res.complate(message);
|
|
|
|
})
|
|
app.post("/:id/react/:type", async (req, res) => {
|
|
|
|
|
|
const { message } = req;
|
|
|
|
if (req.params.type == "like") {
|
|
if (message.react.like.includes(req.user.id))
|
|
message.react.like.pull(req.user.id);
|
|
else {
|
|
message.react.like.push(req.user.id);
|
|
message.react.dislike.pull(req.user.id);
|
|
}
|
|
|
|
|
|
} else if (req.params.type == "dislike") {
|
|
|
|
if (message.react.dislike.includes(req.user.id))
|
|
message.react.dislike.pull(req.user.id);
|
|
else {
|
|
message.react.dislike.push(req.user.id);
|
|
message.react.like.pull(req.user.id);
|
|
}
|
|
|
|
} else
|
|
return res.error(400, `We don't have any react type with name ${req.params.type}.`);
|
|
|
|
await message.save();
|
|
|
|
res.complate(message);
|
|
|
|
});
|
|
|
|
module.exports = app; |