From b9391bfac1aefc02bb51fb532c95a8a3e1c9f818 Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Tue, 5 Oct 2021 19:37:20 +0200 Subject: :sparkles: added autoJoin guild to config --- api/src/routes/users/@me/guilds.ts | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'api/src/routes/users/@me') diff --git a/api/src/routes/users/@me/guilds.ts b/api/src/routes/users/@me/guilds.ts index 4ba03cec..22a2c04c 100644 --- a/api/src/routes/users/@me/guilds.ts +++ b/api/src/routes/users/@me/guilds.ts @@ -1,5 +1,5 @@ import { Router, Request, Response } from "express"; -import { Guild, Member, User, GuildDeleteEvent, GuildMemberRemoveEvent, emitEvent } from "@fosscord/util"; +import { Guild, Member, User, GuildDeleteEvent, GuildMemberRemoveEvent, emitEvent, Config } from "@fosscord/util"; import { HTTPError } from "lambert-server"; import { route } from "@fosscord/api"; @@ -12,12 +12,16 @@ router.get("/", route({}), async (req: Request, res: Response) => { }); // user send to leave a certain guild -router.delete("/:id", route({}), async (req: Request, res: Response) => { - const guild_id = req.params.id; +router.delete("/:guild_id", route({}), async (req: Request, res: Response) => { + const { autoJoin } = Config.get().guild; + const { guild_id } = req.params; const guild = await Guild.findOneOrFail({ where: { id: guild_id }, select: ["owner_id"] }); if (!guild) throw new HTTPError("Guild doesn't exist", 404); if (guild.owner_id === req.user_id) throw new HTTPError("You can't leave your own guild", 400); + if (autoJoin.enabled && autoJoin.guilds.includes(guild_id) && !autoJoin.canLeave) { + throw new HTTPError("You can't leave instance auto join guilds", 400); + } await Promise.all([ Member.delete({ id: req.user_id, guild_id: guild_id }), -- cgit 1.4.1