diff options
Diffstat (limited to 'src/api/routes/channels/#channel_id/webhooks.ts')
-rw-r--r-- | src/api/routes/channels/#channel_id/webhooks.ts | 28 |
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, + }); }, ); |