summary refs log tree commit diff
path: root/src/api/routes/channels/#channel_id/webhooks.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/api/routes/channels/#channel_id/webhooks.ts')
-rw-r--r--src/api/routes/channels/#channel_id/webhooks.ts28
1 files changed, 25 insertions, 3 deletions
diff --git a/src/api/routes/channels/#channel_id/webhooks.ts b/src/api/routes/channels/#channel_id/webhooks.ts
index da8fe73c..13f421f1 100644
--- a/src/api/routes/channels/#channel_id/webhooks.ts
+++ b/src/api/routes/channels/#channel_id/webhooks.ts
@@ -1,9 +1,10 @@
 import { Router, Response, Request } from "express";
 import { route } from "@fosscord/api";
-import { Channel, Config, trimSpecial, Webhook } from "@fosscord/util";
+import { Channel, Config, handleFile, trimSpecial, User, Webhook, WebhookCreateSchema, WebhookType } from "@fosscord/util";
 import { HTTPError } from "lambert-server";
 import { isTextChannel } from "./messages/index";
 import { DiscordApiErrors } from "@fosscord/util";
+import crypto from "crypto";
 
 const router: Router = Router();
 
@@ -30,11 +31,32 @@ router.post(
 		if (webhook_count > maxWebhooks)
 			throw DiscordApiErrors.MAXIMUM_WEBHOOKS.withParams(maxWebhooks);
 
-		var { avatar, name } = req.body as { name: string; avatar?: string };
+		var { avatar, name } = req.body as WebhookCreateSchema;
 		name = trimSpecial(name);
+
+		// TODO: move this
 		if (name === "clyde") throw new HTTPError("Invalid name", 400);
+		if (name === "Fosscord Ghost") throw new HTTPError("Invalid name", 400);
+
+		if (avatar)
+			avatar = await handleFile(`/avatars/${channel_id}`, avatar);
+
+		const hook = Webhook.create({
+			type: WebhookType.Incoming,
+			name,
+			avatar,
+			guild_id: channel.guild_id,
+			channel_id: channel.id,
+			user_id: req.user_id,
+			token: crypto.randomBytes(24).toString("base64"),
+		});
 
-		// TODO: save webhook in database and send response
+		const user = await User.getPublicUser(req.user_id);
+
+		return res.json({
+			...hook,
+			user: user,
+		});
 	},
 );