mirror of
https://github.com/spacebarchat/server.git
synced 2026-05-01 03:35:30 +00:00
fix: expose only public properties
This commit is contained in:
@@ -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
|
||||
|
||||
@@ -0,0 +1,25 @@
|
||||
/*
|
||||
Spacebar: A FOSS re-implementation and extension of the Discord.com backend.
|
||||
Copyright (C) 2026 Spacebar and Spacebar 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 <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
export interface PartialConnectedAccountResponse {
|
||||
id: string;
|
||||
type: string;
|
||||
name: string;
|
||||
verified: boolean;
|
||||
metadata?: object;
|
||||
}
|
||||
@@ -49,6 +49,7 @@ export * from "./InstanceStatsResponse";
|
||||
export * from "./LocationMetadataResponse";
|
||||
export * from "./MemberJoinGuildResponse";
|
||||
export * from "./OAuthAuthorizeResponse";
|
||||
export * from "./PartialConnectedAccountResponse";
|
||||
export * from "./PreloadMessagesResponseSchema";
|
||||
export * from "./RefreshUrlsResponse";
|
||||
export * from "./SettingsProtoUpdateResponse";
|
||||
|
||||
Reference in New Issue
Block a user