From fafa4dedb2b212cf58bbceec2ed468d03e0c2175 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 19 Feb 2023 21:19:41 +0100 Subject: Get DSharpPlus up and running. Signed-off-by: TheArcaneBrony --- src/api/routes/oauth2/applications/@me/index.ts | 39 +++++++++++++++++++++++++ src/gateway/opcodes/Identify.ts | 3 ++ src/util/entities/Guild.ts | 2 ++ 3 files changed, 44 insertions(+) create mode 100644 src/api/routes/oauth2/applications/@me/index.ts diff --git a/src/api/routes/oauth2/applications/@me/index.ts b/src/api/routes/oauth2/applications/@me/index.ts new file mode 100644 index 00000000..79d9f9c6 --- /dev/null +++ b/src/api/routes/oauth2/applications/@me/index.ts @@ -0,0 +1,39 @@ +/* + Fosscord: A FOSS re-implementation and extension of the Discord.com backend. + Copyright (C) 2023 Fosscord and Fosscord 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 { Request, Response, Router } from "express"; +import { route } from "@fosscord/api"; +import { + Application, + ApplicationCreateSchema, + trimSpecial, + User, +} from "@fosscord/util"; + +const router: Router = Router(); + +router.get("/", route({}), async (req: Request, res: Response) => { + const results = await Application.findOne({ + where: { id: req.user_id }, + relations: ["owner", "bot"], + }); + + res.json(results).status(200); +}); + +export default router; diff --git a/src/gateway/opcodes/Identify.ts b/src/gateway/opcodes/Identify.ts index 030ca66e..6227b578 100644 --- a/src/gateway/opcodes/Identify.ts +++ b/src/gateway/opcodes/Identify.ts @@ -95,6 +95,8 @@ export async function onIdentify(this: WebSocket, data: Payload) { "guild.emojis", "guild.roles", "guild.stickers", + "guild.members", //root@Rory - 19/02/2023 - required for DSharpPlus + "guild.members.user", //root@Rory - 19/02/2023 - required for DSharpPlus "user", "roles", ], @@ -163,6 +165,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { let guilds: Partial[] = members.map((x) => ({ ...x.guild, joined_at: x.joined_at, + presences: [], //root@Rory - 19/02/2023 - required for DSharpPlus })); const pending_guilds: typeof guilds = []; diff --git a/src/util/entities/Guild.ts b/src/util/entities/Guild.ts index c835f5fc..5957896a 100644 --- a/src/util/entities/Guild.ts +++ b/src/util/entities/Guild.ts @@ -309,6 +309,8 @@ export class Guild extends BaseClass { @Column({ nullable: true }) premium_progress_bar_enabled: boolean = false; + presences: any; + static async createGuild(body: { name?: string; icon?: string | null; -- cgit 1.4.1