summary refs log tree commit diff
path: root/api/src/routes
diff options
context:
space:
mode:
authorAlTech98 <altech123159@gmail.com>2021-09-17 18:13:02 +0200
committerGitHub <noreply@github.com>2021-09-17 18:13:02 +0200
commit987f765a2887a9bb648086877069ffd3ce335c04 (patch)
tree17310ae2bd70bb77cec26b9f9e8aace36ef72c11 /api/src/routes
parentFix GET /users/@me/channels (diff)
parent:bug: fix vanity url (diff)
downloadserver-987f765a2887a9bb648086877069ffd3ce335c04.tar.xz
Merge branch 'fosscord:master' into fix-dm
Diffstat (limited to 'api/src/routes')
-rw-r--r--api/src/routes/guilds/#guild_id/vanity-url.ts7
1 files changed, 4 insertions, 3 deletions
diff --git a/api/src/routes/guilds/#guild_id/vanity-url.ts b/api/src/routes/guilds/#guild_id/vanity-url.ts
index 801768fb..7f2cea9e 100644
--- a/api/src/routes/guilds/#guild_id/vanity-url.ts
+++ b/api/src/routes/guilds/#guild_id/vanity-url.ts
@@ -1,6 +1,7 @@
 import { Channel, ChannelType, getPermission, Guild, Invite, trimSpecial } from "@fosscord/util";
 import { Router, Request, Response } from "express";
 import { route } from "@fosscord/api";
+import { HTTPError } from "lambert-server";
 
 const router = Router();
 
@@ -29,14 +30,14 @@ router.patch("/", route({ body: "VanityUrlSchema", permission: "MANAGE_GUILD" })
 	const body = req.body as VanityUrlSchema;
 	const code = body.code?.replace(InviteRegex, "");
 
-	await Invite.findOneOrFail({ code });
+	const invite = await Invite.findOne({ code });
+	if (invite) throw new HTTPError("Invite already exists");
 
 	const guild = await Guild.findOneOrFail({ id: guild_id });
 	const { id } = await Channel.findOneOrFail({ guild_id, type: ChannelType.GUILD_TEXT });
-	guild.vanity_url_code = code;
 
 	Promise.all([
-		guild.save(),
+		Guild.update({ id: guild_id }, { vanity_url_code: code }),
 		Invite.delete({ code: guild.vanity_url_code }),
 		new Invite({
 			code: code,