diff options
Diffstat (limited to '')
-rw-r--r-- | src/gateway/opcodes/LazyRequest.ts | 31 |
1 files changed, 23 insertions, 8 deletions
diff --git a/src/gateway/opcodes/LazyRequest.ts b/src/gateway/opcodes/LazyRequest.ts index ce0bb915..b7fff4d1 100644 --- a/src/gateway/opcodes/LazyRequest.ts +++ b/src/gateway/opcodes/LazyRequest.ts @@ -197,6 +197,17 @@ async function getMembers(guild_id: string, range: [number, number]) { }; } +async function subscribeToMemberEvents(this: WebSocket, user_id: string) { + if (this.events[user_id]) return false; // already subscribed as friend + if (this.member_events[user_id]) return false; // already subscribed in member list + this.member_events[user_id] = await listenEvent( + user_id, + handlePresenceUpdate.bind(this), + this.listen_options, + ); + return true; +} + export async function onLazyRequest(this: WebSocket, { d }: Payload) { // TODO: check data check.call(this, LazyRequestSchema, d); @@ -209,6 +220,16 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) { await Promise.all([ members.map(async (x) => { + if (!x) return; + const didSubscribe = await subscribeToMemberEvents.call( + this, + x, + ); + if (!didSubscribe) return; + + // if we didn't subscribe just now, this is a new subscription + // and we should send a PRESENCE_UPDATE immediately + const sessions = await Session.find({ where: { user_id: x } }); const session = getMostRelevantSession(sessions); // eslint-disable-next-line @typescript-eslint/ban-ts-comment @@ -251,14 +272,8 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) { ops.forEach((op) => { op.members.forEach(async (member) => { - if (!member) return; - if (this.events[member.user.id]) return; // already subscribed as friend - if (this.member_events[member.user.id]) return; // already subscribed in member list - this.member_events[member.user.id] = await listenEvent( - member.user.id, - handlePresenceUpdate.bind(this), - this.listen_options, - ); + if (!member?.user.id) return; + return subscribeToMemberEvents.call(this, member.user.id); }); }); |