summary refs log tree commit diff
path: root/src/routes
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-05-08 13:55:54 +0200
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-05-08 13:55:54 +0200
commitf309ecb325ae26f93831b4d4e27f50f7161da944 (patch)
treeffe16e3e0e639e6954a631d02aace4e9aa771e26 /src/routes
parent:bug: fix add/remove Member function (diff)
parentUpdate members.ts (diff)
downloadserver-f309ecb325ae26f93831b4d4e27f50f7161da944.tar.xz
Merge branch 'master' of https://github.com/discord-open-source/discord-api
Diffstat (limited to 'src/routes')
-rw-r--r--src/routes/guilds/#guild_id/members.ts75
1 files changed, 50 insertions, 25 deletions
diff --git a/src/routes/guilds/#guild_id/members.ts b/src/routes/guilds/#guild_id/members.ts

index 82c94aa1..69eb5bb6 100644 --- a/src/routes/guilds/#guild_id/members.ts +++ b/src/routes/guilds/#guild_id/members.ts
@@ -1,8 +1,8 @@ import { Request, Response, Router } from "express"; -import { GuildModel, MemberModel, UserModel, toObject, GuildMemberAddEvent } from "@fosscord/server-util"; +import { GuildModel, MemberModel, UserModel, toObject, GuildMemberAddEvent, getPermission } from "@fosscord/server-util"; import { HTTPError } from "lambert-server"; import { instanceOf, Length } from "../../../util/instanceOf"; -import { PublicMemberProjection, addMember, removeMember } from "../../../util/Member"; +import { PublicMemberProjection, addMember, removeMember, addRole, removeRole, changeNickname } from "../../../util/Member"; import { emitEvent } from "../../../util/Event"; import { getPublicUser } from "../../../util/User"; @@ -37,45 +37,70 @@ router.get("/", async (req: Request, res: Response) => { return res.json(toObject(members)); }); -router.get("/:member", async (req: Request, res: Response) => { - const { guild_id } = req.params; - const user_id = req.params.member; +router.get("/:member_id", async (req: Request, res: Response) => { + const { guild_id, member_id } = req.params; - const member = await MemberModel.findOne({ id: user_id, guild_id }).exec(); + const member = await MemberModel.findOne({ id: member_id, guild_id }).exec(); if (!member) throw new HTTPError("Member not found", 404); - return res.json(member); + return res.json(toObject(member)); }); -router.put("/:member", async (req: Request, res: Response) => { - const { guild_id } = req.params; - const guild = await GuildModel.findOne({ id: guild_id }).exec(); - if (!guild) throw new HTTPError("Guild not found", 404); +router.put("/:member_id", async (req: Request, res: Response) => { + const { guild_id, member_id } = req.params; - const user_id = req.params.member; + await addMember(member_id, guild_id); + res.sendStatus(204) +}); - const user = await UserModel.findOne({ id: user_id }).exec(); - if (!user) throw new HTTPError("User not found", 404); - await addMember(user_id, guild_id); +router.delete("/:member_id", async (req: Request, res: Response) => { + const { guild_id, member_id } = req.params; - // https://discord.com/developers/docs/resources/guild#add-guild-member + await removeMember(member_id, guild_id); + res.sendStatus(204) }); +router.delete("/:member_id/roles/:role_id", async (req: Request, res: Response) => { + const { guild_id, role_id, member_id } = req.params; -router.delete("/:member", async (req: Request, res: Response) => { - const { guild_id } = req.params; - const guild = await GuildModel.findOne({ id: guild_id }).exec(); - if (!guild) throw new HTTPError("Guild not found", 404); + const perms = await getPermission(member_id, guild_id); + perms.hasThrow("MANAGE_ROLES"); + + await removeRole(member_id, guild_id, role_id); + res.sendStatus(204); +}); - const user_id = req.params.member; +router.put("/:member_id/roles/:role_id", async (req: Request, res: Response) => { + const { guild_id, role_id, member_id } = req.params; - const member = await MemberModel.findOne({ id: user_id, guild_id }).exec(); - if (!member) throw new HTTPError("Member not found", 404); + const perms = await getPermission(member_id, guild_id); + perms.hasThrow("MANAGE_ROLES"); + + await addRole(member_id, guild_id, role_id); + res.sendStatus(204); +}); + +router.patch("/:member_id/nick", async (req: Request, res: Response) => { + const { guild_id, member_id } = req.params; + if(!req.body.nickname) throw new HTTPError("No nickname defined", 404); + + const perms = await getPermission(member_id, guild_id); + perms.hasThrow("MANAGE_NICKNAMES"); + + await changeNickname(member_id, guild_id, req.body.nickname); + res.status(204); +}); + +router.patch("/members/@me/nick", async (req: Request, res: Response) => { + const { guild_id, member_id } = req.params; + if(!req.body.nickname) throw new HTTPError("No nickname defined", 404); - await removeMember(user_id, guild_id); + const perms = await getPermission(member_id, guild_id); + perms.hasThrow("CHANGE_NICKNAME"); - // https://discord.com/developers/docs/resources/guild#remove-guild-member + await changeNickname(member_id, guild_id, req.body.nickname); + res.status(204); });