summary refs log tree commit diff
diff options
context:
space:
mode:
authorMadeline <46743919+MaddyUnderStars@users.noreply.github.com>2022-07-16 22:22:48 +1000
committerMadeline <46743919+MaddyUnderStars@users.noreply.github.com>2022-07-16 22:22:48 +1000
commitae185c2e399e2f34f8672d26b2561c17ce4afd67 (patch)
tree9765b1313e73c663f9aab8b819f5679018dcc6db
parentRelax some of the limits (diff)
downloadserver-ae185c2e399e2f34f8672d26b2561c17ce4afd67.tar.xz
Respect with_mutual_guilds and guild_id in /users/:id/profile
-rw-r--r--api/src/routes/users/#id/profile.ts53
1 files changed, 39 insertions, 14 deletions
diff --git a/api/src/routes/users/#id/profile.ts b/api/src/routes/users/#id/profile.ts
index 4dbb84cf..eca90a83 100644
--- a/api/src/routes/users/#id/profile.ts
+++ b/api/src/routes/users/#id/profile.ts
@@ -1,5 +1,5 @@
 import { Router, Request, Response } from "express";
-import { PublicConnectedAccount, PublicUser, User, UserPublic, Member } from "@fosscord/util";
+import { PublicConnectedAccount, PublicUser, User, UserPublic, Member, Guild } from "@fosscord/util";
 import { route } from "@fosscord/api";
 
 const router: Router = Router();
@@ -13,29 +13,40 @@ export interface UserProfileResponse {
 
 router.get("/", route({ test: { response: { body: "UserProfileResponse" } } }), async (req: Request, res: Response) => {
 	if (req.params.id === "@me") req.params.id = req.user_id;
+
+	const { guild_id, with_mutual_guilds } = req.query;
+
 	const user = await User.getPublicUser(req.params.id, { relations: ["connected_accounts"] });
 
 	var mutual_guilds: object[] = [];
 	var premium_guild_since;
-	const requested_member = await Member.find( { id: req.params.id,  })
-	const self_member = await Member.find( { id: req.user_id,  })
 
-	for(const rmem of requested_member) {
-		if(rmem.premium_since) {
-			if(premium_guild_since){
-				if(premium_guild_since > rmem.premium_since) {
+	if (with_mutual_guilds) {
+		const requested_member = await Member.find({ id: req.params.id, });
+		const self_member = await Member.find({ id: req.user_id, });
+
+		for (const rmem of requested_member) {
+			if (rmem.premium_since) {
+				if (premium_guild_since) {
+					if (premium_guild_since > rmem.premium_since) {
+						premium_guild_since = rmem.premium_since;
+					}
+				} else {
 					premium_guild_since = rmem.premium_since;
 				}
-			} else {
-				premium_guild_since = rmem.premium_since;
 			}
-		}
-		for(const smem of self_member) {
-			if (smem.guild_id === rmem.guild_id) {
-				mutual_guilds.push({id: rmem.guild_id, nick: rmem.nick})
+			for (const smem of self_member) {
+				if (smem.guild_id === rmem.guild_id) {
+					mutual_guilds.push({ id: rmem.guild_id, nick: rmem.nick });
+				}
 			}
 		}
 	}
+
+	const guild_member = guild_id && typeof guild_id == "string"
+		? await Member.findOneOrFail({ id: req.params.id, guild_id: guild_id }, { relations: ["roles"] })
+		: undefined;
+
 	res.json({
 		connected_accounts: user.connected_accounts,
 		premium_guild_since: premium_guild_since, // TODO
@@ -51,7 +62,21 @@ router.get("/", route({ test: { response: { body: "UserProfileResponse" } } }),
 			banner: user.banner,
 			bio: req.user_bot ? null : user.bio,
 			bot: user.bot
-		}
+		},
+		guild_member: guild_member ? {
+			avatar: user.avatar,	// TODO
+			banner: user.banner,	// TODO
+			bio: req.user_bot ? null : user.bio, // TODO
+			communication_disabled_until: null,	// TODO
+			deaf: guild_member.deaf,
+			flags: user.flags,
+			is_pending: guild_member.pending,
+			pending: guild_member.pending,	// why is this here twice, discord?
+			joined_at: guild_member.joined_at,
+			mute: guild_member.mute,
+			nick: guild_member.nick,
+			premium_since: guild_member.premium_since,
+		} : undefined,
 	});
 });