diff --git a/api/src/routes/invites/index.ts b/api/src/routes/invites/index.ts
index e7543dbb..23fa3aec 100644
--- a/api/src/routes/invites/index.ts
+++ b/api/src/routes/invites/index.ts
@@ -1,48 +1,41 @@
import { Router, Request, Response } from "express";
-import { getPermission, GuildModel, InviteModel, toObject } from "@fosscord/util";
+import { getPermission, Guild, Invite, Member } from "@fosscord/util";
import { HTTPError } from "lambert-server";
-import { addMember } from "../../util/Member";
const router: Router = Router();
router.get("/:code", async (req: Request, res: Response) => {
const { code } = req.params;
- const invite = await InviteModel.findOne({ code }).exec();
- if (!invite) throw new HTTPError("Unknown Invite", 404);
+ const invite = await Invite.findOneOrFail({ code });
- res.status(200).send(toObject(invite));
+ res.status(200).send(invite);
});
router.post("/:code", async (req: Request, res: Response) => {
const { code } = req.params;
- const invite = await InviteModel.findOneAndUpdate({ code }, { $inc: { uses: 1 } }, { new: true }).exec();
- if (!invite) throw new HTTPError("Unknown Invite", 404);
- if (invite.uses >= invite.max_uses) await InviteModel.deleteOne({ code });
+ const invite = await Invite.findOneOrFail({ code });
+ if (invite.uses++ >= invite.max_uses) await Invite.delete({ code });
+ else await invite.save();
- await addMember(req.user_id, invite.guild_id);
+ await Member.addToGuild(req.user_id, invite.guild_id);
- res.status(200).send(toObject(invite));
+ res.status(200).send(invite);
});
router.delete("/:code", async (req: Request, res: Response) => {
const { code } = req.params;
- const invite = await InviteModel.findOne({ code }).exec();
+ const invite = await Invite.findOneOrFail({ code });
const { guild_id, channel_id } = invite;
- const guild = await GuildModel.findOne({ id: guild_id }).exec();
- const permission = await getPermission(req.user_id, guild_id, channel_id, { guild });
+ const permission = await getPermission(req.user_id, guild_id, channel_id);
if (!permission.has("MANAGE_GUILD") && !permission.has("MANAGE_CHANNELS"))
throw new HTTPError("You missing the MANAGE_GUILD or MANAGE_CHANNELS permission", 401);
- await InviteModel.deleteOne({ code }).exec();
+ await Promise.all([Invite.delete({ code }), Guild.update({ vanity_url_code: code }, { vanity_url_code: undefined })]);
- await GuildModel.updateOne({ vanity_url_code: code }, { $unset: { vanity_url_code: 1 } })
- .exec()
- .catch((e) => {});
-
- res.status(200).send({ invite: toObject(invite) });
+ res.json({ invite: invite });
});
export default router;
|