Files
discordeno/src/ws/resume.ts
T
2021-04-15 14:25:26 +02:00

61 lines
1.6 KiB
TypeScript

import { DiscordGatewayOpcodes } from "../types/codes/gateway_opcodes.ts";
import { identify } from "./identify.ts";
import { ws } from "./ws.ts";
export async function resume(shardId: number) {
ws.log("RESUMING", { shardId });
// NOW WE HANDLE RESUMING THIS SHARD
// Get the old data for this shard necessary for resuming
const oldShard = ws.shards.get(shardId);
if (!oldShard?.sessionId) return identify(shardId, ws.maxShards);
// CREATE A SHARD
const socket = await ws.createShard(shardId);
// ONLY CLOSE IF SHARD SOCKET IS STILL CONNECTED
if (oldShard.ws.readyState === WebSocket.OPEN) {
// HOW TO CLOSE OLD SHARD SOCKET!!!
oldShard.ws.close(3065, "Resuming the shard, closing old shard.");
}
// STOP OLD HEARTBEAT
clearInterval(oldShard.heartbeat.intervalId);
ws.shards.set(shardId, {
id: shardId,
ws: socket,
resumeInterval: 0,
sessionId: oldShard.sessionId,
previousSequenceNumber: oldShard.previousSequenceNumber,
resuming: false,
ready: false,
unavailableGuildIds: new Set(),
heartbeat: {
lastSentAt: 0,
lastReceivedAt: 0,
acknowledged: false,
keepAlive: false,
interval: 0,
intervalId: 0,
},
queue: oldShard.queue || [],
processingQueue: false,
queueStartedAt: Date.now(),
queueCounter: 0,
});
// Resume on open
socket.onopen = () => {
ws.shards.get(shardId)?.queue.unshift({
op: DiscordGatewayOpcodes.Resume,
d: {
token: ws.identifyPayload.token,
session_id: oldShard.sessionId,
seq: oldShard.previousSequenceNumber,
},
});
ws.processQueue(shardId);
};
}