Skip to content

Commit

Permalink
Merge pull request spacebarchat#1184 from DEVTomatoCake/fix/widget.js…
Browse files Browse the repository at this point in the history
…on-channel-ordering-deleted-channels
  • Loading branch information
MaddyUnderStars authored Aug 21, 2024
2 parents b63f285 + ad2dda6 commit 346641c
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 11 deletions.
2 changes: 1 addition & 1 deletion src/api/routes/channels/#channel_id/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ router.delete(
}

await Promise.all([
Channel.delete({ id: channel_id }),
Channel.deleteChannel(channel),
emitEvent({
event: "CHANNEL_DELETE",
data: channel,
Expand Down
9 changes: 7 additions & 2 deletions src/api/routes/guilds/#guild_id/widget.json.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,13 @@ router.get(
}),
async (req: Request, res: Response) => {
const { guild_id } = req.params;

const guild = await Guild.findOneOrFail({ where: { id: guild_id } });

const guild = await Guild.findOneOrFail({
where: { id: guild_id },
select: {
channel_ordering: true,
},
});
if (!guild.widget_enabled) throw DiscordApiErrors.EMBED_DISABLED;

// Fetch existing widget invite for widget channel
Expand Down
32 changes: 24 additions & 8 deletions src/util/entities/Channel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -459,9 +459,21 @@ export class Channel extends BaseClass {
}

static async deleteChannel(channel: Channel) {
await Message.delete({ channel_id: channel.id }); //TODO we should also delete the attachments from the cdn but to do that we need to move cdn.ts in util
//TODO before deleting the channel we should check and delete other relations
// TODO Delete attachments from the CDN for messages in the channel
await Channel.delete({ id: channel.id });

const guild = await Guild.findOneOrFail({
where: { id: channel.guild_id },
select: { channel_ordering: true },
});

const updatedOrdering = guild.channel_ordering.filter(
(id) => id != channel.id,
);
await Guild.update(
{ id: channel.guild_id },
{ channel_ordering: updatedOrdering },
);
}

static async calculatePosition(
Expand All @@ -487,15 +499,19 @@ export class Channel extends BaseClass {

const channels = await Promise.all(
guild.channel_ordering.map((id) =>
Channel.findOneOrFail({ where: { id } }),
Channel.findOne({ where: { id } }),
),
);

return channels.reduce((r, v) => {
v.position = (guild as Guild).channel_ordering.indexOf(v.id);
r[v.position] = v;
return r;
}, [] as Array<Channel>);
return channels
.filter((channel) => channel !== null)
.reduce((r, v) => {
v = v as Channel;

v.position = (guild as Guild).channel_ordering.indexOf(v.id);
r[v.position] = v;
return r;
}, [] as Array<Channel>);
}

isDm() {
Expand Down

0 comments on commit 346641c

Please sign in to comment.