mirror of
https://github.com/spacebarchat/server.git
synced 2024-11-23 19:02:37 +01:00
Fix gateway not listening for new channels events
This commit is contained in:
parent
5d6fa7697a
commit
97e0c8709b
@ -116,7 +116,7 @@ async function consume(this: WebSocket, opts: EventOpts) {
|
||||
.has("VIEW_CHANNEL")
|
||||
)
|
||||
return;
|
||||
break;
|
||||
//No break needed here, we need to call the listenEvent function below
|
||||
case "GUILD_CREATE":
|
||||
this.events[id] = await listenEvent(id, consumer, listenOpts);
|
||||
break;
|
||||
@ -193,16 +193,11 @@ async function consume(this: WebSocket, opts: EventOpts) {
|
||||
break;
|
||||
}
|
||||
|
||||
let aa = {
|
||||
Send(this, {
|
||||
op: OPCODES.Dispatch,
|
||||
t: event,
|
||||
d: data,
|
||||
s: this.sequence++,
|
||||
}
|
||||
|
||||
//TODO remove before PR merge
|
||||
console.log(aa)
|
||||
|
||||
Send(this, aa);
|
||||
});
|
||||
opts.acknowledge?.();
|
||||
}
|
||||
|
@ -84,27 +84,24 @@ export class ChannelService {
|
||||
return
|
||||
}
|
||||
|
||||
let channel_dto = null;
|
||||
await emitEvent({
|
||||
event: "CHANNEL_DELETE",
|
||||
data: await DmChannelDTO.from(channel, [user_id]),
|
||||
user_id: user_id
|
||||
});
|
||||
|
||||
//If the owner leave we make the first recipient in the list the new owner
|
||||
if (channel.owner_id === user_id) {
|
||||
channel.owner_id = channel.recipients!.find(r => r.user_id !== user_id)!.user_id //Is there a criteria to choose the new owner?
|
||||
channel_dto = await DmChannelDTO.from(channel, [user_id])
|
||||
await emitEvent({
|
||||
event: "CHANNEL_UPDATE",
|
||||
data: channel_dto,
|
||||
data: await DmChannelDTO.from(channel, [user_id]),
|
||||
channel_id: channel.id
|
||||
});
|
||||
}
|
||||
|
||||
await channel.save()
|
||||
|
||||
await emitEvent({
|
||||
event: "CHANNEL_DELETE",
|
||||
data: channel_dto !== null ? channel_dto : await DmChannelDTO.from(channel, [user_id]),
|
||||
user_id: user_id
|
||||
});
|
||||
|
||||
await emitEvent({
|
||||
event: "CHANNEL_RECIPIENT_REMOVE", data: {
|
||||
channel_id: channel.id,
|
||||
|
@ -5,7 +5,6 @@ import { EVENT, Event } from "../interfaces";
|
||||
const events = new EventEmitter();
|
||||
|
||||
export async function emitEvent(payload: Omit<Event, "created_at">) {
|
||||
console.log(payload) //TODO remove before merge
|
||||
const id = (payload.channel_id || payload.user_id || payload.guild_id) as string;
|
||||
if (!id) return console.error("event doesn't contain any id", payload);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user