From 4e96f2e8328c3a76d3d46abc22c711eb2e1a0e0e Mon Sep 17 00:00:00 2001 From: Rory& Date: Thu, 16 Oct 2025 09:36:58 +0200 Subject: [PATCH] Implement applications/@me --- src/api/routes/applications/@me.ts | 115 +++++++++++++++++++++++++++++ 1 file changed, 115 insertions(+) create mode 100644 src/api/routes/applications/@me.ts diff --git a/src/api/routes/applications/@me.ts b/src/api/routes/applications/@me.ts new file mode 100644 index 00000000..773a4827 --- /dev/null +++ b/src/api/routes/applications/@me.ts @@ -0,0 +1,115 @@ +/* + Spacebar: A FOSS re-implementation and extension of the Discord.com backend. + Copyright (C) 2023 Spacebar and Spacebar Contributors + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published + by the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . +*/ + +import { route } from "@spacebar/api"; +import { + Application, + DiscordApiErrors, + Guild, + handleFile, +} from "@spacebar/util"; +import { Request, Response, Router } from "express"; +import { HTTPError } from "lambert-server"; +import { verifyToken } from "node-2fa"; +import { ApplicationModifySchema } from "@spacebar/schemas" + +const router: Router = Router({ mergeParams: true }); + +// TODO: actually make this be correct - this is just a copy paste of /applications/:id/index.ts minus delete +router.get( + "/", + route({ + responses: { + 200: { + body: "Application", + }, + 400: { + body: "APIErrorResponse", + }, + }, + }), + async (req: Request, res: Response) => { + const app = await Application.findOneOrFail({ + where: { id: req.user_id }, + relations: ["owner", "bot"], + }); + + return res.json(app); + }, +); + +router.patch( + "/", + route({ + requestBody: "ApplicationModifySchema", + responses: { + 200: { + body: "Application", + }, + 400: { + body: "APIErrorResponse", + }, + }, + }), + async (req: Request, res: Response) => { + const body = req.body as ApplicationModifySchema; + + const app = await Application.findOneOrFail({ + where: { id: req.user_id }, + relations: ["owner", "bot"], + }); + + if (body.icon) { + body.icon = await handleFile( + `/app-icons/${app.id}`, + body.icon as string, + ); + } + if (body.cover_image) { + body.cover_image = await handleFile( + `/app-icons/${app.id}`, + body.cover_image as string, + ); + } + + if (body.guild_id) { + const guild = await Guild.findOneOrFail({ + where: { id: body.guild_id }, + select: ["owner_id"], + }); + if (guild.owner_id != req.user_id) + throw new HTTPError( + "You must be the owner of the guild to link it to an application", + 400, + ); + } + + if (app.bot) { + app.bot.assign({ bio: body.description }); + await app.bot.save(); + } + + app.assign(body); + + await app.save(); + + return res.json(app); + }, +); + +export default router;