From 0f04fbb6e60c54626f3c35b2863e0850f155e175 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Intevel=20=E3=83=84?= <59223342+Intevel@users.noreply.github.com> Date: Thu, 6 May 2021 23:17:16 +0200 Subject: [PATCH] [Route] DELETE /guilds/:id/roles --- src/routes/guilds/#guild_id/roles.ts | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/src/routes/guilds/#guild_id/roles.ts b/src/routes/guilds/#guild_id/roles.ts index 3e7a8d91..fa9025a4 100644 --- a/src/routes/guilds/#guild_id/roles.ts +++ b/src/routes/guilds/#guild_id/roles.ts @@ -50,4 +50,29 @@ router.post("/", check(RoleCreateSchema), async (req: Request, res: Response) => res.json(toObject(roleNew)).send(); }); +router.delete("/:role_id", async (req: Request, res: Response) => { + + const guild_id = req.params.guild_id; + const { role_id } = req.params; + + const guild = await GuildModel.findOne({ id: guild_id }, { id: true }).exec(); + if (!guild) throw new HTTPError("Guild not found", 404); + if (!role_id) throw new HTTPError("Unknown role_id", 404); + + const user = await UserModel.findOne({ id: req.user_id }).exec(); + if (!user) throw new HTTPError("User not found", 404); + + const perms = await getPermission(req.user_id, guild_id); + + if (!perms.has("MANAGE_ROLES")) + throw new HTTPError("You missing the MANAGE_ROLES permission", 401); + + await RoleModel.findOneAndDelete({ + id: role_id, + guild_id: guild_id + }).exec(); + + res.send("Deleted"); +}); + export default router;