mirror of
https://github.com/Akif9748/akf-forum.git
synced 2024-11-23 04:10:40 +03:00
48 lines
No EOL
1.3 KiB
JavaScript
48 lines
No EOL
1.3 KiB
JavaScript
const { Router } = require("express");
|
|
const app = Router();
|
|
|
|
const error = require("../errors/error");
|
|
const { UserModel, MessageModel, ThreadModel } = require("../models");
|
|
|
|
app.get("/", async ({ user }, res) => {
|
|
const users = await UserModel.find(user?.admin ? {} : { deleted: false });
|
|
return res.render("users", { users, user })
|
|
|
|
});
|
|
|
|
app.get("/:id", async (req, res) => {
|
|
const user = req.user
|
|
const { id = null } = req.params;
|
|
const member = await UserModel.get(id);
|
|
|
|
|
|
if (member && (user?.admin || !member.deleted)) {
|
|
|
|
const message = await MessageModel.count({ authorID: id });
|
|
const thread = await ThreadModel.count({ authorID: id });
|
|
res.render("user", { user, member, counts: { message, thread } })
|
|
}
|
|
else error(res, 404, "We have not got this user.");
|
|
|
|
});
|
|
|
|
app.use(require("../middlewares/login"));
|
|
|
|
|
|
app.post("/:id/delete/", async (req, res) => {
|
|
const user = req.user;
|
|
if (!user?.admin)
|
|
return error(res, 403, "You have not got permission for this.");
|
|
|
|
const { id = null } = req.params;
|
|
const member = await UserModel.get(id);
|
|
|
|
if (!member || member.deleted) return error(res, 404, "We have not got any user declared as this id.");
|
|
|
|
member.deleted = true;
|
|
await member.save();
|
|
|
|
res.redirect("/admin");
|
|
});
|
|
|
|
module.exports = app; |