Merge branch 'fix/sendMemberInProfile' into slowcord
This commit is contained in:
commit
16ffe2d77a
@ -1,5 +1,5 @@
|
|||||||
import { Router, Request, Response } from "express";
|
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";
|
import { route } from "@fosscord/api";
|
||||||
|
|
||||||
const router: Router = Router();
|
const router: Router = Router();
|
||||||
@ -13,29 +13,40 @@ export interface UserProfileResponse {
|
|||||||
|
|
||||||
router.get("/", route({ test: { response: { body: "UserProfileResponse" } } }), async (req: Request, res: Response) => {
|
router.get("/", route({ test: { response: { body: "UserProfileResponse" } } }), async (req: Request, res: Response) => {
|
||||||
if (req.params.id === "@me") req.params.id = req.user_id;
|
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"] });
|
const user = await User.getPublicUser(req.params.id, { relations: ["connected_accounts"] });
|
||||||
|
|
||||||
var mutual_guilds: object[] = [];
|
var mutual_guilds: object[] = [];
|
||||||
var premium_guild_since;
|
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 (with_mutual_guilds) {
|
||||||
if(rmem.premium_since) {
|
const requested_member = await Member.find({ id: req.params.id, });
|
||||||
if(premium_guild_since){
|
const self_member = await Member.find({ id: req.user_id, });
|
||||||
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;
|
premium_guild_since = rmem.premium_since;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
premium_guild_since = rmem.premium_since;
|
|
||||||
}
|
}
|
||||||
}
|
for (const smem of self_member) {
|
||||||
for(const smem of self_member) {
|
if (smem.guild_id === rmem.guild_id) {
|
||||||
if (smem.guild_id === rmem.guild_id) {
|
mutual_guilds.push({ id: rmem.guild_id, nick: rmem.nick });
|
||||||
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({
|
res.json({
|
||||||
connected_accounts: user.connected_accounts,
|
connected_accounts: user.connected_accounts,
|
||||||
premium_guild_since: premium_guild_since, // TODO
|
premium_guild_since: premium_guild_since, // TODO
|
||||||
@ -51,7 +62,21 @@ router.get("/", route({ test: { response: { body: "UserProfileResponse" } } }),
|
|||||||
banner: user.banner,
|
banner: user.banner,
|
||||||
bio: req.user_bot ? null : user.bio,
|
bio: req.user_bot ? null : user.bio,
|
||||||
bot: user.bot
|
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,
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user