fix: expose only public properties

This commit is contained in:
CyberL1
2026-04-19 11:17:44 +02:00
parent 748dc308e9
commit 9a46c3a712
3 changed files with 53 additions and 2 deletions
+27 -2
View File
@@ -20,7 +20,7 @@ import { route } from "@spacebar/api";
import { Badge, Config, emitEvent, FieldErrors, handleFile, Member, Relationship, User, UserUpdateEvent } from "@spacebar/util";
import { Request, Response, Router } from "express";
import { In } from "typeorm";
import { PrivateUserProjection, PublicUser, PublicUserProjection, RelationshipType, UserProfileModifySchema } from "@spacebar/schemas";
import { PartialConnectedAccountResponse, PrivateUserProjection, PublicUser, PublicUserProjection, RelationshipType, UserProfileModifySchema } from "@spacebar/schemas";
const router: Router = Router({ mergeParams: true });
@@ -123,8 +123,33 @@ router.get("/", route({ responses: { 200: { body: "UserProfileResponse" } } }),
}
}
// Only expose public propeties to response
const publicUserConnections: PartialConnectedAccountResponse[] = [];
user.connected_accounts
.filter((x) => x.visibility != 0)
.map((x) => {
const publicUserConnection = {
id: x.id,
type: x.type,
name: x.name,
verified: x.verified ?? false,
} satisfies PartialConnectedAccountResponse;
if (x.verified) {
publicUserConnection.verified = x.verified;
}
if (x.metadata_visibility != 0) {
// @ts-expect-error idk
x.metadata = x.metadata_;
}
publicUserConnections.push(publicUserConnection);
});
res.json({
connected_accounts: user.connected_accounts.filter((x) => x.visibility != 0),
connected_accounts: publicUserConnections,
premium_guild_since: premium_guild_since, // TODO
premium_since: user.premium_since, // TODO
mutual_guilds: with_mutual_guilds ? mutual_guilds : undefined, // TODO {id: "", nick: null} when ?with_mutual_guilds=true