From 00e3606f7c99eb3f9b4c6f9e0eb72234eb7d584a Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Fri, 28 Oct 2022 19:23:02 +1100 Subject: [PATCH] Fix user settings not saving properly and guild folders --- assets/schemas.json | Bin 813547 -> 844214 bytes fosscord-server.code-workspace | 3 --- src/api/routes/users/@me/settings.ts | 9 +++++---- src/util/entities/User.ts | 6 +++--- src/util/schemas/UserGuildSettingsSchema.ts | 2 +- src/util/schemas/index.ts | 3 ++- 6 files changed, 11 insertions(+), 12 deletions(-) diff --git a/assets/schemas.json b/assets/schemas.json index 464eeb66e7226bb6183a3a738ddd771a6c5cd2ff..316d512b8b189eafa01befa2afe2ad5f82f2c161 100644 GIT binary patch delta 5830 zcmc&&OKTHh6y=*&W+qb-u|BY9t<`Q+M6^(w_-L)I(2{1;NNa~Cnl`2+X-N||5)6nB z)S{5;C%9-MNL~4$kSof3f2g1Rz=CMRP919&aUE$!rpRqu6 z@b7n5ir4LCCjU0h{Jg%#Xvp}P#?ubw%}njs$VboUYxvdg;{HtfawB(s5IcB5X5HNJ zQ0$rM3_Wc};-9$tr45NcJ-^}*5TB~{uz3%V0JjL(sQ&`Hha3a>Uoh4Il!0>9!UL!R zk9&nO)QQe1p%obgG+h)FC;?%+_!H`ZuDF;7d4Q}oXar#|HIYf#Me!X}{gP#G)&RkUSRd5_wMft>CmUs-V@WuQ-OwvQ+UtZwpA?M2%aC;{n}Z8LNP zscN+Zt))k%szSqH?QJ#KjV$IjKh(J+NCL$!O+k*J(u?gA+MQ023|1WW^SvcuC7A_{ zkPBI9$Y_HeRAx>OPaFgZvh;?;t$RtL@~G|y2}0Ibx}gV~b*}jMWS^jLW1V4U(py)z zcmwf7I1q9F?~~p>&OXa^+;K~G^4=SohdbR&qLS07*XY-JBa2#r<%#=3tcEr$>Q9iq dqox*n3E0X#bn=}28kB(lx&0E5fJe|%e*n({Vfp|7 delta 695 zcmXYtOK1~O6o#2QGdFkcMAHgZd||9fn=UFftx&{(t%(&2i4Pj>qL4)mnhJ*C1AO5= zmIelUP?2cd*iCITdXa8Ivr(*A5v5|WLEKb93dJsb#mU^W`_6y=^Ph9>vr6apce|!m zlQ1@>4?NkBdU3#^$E9y!DVcv7BMymBSXqfW2sXOJiE-tTG>O1xMd_2SLjh7mbxWGm zuy^ls(kqiio~TqJ*rVY#(XY$KPWg&3`vRmU(OV%)uiiw+)j z-$eA>c4sBRhtpw=S3<##oA*yQ1Ln??HIS>Z5WE@HTb$Cmch?7V zA=+B6+Q3^h4J& { - const body = req.body as UserSettings; + const body = req.body as UserSettingsSchema; if (body.locale === "en") body.locale = "en-US"; // fix discord client crash on unkown locale const user = await User.findOneOrFail({ where: { id: req.user_id, bot: false }, + select: ["settings"] }); - user.settings = { ...user.settings, ...body }; - await user.save(); + user.settings = OrmUtils.mergeDeep(user.settings, body); + User.update({ id: user.id }, { settings: user.settings }); res.json(user.settings); }, diff --git a/src/util/entities/User.ts b/src/util/entities/User.ts index 7f37391a..700a6dae 100644 --- a/src/util/entities/User.ts +++ b/src/util/entities/User.ts @@ -453,10 +453,10 @@ export interface UserSettings { gif_auto_play: boolean; // every top guild is displayed as a "folder" guild_folders: { - color: number; + color?: number; guild_ids: string[]; - id: number; - name: string; + id?: number; + name?: string; }[]; guild_positions: string[]; // guild ids ordered by position inline_attachment_media: boolean; diff --git a/src/util/schemas/UserGuildSettingsSchema.ts b/src/util/schemas/UserGuildSettingsSchema.ts index 43028c58..e78bbf7c 100644 --- a/src/util/schemas/UserGuildSettingsSchema.ts +++ b/src/util/schemas/UserGuildSettingsSchema.ts @@ -3,7 +3,7 @@ import { UserGuildSettings, ChannelOverride } from "@fosscord/util"; // This sucks. I would use a DeepPartial, my own or typeorms, but they both generate inncorect schema export interface UserGuildSettingsSchema extends Partial> { - channel_overrides: { + channel_overrides?: { [channel_id: string]: Partial; }; } \ No newline at end of file diff --git a/src/util/schemas/index.ts b/src/util/schemas/index.ts index 8881b247..780022c6 100644 --- a/src/util/schemas/index.ts +++ b/src/util/schemas/index.ts @@ -44,4 +44,5 @@ export * from "./ChannelPermissionOverwriteSchema"; export * from "./UserGuildSettingsSchema"; export * from "./GatewayPayloadSchema"; export * from "./RolePositionUpdateSchema"; -export * from "./ChannelReorderSchema"; \ No newline at end of file +export * from "./ChannelReorderSchema"; +export * from "./UserSettingsSchema"; \ No newline at end of file