akf-forum/routes/users.js

42 lines
1.4 KiB
JavaScript
Raw Normal View History

2022-04-06 21:14:46 +03:00
const { Router } = require("express");
const app = Router();
2022-03-21 23:53:22 +03:00
2022-04-06 21:14:46 +03:00
const { UserModel, MessageModel, ThreadModel } = require("../models");
2022-03-21 23:53:22 +03:00
2022-08-09 19:48:10 +03:00
app.get("/", async ({ user }, res) => {
2022-08-10 00:44:13 +03:00
const users = await UserModel.find(user?.admin ? {} : { deleted: false });
2022-08-27 10:31:16 +03:00
return res.reply("users", { users })
2022-03-21 23:53:22 +03:00
});
2022-04-03 21:01:55 +03:00
app.get("/:id/edit", async (req, res) => {
if(!req.user || (!req.user.admin&&req.params.id !== req.user.id)) return res.error(403, "You have not got permission for this.");
const member = await UserModel.get(req.params.id);
if (member && (req.user?.admin || !member.deleted))
res.reply("edit_user", { member })
else
res.error(404, `We don't have any user with id ${req.params.id}.`);
});
2022-04-06 21:14:46 +03:00
app.get("/:id", async (req, res) => {
const user = req.user
2022-08-29 16:16:44 +03:00
const { id } = req.params;
const member = await UserModel.get(id);
2022-03-21 23:53:22 +03:00
2022-04-03 21:01:55 +03:00
if (member && (user?.admin || !member.deleted)) {
2022-03-21 23:53:22 +03:00
2022-08-31 16:25:35 +03:00
const message = await MessageModel.count({ authorID: id });
const thread = await ThreadModel.count({ authorID: id });
2022-08-29 19:31:59 +03:00
member.about = member.about.replaceAll("&", "&")
.replaceAll("<", "&lt;").replaceAll(">", "&gt;")
.replaceAll("\"", "&quot;").replaceAll("'", "&#39;")
.replaceAll("\n", "<br>");
2022-08-27 10:31:16 +03:00
res.reply("user", { member, counts: { message, thread } })
2022-03-21 23:53:22 +03:00
}
2022-08-29 19:31:59 +03:00
else res.error(404, `We don't have any user with id ${id}.`);
2022-03-21 23:53:22 +03:00
});
2022-04-03 21:01:55 +03:00
2022-03-21 23:53:22 +03:00
module.exports = app;