summary refs log tree commit diff
diff options
context:
space:
mode:
authorIntevel ツ <59223342+Intevel@users.noreply.github.com>2021-05-06 23:11:17 +0200
committerIntevel ツ <59223342+Intevel@users.noreply.github.com>2021-05-06 23:11:17 +0200
commit7080cc65ed1248d5a4c483a7bca33db5ce900e2f (patch)
treebd1d9a93163f7936605f44260fd76b187ff92326
parentCreate Roles.ts (diff)
downloadserver-7080cc65ed1248d5a4c483a7bca33db5ce900e2f.tar.xz
Create roles.ts
-rw-r--r--src/routes/guilds/#guild_id/roles.ts49
1 files changed, 49 insertions, 0 deletions
diff --git a/src/routes/guilds/#guild_id/roles.ts b/src/routes/guilds/#guild_id/roles.ts
new file mode 100644

index 00000000..6d931c56 --- /dev/null +++ b/src/routes/guilds/#guild_id/roles.ts
@@ -0,0 +1,49 @@ +import { Request, Response, Router } from "express"; +import { RoleModel, GuildModel, getPermission, toObject, UserModel, Snowflake, MemberModel } from "@fosscord/server-util"; +import { HTTPError } from "lambert-server"; +import { emitEvent } from "../../../util/Event"; +import { check } from "../../../util/instanceOf"; +import { RoleCreateSchema } from "../../../schema/Roles"; +import { getPublicUser } from "../../../util/User"; + +const router: Router = Router(); + +router.get("/", async (req: Request, res: Response) => { + const guild_id = req.params.id; + + const guild = await GuildModel.exists({ id: guild_id }); + if (!guild) throw new HTTPError("Guild not found", 404); + + var roles = await RoleModel.find({ guild_id: guild_id }).exec(); + return res.json(toObject(roles)); +}); + +router.post("/", check(RoleCreateSchema), async (req: Request, res: Response) => { + + const guild_id = req.params.guild_id; + const body = req.body as RoleCreateSchema; + + const guild = await GuildModel.findOne({ id: guild_id }, { id: true }).exec(); + if (!guild) throw new HTTPError("Guild not found", 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); + + const role_id = Snowflake.generate(); + + var role = { + ...body, + id: role_id, + } + + const roleNew = await new RoleModel(role).save(); + + res.json(toObject(roleNew)).send(); +}); + +export default router;