akf-forum/routes/users.js

49 lines
1.3 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 error = require("../errors/error");
const { UserModel, MessageModel, ThreadModel } = require("../models");
2022-03-21 23:53:22 +03:00
2022-04-06 21:14:46 +03:00
app.get("/", async (req, res) => {
const user = req.user
const users = await UserModel.find({ deleted: false });
return res.render("users", { users, user })
2022-03-21 23:53:22 +03:00
});
2022-04-03 21:01:55 +03:00
2022-04-06 21:14:46 +03:00
app.get("/:id", async (req, res) => {
const user = req.user
2022-03-21 23:53:22 +03:00
const { id = null } = 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-04-06 21:14:46 +03:00
const message = await MessageModel.count({ authorID: id });
const thread = await ThreadModel.count({ authorID: id });
res.render("user", { user, member, counts:{ message, thread } })
2022-03-21 23:53:22 +03:00
}
else error(res, 404, "We have not got this user.");
});
2022-04-03 21:01:55 +03:00
app.use(require("../middlewares/login"));
2022-04-06 21:14:46 +03:00
app.post("/:id/delete/", async (req, res) => {
const user = req.user;
2022-04-03 21:01:55 +03:00
if (!user?.admin)
2022-03-21 23:53:22 +03:00
return error(res, 403, "You have not got permission for this.");
2022-04-06 21:14:46 +03:00
const { id = null } = req.params;
const member = await UserModel.get(id);
2022-04-06 21:14:46 +03:00
2022-03-21 23:53:22 +03:00
if (!member || member.deleted) return error(res, 404, "We have not got any user declared as this id.");
2022-04-06 21:14:46 +03:00
2022-03-21 23:53:22 +03:00
member.deleted = true;
await member.save();
2022-04-06 21:14:46 +03:00
2022-03-21 23:53:22 +03:00
res.redirect("/admin");
});
module.exports = app;