summary refs log tree commit diff
path: root/src/api/routes/users/#id/profile.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/api/routes/users/#id/profile.ts')
-rw-r--r--src/api/routes/users/#id/profile.ts150
1 files changed, 89 insertions, 61 deletions
diff --git a/src/api/routes/users/#id/profile.ts b/src/api/routes/users/#id/profile.ts
index de96422a..ebea805b 100644
--- a/src/api/routes/users/#id/profile.ts
+++ b/src/api/routes/users/#id/profile.ts
@@ -1,5 +1,12 @@
 import { Router, Request, Response } from "express";
-import { PublicConnectedAccount, PublicUser, User, UserPublic, Member, Guild } from "@fosscord/util";
+import {
+	PublicConnectedAccount,
+	PublicUser,
+	User,
+	UserPublic,
+	Member,
+	Guild,
+} from "@fosscord/util";
 import { route } from "@fosscord/api";
 
 const router: Router = Router();
@@ -11,81 +18,102 @@ export interface UserProfileResponse {
 	premium_since?: Date;
 }
 
-router.get("/", route({ test: { response: { body: "UserProfileResponse" } } }), async (req: Request, res: Response) => {
-	if (req.params.id === "@me") req.params.id = req.user_id;
+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 { guild_id, with_mutual_guilds } = req.query;
 
-	const user = await User.getPublicUser(req.params.id, { relations: ["connected_accounts"] });
+		const user = await User.getPublicUser(req.params.id, {
+			relations: ["connected_accounts"],
+		});
 
-	var mutual_guilds: object[] = [];
-	var premium_guild_since;
+		var mutual_guilds: object[] = [];
+		var premium_guild_since;
 
-	if (with_mutual_guilds == "true") {
-		const requested_member = await Member.find({ where: { id: req.params.id } });
-		const self_member = await Member.find({ where: { id: req.user_id } });
+		if (with_mutual_guilds == "true") {
+			const requested_member = await Member.find({
+				where: { id: req.params.id },
+			});
+			const self_member = await Member.find({
+				where: { 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) {
+			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({ where: { id: req.params.id, guild_id: guild_id }, relations: ["roles"] })
-		: undefined;
+		const guild_member =
+			guild_id && typeof guild_id == "string"
+				? await Member.findOneOrFail({
+						where: { id: req.params.id, guild_id: guild_id },
+						relations: ["roles"],
+				  })
+				: undefined;
 
-	// TODO: make proper DTO's in util?
+		// TODO: make proper DTO's in util?
 
-	const userDto = {
-		username: user.username,
-		discriminator: user.discriminator,
-		id: user.id,
-		public_flags: user.public_flags,
-		avatar: user.avatar,
-		accent_color: user.accent_color,
-		banner: user.banner,
-		bio: req.user_bot ? null : user.bio,
-		bot: user.bot
-	};
+		const userDto = {
+			username: user.username,
+			discriminator: user.discriminator,
+			id: user.id,
+			public_flags: user.public_flags,
+			avatar: user.avatar,
+			accent_color: user.accent_color,
+			banner: user.banner,
+			bio: req.user_bot ? null : user.bio,
+			bot: user.bot,
+		};
 
-	const guildMemberDto = 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,
-		roles: guild_member.roles.map(x => x.id).filter(id => id != guild_id),
-		user: userDto
-	} : undefined;
+		const guildMemberDto = 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,
+					roles: guild_member.roles
+						.map((x) => x.id)
+						.filter((id) => id != guild_id),
+					user: userDto,
+			  }
+			: undefined;
 
-	res.json({
-		connected_accounts: user.connected_accounts,
-		premium_guild_since: premium_guild_since, // TODO
-		premium_since: user.premium_since, // TODO
-		mutual_guilds: mutual_guilds, // TODO {id: "", nick: null} when ?with_mutual_guilds=true
-		user: userDto,
-		guild_member: guildMemberDto,
-	});
-});
+		res.json({
+			connected_accounts: user.connected_accounts,
+			premium_guild_since: premium_guild_since, // TODO
+			premium_since: user.premium_since, // TODO
+			mutual_guilds: mutual_guilds, // TODO {id: "", nick: null} when ?with_mutual_guilds=true
+			user: userDto,
+			guild_member: guildMemberDto,
+		});
+	},
+);
 
 export default router;