@discordeno/gateway 21.0.1-next.d50d47e → 21.0.1-next.d79e672

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -17,7 +17,7 @@ _export(exports, {
17
17
  }
18
18
  });
19
19
  const _nodebuffer = require("node:buffer");
20
- const _nodezlib = require("node:zlib");
20
+ const _nodezlib = /*#__PURE__*/ _interop_require_default(require("node:zlib"));
21
21
  const _types = require("@discordeno/types");
22
22
  const _utils = require("@discordeno/utils");
23
23
  const _ws = /*#__PURE__*/ _interop_require_default(require("ws"));
@@ -175,8 +175,8 @@ let DiscordenoShard = class DiscordenoShard {
175
175
  url.searchParams.set('compress', this.gatewayConfig.transportCompression);
176
176
  if (this.gatewayConfig.transportCompression === _types1.TransportCompression.zlib) {
177
177
  this.inflateBuffer = null;
178
- this.inflate = (0, _nodezlib.createInflate)({
179
- finishFlush: _nodezlib.constants.Z_SYNC_FLUSH,
178
+ this.inflate = _nodezlib.default.createInflate({
179
+ finishFlush: _nodezlib.default.constants.Z_SYNC_FLUSH,
180
180
  chunkSize: 64 * 1024
181
181
  });
182
182
  this.inflate.on('error', (e)=>{
@@ -195,17 +195,40 @@ let DiscordenoShard = class DiscordenoShard {
195
195
  });
196
196
  }
197
197
  if (this.gatewayConfig.transportCompression === _types1.TransportCompression.zstd) {
198
- const fzstd = await getFZStd().catch(()=>{
199
- this.logger.warn('[Shard] "fzstd" is not installed. Disabled transport compression.');
200
- url.searchParams.delete('compress');
201
- return null;
202
- });
203
- if (fzstd) {
204
- this.zstdDecompress = new fzstd.Decompress((data)=>{
205
- const decodedData = this.textDecoder.decode(data);
206
- const parsedData = JSON.parse(decodedData);
207
- this.decompressionPromisesQueue.shift()?.(parsedData);
198
+ if ('createZstdDecompress' in _nodezlib.default) {
199
+ this.logger.debug('[Shard] Using node:zlib zstd decompression.');
200
+ this.inflateBuffer = null;
201
+ this.inflate = _nodezlib.default.createZstdDecompress({
202
+ chunkSize: 64 * 1024
203
+ });
204
+ this.inflate.on('error', (e)=>{
205
+ this.logger.error('The was an error in decompressing a Zstd compressed payload', e);
206
+ });
207
+ this.inflate.on('data', (data)=>{
208
+ if (!(data instanceof Uint8Array)) return;
209
+ if (this.inflateBuffer) {
210
+ const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength);
211
+ newBuffer.set(this.inflateBuffer);
212
+ newBuffer.set(data, this.inflateBuffer.byteLength);
213
+ this.inflateBuffer = newBuffer;
214
+ return;
215
+ }
216
+ this.inflateBuffer = data;
208
217
  });
218
+ } else {
219
+ const fzstd = await getFZStd().catch(()=>{
220
+ this.logger.warn('[Shard] "fzstd" is not installed. Disabled transport compression.');
221
+ url.searchParams.delete('compress');
222
+ return null;
223
+ });
224
+ if (fzstd) {
225
+ this.logger.debug('[Shard] Using fzstd zstd decompression.');
226
+ this.zstdDecompress = new fzstd.Decompress((data)=>{
227
+ const decodedData = this.textDecoder.decode(data);
228
+ const parsedData = JSON.parse(decodedData);
229
+ this.decompressionPromisesQueue.shift()?.(parsedData);
230
+ });
231
+ }
209
232
  }
210
233
  }
211
234
  }
@@ -465,16 +488,31 @@ let DiscordenoShard = class DiscordenoShard {
465
488
  return JSON.parse(decodedData);
466
489
  }
467
490
  if (this.gatewayConfig.transportCompression === _types1.TransportCompression.zstd) {
468
- if (!this.zstdDecompress) {
469
- this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no instance of Decompress was found.');
470
- return null;
491
+ if (this.zstdDecompress) {
492
+ this.zstdDecompress.push(compressedData);
493
+ const decompressionPromise = new Promise((r)=>this.decompressionPromisesQueue.push(r));
494
+ return await decompressionPromise;
495
+ }
496
+ if (this.inflate) {
497
+ // Alias, used to avoid some null checks in the Promise constructor
498
+ const decompress = this.inflate;
499
+ const writePromise = new Promise((resolve, reject)=>{
500
+ decompress.write(compressedData, 'binary', (error)=>error ? reject(error) : resolve());
501
+ });
502
+ await writePromise;
503
+ if (!this.inflateBuffer) {
504
+ this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.');
505
+ return null;
506
+ }
507
+ const decodedData = this.textDecoder.decode(this.inflateBuffer);
508
+ this.inflateBuffer = null;
509
+ return JSON.parse(decodedData);
471
510
  }
472
- this.zstdDecompress.push(compressedData);
473
- const decompressionPromise = new Promise((r)=>this.decompressionPromisesQueue.push(r));
474
- return await decompressionPromise;
511
+ this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no zstd decompressor was found.');
512
+ return null;
475
513
  }
476
514
  if (this.gatewayConfig.compress) {
477
- const decompressed = (0, _nodezlib.inflateSync)(compressedData);
515
+ const decompressed = _nodezlib.default.inflateSync(compressedData);
478
516
  const decodedData = this.textDecoder.decode(decompressed);
479
517
  return JSON.parse(decodedData);
480
518
  }
@@ -688,4 +726,4 @@ let DiscordenoShard = class DiscordenoShard {
688
726
  }
689
727
  const _default = DiscordenoShard;
690
728
 
691
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/Shard.ts"],"sourcesContent":["import { Buffer } from 'node:buffer'\nimport { createInflate, type Inflate, inflateSync, constants as zlibConstants } from 'node:zlib'\nimport type { DiscordGatewayPayload, DiscordHello, DiscordReady, DiscordUpdatePresence } from '@discordeno/types'\nimport { GatewayCloseEventCodes, GatewayOpcodes } from '@discordeno/types'\nimport { camelize, delay, LeakyBucket, logger } from '@discordeno/utils'\nimport type { Decompress as ZstdDecompress } from 'fzstd'\nimport NodeWebSocket from 'ws'\nimport {\n  type ShardEvents,\n  type ShardGatewayConfig,\n  type ShardHeart,\n  ShardSocketCloseCodes,\n  type ShardSocketRequest,\n  ShardState,\n  TransportCompression,\n} from './types.js'\n\nconst ZLIB_SYNC_FLUSH = new Uint8Array([0x0, 0x0, 0xff, 0xff])\n\nlet fzstd: typeof import('fzstd')\n\n/** Since fzstd is an optional dependency, we need to import it lazily. */\nasync function getFZStd() {\n  return (fzstd ??= await import('fzstd'))\n}\n\nexport class DiscordenoShard {\n  /** The id of the shard. */\n  id: number\n  /** The connection config details that this shard will used to connect to discord. */\n  connection: ShardGatewayConfig\n  /** This contains all the heartbeat information */\n  heart: ShardHeart\n  /** The maximum of requests which can be send to discord per rate limit tick. Typically this value should not be changed. */\n  maxRequestsPerRateLimitTick: number = 120\n  /** The previous payload sequence number. */\n  previousSequenceNumber: number | null = null\n  /** In which interval (in milliseconds) the gateway resets it's rate limit. */\n  rateLimitResetInterval: number = 60000\n  /** Current session id of the shard if present. */\n  sessionId?: string\n  /** This contains the WebSocket connection to Discord, if currently connected. */\n  socket?: WebSocket\n  /** Current internal state of the this. */\n  state = ShardState.Offline\n  /** The url provided by discord to use when resuming a connection for this this. */\n  resumeGatewayUrl: string = ''\n  /** The shard related event handlers. */\n  events: ShardEvents = {}\n  /** Cache for pending gateway requests which should have been send while the gateway went offline. */\n  offlineSendQueue: (() => void)[] = []\n  /** Resolve internal waiting states. Mapped by SelectedEvents => ResolveFunction */\n  resolves = new Map<'READY' | 'RESUMED' | 'INVALID_SESSION', (payload: DiscordGatewayPayload) => void>()\n  /** Shard bucket. Only access this if you know what you are doing. Bucket for handling shard request rate limits. */\n  bucket: LeakyBucket\n  /** Logger for the bucket. */\n  logger: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /**\n   * Is the shard going offline?\n   *\n   * @remarks\n   * This will be true if the close method has been called with either 1000 or 1001\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  goingOffline = false\n  /** Text decoder used for compressed payloads. */\n  textDecoder = new TextDecoder()\n  /** ZLib Inflate instance for ZLib-stream transport payloads. */\n  inflate?: Inflate\n  /** ZLib inflate buffer. */\n  inflateBuffer: Uint8Array | null = null\n  /** ZStd Decompress instance for ZStd-stream transport payloads. */\n  zstdDecompress?: ZstdDecompress\n  /** Queue for compressed payloads for Zstd Decompress */\n  decompressionPromisesQueue: ((data: DiscordGatewayPayload) => void)[] = []\n  /**\n   * A function that will be called once the socket is closed and handleClose() has finished updating internal states.\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  resolveAfterClose?: (close: CloseEvent) => void\n\n  constructor(options: ShardCreateOptions) {\n    this.id = options.id\n    this.connection = options.connection\n    this.events = options.events\n    this.logger = options.logger ?? logger\n\n    this.heart = {\n      acknowledged: false,\n      interval: 45000,\n    }\n\n    if (options.requestIdentify) this.requestIdentify = options.requestIdentify\n    if (options.makePresence) this.makePresence = options.makePresence\n\n    this.bucket = new LeakyBucket({\n      max: this.calculateSafeRequests(),\n      refillAmount: this.calculateSafeRequests(),\n      refillInterval: 60000,\n      logger: this.logger,\n    })\n  }\n\n  /** The gateway configuration which is used to connect to Discord. */\n  get gatewayConfig(): ShardGatewayConfig {\n    return this.connection\n  }\n\n  /** The url to connect to. Initially this is the discord gateway url, and then is switched to resume gateway url once a READY is received. */\n  get connectionUrl(): string {\n    // Use || and not ?? here. ?? will cause a bug.\n    return this.resumeGatewayUrl || this.gatewayConfig.url\n  }\n\n  /** Calculate the amount of requests which can safely be made per rate limit interval, before the gateway gets disconnected due to an exceeded rate limit. */\n  calculateSafeRequests(): number {\n    // * 2 adds extra safety layer for discords OP 1 requests that we need to respond to\n    const safeRequests = this.maxRequestsPerRateLimitTick - Math.ceil(this.rateLimitResetInterval / this.heart.interval) * 2\n\n    return safeRequests < 0 ? 0 : safeRequests\n  }\n\n  async checkOffline(highPriority: boolean): Promise<void> {\n    if (this.isOpen()) return\n\n    return await new Promise<void>((resolve) => {\n      // Higher priority requests get added at the beginning of the array.\n      if (highPriority) this.offlineSendQueue.unshift(resolve)\n      else this.offlineSendQueue.push(resolve)\n    })\n  }\n\n  /** Close the socket connection to discord if present. */\n  async close(code: number, reason: string): Promise<void> {\n    this.logger.debug(`[Shard] Request for Shard #${this.id} to close the socket with code ${code}.`)\n\n    if (this.socket?.readyState !== NodeWebSocket.OPEN) {\n      this.logger.debug(`[Shard] Shard #${this.id}'s ready state is ${this.socket?.readyState}, Unable to close.`)\n      return\n    }\n\n    this.goingOffline = code === GatewayCloseEventCodes.NormalClosure || code === GatewayCloseEventCodes.GoingAway\n\n    // This has to be created before the actual call to socket.close as for example Bun calls socket.onclose immediately on the .close() call instead of waiting for the connection to end\n    const promise = new Promise((resolve) => {\n      this.resolveAfterClose = resolve\n    })\n\n    this.socket.close(code, reason)\n\n    this.logger.debug(`[Shard] Waiting for Shard #${this.id} to close the socket with code ${code}.`)\n\n    // We need to wait for the socket to be fully closed, otherwise there'll be race condition issues if we try to connect again, resulting in unexpected behavior.\n    await promise\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed the socket with code ${code}.`)\n\n    // Reset the resolveAfterClose function after it has been resolved.\n    this.resolveAfterClose = undefined\n  }\n\n  /** Connect the shard with the gateway and start heartbeating. This will not identify the shard to the gateway. */\n  async connect(): Promise<DiscordenoShard> {\n    // Only set the shard to `Connecting` state,\n    // if the connection request does not come from an identify or resume action.\n    if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n      this.state = ShardState.Connecting\n    }\n\n    this.logger.debug(`[Shard] Connecting Shard #${this.id} socket.`)\n\n    this.events.connecting?.(this)\n\n    const url = new URL(this.connectionUrl)\n    url.searchParams.set('v', this.gatewayConfig.version.toString())\n    url.searchParams.set('encoding', 'json')\n\n    // Set the compress url param and initialize the decompression contexts\n    if (this.gatewayConfig.transportCompression) {\n      url.searchParams.set('compress', this.gatewayConfig.transportCompression)\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n        this.inflateBuffer = null\n        this.inflate = createInflate({\n          finishFlush: zlibConstants.Z_SYNC_FLUSH,\n          chunkSize: 64 * 1024,\n        })\n\n        this.inflate.on('error', (e) => {\n          this.logger.error('The was an error in decompressing a ZLib compressed payload', e)\n        })\n\n        this.inflate.on('data', (data) => {\n          if (!(data instanceof Uint8Array)) return\n\n          if (this.inflateBuffer) {\n            const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength)\n            newBuffer.set(this.inflateBuffer)\n            newBuffer.set(data, this.inflateBuffer.byteLength)\n            this.inflateBuffer = newBuffer\n\n            return\n          }\n\n          this.inflateBuffer = data\n        })\n      }\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n        const fzstd = await getFZStd().catch(() => {\n          this.logger.warn('[Shard] \"fzstd\" is not installed. Disabled transport compression.')\n          url.searchParams.delete('compress')\n\n          return null\n        })\n\n        if (fzstd) {\n          this.zstdDecompress = new fzstd.Decompress((data) => {\n            const decodedData = this.textDecoder.decode(data)\n            const parsedData = JSON.parse(decodedData)\n            this.decompressionPromisesQueue.shift()?.(parsedData)\n          })\n        }\n      }\n    }\n\n    if (this.gatewayConfig.compress && this.gatewayConfig.transportCompression) {\n      this.logger.warn('[Shard] Payload compression has been disabled since transport compression is enabled as well.')\n      this.gatewayConfig.compress = false\n    }\n\n    // We check for built-in WebSocket implementations in Bun or Deno, NodeJS v22 has an implementation too but it seems to be less optimized so for now it is better to use the ws npm package\n    const shouldUseBuiltin = Reflect.has(globalThis, 'WebSocket') && (Reflect.has(globalThis, 'Bun') || Reflect.has(globalThis, 'Deno'))\n\n    // @ts-expect-error NodeWebSocket doesn't support \"dispatchEvent\", and while we don't use it, it is required on the \"WebSocket\" type\n    const socket: WebSocket = shouldUseBuiltin ? new WebSocket(url) : new NodeWebSocket(url)\n    this.socket = socket\n\n    // By default WebSocket will give us a Blob, this changes it so that it gives us an ArrayBuffer\n    socket.binaryType = 'arraybuffer'\n\n    socket.onerror = (event) => this.handleError(event)\n    socket.onclose = (closeEvent) => this.handleClose(closeEvent)\n    socket.onmessage = (messageEvent) => this.handleMessage(messageEvent)\n\n    return await new Promise((resolve) => {\n      socket.onopen = () => {\n        // Only set the shard to `Unidentified` state if the connection request does not come from an identify or resume action.\n        if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n          this.state = ShardState.Unidentified\n        }\n\n        this.logger.debug(`[Shard] Shard #${this.id} socket connected.`)\n\n        this.events.connected?.(this)\n\n        resolve(this)\n      }\n    })\n  }\n\n  /**\n   * Identify the shard to the gateway. If not connected, this will also connect the shard to the gateway.\n   * @param bypassRequest - Whether to bypass the requestIdentify handler and identify immediately. This should be used carefully as it can cause invalid sessions.\n   */\n  async identify(bypassRequest = false): Promise<void> {\n    // A new identify has been requested even though there is already a connection open.\n    // Therefore we need to close the old connection and heartbeating before creating a new one.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Identifying open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ReIdentifying, 'Re-identifying closure of old connection.')\n    }\n\n    if (!bypassRequest) {\n      await this.requestIdentify()\n    }\n\n    this.state = ShardState.Identifying\n    this.events.identifying?.(this)\n\n    // It is possible that the shard is in Heartbeating state but not identified,\n    // so check whether there is already a gateway connection existing.\n    // If not we need to create one before we identify.\n    if (!this.isOpen()) {\n      await this.connect()\n    }\n\n    this.logger.debug(`[Shard] Sending Identify payload for Shard #${this.id}.`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Identify,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          compress: this.gatewayConfig.compress,\n          properties: this.gatewayConfig.properties,\n          intents: this.gatewayConfig.intents,\n          shard: [this.id, this.gatewayConfig.totalShards],\n          presence: await this.makePresence(),\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('READY', () => {\n        resolve()\n      })\n      // When identifying too fast, Discord sends an invalid session payload.\n      // This can safely be ignored though and the shard starts a new identify action.\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('READY')\n        resolve()\n      })\n    })\n  }\n\n  /** Check whether the connection to Discord is currently open. */\n  isOpen(): boolean {\n    return this.socket?.readyState === NodeWebSocket.OPEN\n  }\n\n  /** Attempt to resume the previous shards session with the gateway. */\n  async resume(): Promise<void> {\n    this.logger.debug(`[Shard] Resuming Shard #${this.id}`)\n\n    // It has been requested to resume the Shards session.\n    // It's possible that the shard is still connected with Discord's gateway therefore we need to forcefully close it.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Resuming open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ResumeClosingOldConnection, 'Reconnecting the shard, closing old connection.')\n    }\n\n    // Shard has never identified, so we cannot resume.\n    if (!this.sessionId) {\n      this.logger.debug(`[Shard] Trying to resume Shard #${this.id} without the session id. Identifying the shard instead.`)\n\n      await this.identify()\n      return\n    }\n\n    this.state = ShardState.Resuming\n\n    // Before we can resume, we need to create a new connection with Discord's gateway.\n    await this.connect()\n\n    this.logger.debug(`[Shard] Resuming Shard #${this.id} connected. Session id: ${this.sessionId} | Sequence: ${this.previousSequenceNumber}`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Resume,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          session_id: this.sessionId,\n          seq: this.previousSequenceNumber ?? 0,\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('RESUMED', () => resolve())\n\n      // If it is attempted to resume with an invalid session id, Discord sends an invalid session payload\n      // Not erroring here since it is easy that this happens, also it would be not catchable\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('RESUMED')\n        resolve()\n      })\n    })\n  }\n\n  /**\n   * Send a message to Discord.\n   * @param highPriority - Whether this message should be send asap.\n   */\n  async send(message: ShardSocketRequest, highPriority: boolean = false): Promise<void> {\n    // Before acquiring a token from the bucket, check whether the shard is currently offline or not.\n    // Else bucket and token wait time just get wasted.\n    await this.checkOffline(highPriority)\n\n    await this.bucket.acquire(highPriority)\n\n    // It's possible, that the shard went offline after a token has been acquired from the bucket.\n    await this.checkOffline(highPriority)\n\n    this.socket?.send(JSON.stringify(message))\n  }\n\n  /** Shutdown the this. Forcefully disconnect the shard from Discord. The shard may not attempt to reconnect with Discord. */\n  async shutdown(): Promise<void> {\n    await this.close(ShardSocketCloseCodes.Shutdown, 'Shard shutting down.')\n    this.state = ShardState.Offline\n  }\n\n  /** Handle a gateway connection error */\n  handleError(error: Event): void {\n    this.logger.error(`[Shard] There was an error connecting Shard #${this.id}.`, error)\n  }\n\n  /** Handle a gateway connection close. */\n  async handleClose(close: CloseEvent): Promise<void> {\n    this.socket = undefined\n    this.stopHeartbeating()\n\n    // Clear the zlib/zstd data\n    this.inflate = undefined\n    this.zstdDecompress = undefined\n    this.inflateBuffer = null\n    this.decompressionPromisesQueue = []\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed with code ${close.code}${close.reason ? `, and reason: ${close.reason}` : ''}.`)\n\n    // Resolve the close promise if it exists\n    this.resolveAfterClose?.(close)\n\n    switch (close.code) {\n      case ShardSocketCloseCodes.TestingFinished: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // On these codes a manual start will be done.\n      case ShardSocketCloseCodes.Shutdown:\n      case ShardSocketCloseCodes.ReIdentifying:\n      case ShardSocketCloseCodes.Resharded:\n      case ShardSocketCloseCodes.ResumeClosingOldConnection: {\n        this.state = ShardState.Disconnected\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // When these codes are received something went really wrong.\n      // On those we cannot start a reconnect attempt.\n      case GatewayCloseEventCodes.AuthenticationFailed:\n      case GatewayCloseEventCodes.InvalidShard:\n      case GatewayCloseEventCodes.ShardingRequired:\n      case GatewayCloseEventCodes.InvalidApiVersion:\n      case GatewayCloseEventCodes.InvalidIntents:\n      case GatewayCloseEventCodes.DisallowedIntents: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        throw new Error(close.reason || 'Discord gave no reason! GG! You broke Discord!')\n      }\n      // Gateway connection closes which require a new identify.\n      case GatewayCloseEventCodes.NotAuthenticated:\n      case GatewayCloseEventCodes.InvalidSeq:\n      case GatewayCloseEventCodes.SessionTimedOut: {\n        this.logger.debug(`[Shard] Shard #${this.id} closed requiring re-identify.`)\n        this.state = ShardState.Identifying\n        this.events.disconnected?.(this)\n\n        await this.identify()\n        return\n      }\n      // NOTE: This case must always be right above the cases that runs with default case because of how switch works when you don't break / return, more info below.\n      case GatewayCloseEventCodes.NormalClosure:\n      case GatewayCloseEventCodes.GoingAway: {\n        // If the shard is marked as goingOffline, it stays disconnected.\n        if (this.goingOffline) {\n          this.state = ShardState.Disconnected\n          this.events.disconnected?.(this)\n\n          this.goingOffline = false\n\n          return\n        }\n\n        // Otherwise, we want the shard to go through the default case where it gets resumed, as it might be an unexpected closure from Discord or Cloudflare for example, so we don't use break / return here.\n      }\n      // Gateway connection closes on which a resume is allowed.\n      case GatewayCloseEventCodes.UnknownError:\n      case GatewayCloseEventCodes.UnknownOpcode:\n      case GatewayCloseEventCodes.DecodeError:\n      case GatewayCloseEventCodes.RateLimited:\n      case GatewayCloseEventCodes.AlreadyAuthenticated:\n      default: {\n        // We don't want to get into an infinite loop where we resume forever, so if we were already resuming we identify instead\n        this.state = this.state === ShardState.Resuming ? ShardState.Identifying : ShardState.Resuming\n        this.events.disconnected?.(this)\n\n        if (this.state === ShardState.Resuming) {\n          await this.resume()\n        } else {\n          await this.identify()\n        }\n\n        return\n      }\n    }\n  }\n\n  /** Handle an incoming gateway message. */\n  async handleMessage(message: MessageEvent): Promise<void> {\n    // The ws npm package will use a Buffer, while the global built-in will use ArrayBuffer\n    const isCompressed = message.data instanceof ArrayBuffer || message.data instanceof Buffer\n\n    const data = isCompressed ? await this.decompressPacket(message.data) : (JSON.parse(message.data) as DiscordGatewayPayload)\n\n    // Check if the decompression was not successful\n    if (!data) return\n\n    await this.handleDiscordPacket(data)\n  }\n\n  /**\n   * Decompress a zlib/zstd compressed packet\n   *\n   * @private\n   */\n  async decompressPacket(data: ArrayBuffer | Buffer): Promise<DiscordGatewayPayload | null> {\n    // A buffer is a Uint8Array under the hood. An ArrayBuffer is generic, so we need to create the Uint8Array that uses the whole ArrayBuffer\n    const compressedData: Uint8Array = data instanceof Buffer ? data : new Uint8Array(data)\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n      if (!this.inflate) {\n        this.logger.fatal('[Shard] zlib-stream transport compression was enabled but no instance of Inflate was found.')\n        return null\n      }\n\n      // Alias, used to avoid some null checks in the Promise constructor\n      const inflate = this.inflate\n\n      const writePromise = new Promise<void>((resolve, reject) => {\n        inflate.write(compressedData, 'binary', (error) => (error ? reject(error) : resolve()))\n      })\n\n      if (!endsWithMarker(compressedData, ZLIB_SYNC_FLUSH)) return null\n\n      await writePromise\n\n      if (!this.inflateBuffer) {\n        this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.')\n        return null\n      }\n\n      const decodedData = this.textDecoder.decode(this.inflateBuffer)\n      this.inflateBuffer = null\n\n      return JSON.parse(decodedData)\n    }\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n      if (!this.zstdDecompress) {\n        this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no instance of Decompress was found.')\n        return null\n      }\n\n      this.zstdDecompress.push(compressedData)\n\n      const decompressionPromise = new Promise<DiscordGatewayPayload>((r) => this.decompressionPromisesQueue.push(r))\n      return await decompressionPromise\n    }\n\n    if (this.gatewayConfig.compress) {\n      const decompressed = inflateSync(compressedData)\n      const decodedData = this.textDecoder.decode(decompressed)\n\n      return JSON.parse(decodedData)\n    }\n\n    return null\n  }\n\n  /** Handles a incoming gateway packet. */\n  async handleDiscordPacket(packet: DiscordGatewayPayload): Promise<void> {\n    // Edge case start: https://github.com/discordeno/discordeno/issues/2311\n    this.heart.lastAck = Date.now()\n    this.heart.acknowledged = true\n    // Edge case end!\n\n    switch (packet.op) {\n      case GatewayOpcodes.Heartbeat: {\n        if (!this.isOpen()) return\n\n        this.heart.lastBeat = Date.now()\n        // Discord randomly sends this requiring an immediate heartbeat back.\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n        this.events.heartbeat?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Hello: {\n        const interval = (packet.d as DiscordHello).heartbeat_interval\n        this.logger.debug(`[Shard] Shard #${this.id} received Hello`)\n        this.startHeartbeating(interval)\n\n        if (this.state !== ShardState.Resuming) {\n          const currentQueue = [...this.bucket.queue]\n          // HELLO has been send on a non resume action.\n          // This means that the shard starts a new session,\n          // therefore the rate limit interval has been reset too.\n          this.bucket = new LeakyBucket({\n            max: this.calculateSafeRequests(),\n            refillInterval: 60000,\n            refillAmount: this.calculateSafeRequests(),\n            logger: this.logger,\n          })\n\n          // Queue should not be lost on a re-identify.\n          this.bucket.queue.unshift(...currentQueue)\n        }\n\n        this.events.hello?.(this)\n\n        break\n      }\n      case GatewayOpcodes.HeartbeatACK: {\n        // Manually calculating the round trip time for users who need it.\n        if (this.heart.lastBeat) {\n          this.heart.rtt = this.heart.lastAck - this.heart.lastBeat\n        }\n\n        this.events.heartbeatAck?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Reconnect: {\n        this.logger.debug(`[Shard] Received a Reconnect for Shard #${this.id}`)\n        this.events.requestedReconnect?.(this)\n\n        await this.resume()\n\n        break\n      }\n      case GatewayOpcodes.InvalidSession: {\n        const resumable = packet.d as boolean\n        this.logger.debug(`[Shard] Received Invalid Session for Shard #${this.id} with resumable as ${resumable}`)\n\n        this.events.invalidSession?.(this, resumable)\n\n        // We need to wait for a random amount of time between 1 and 5\n        // Reference: https://discord.com/developers/docs/topics/gateway#resuming\n        await delay(Math.floor((Math.random() * 4 + 1) * 1000))\n\n        this.resolves.get('INVALID_SESSION')?.(packet)\n        this.resolves.delete('INVALID_SESSION')\n\n        // When resumable is false we need to re-identify\n        if (!resumable) {\n          await this.identify()\n\n          break\n        }\n\n        // The session is invalid but apparently it is resumable\n        await this.resume()\n\n        break\n      }\n    }\n\n    switch (packet.t) {\n      case 'RESUMED':\n        this.state = ShardState.Connected\n        this.events.resumed?.(this)\n\n        this.logger.debug(`[Shard] Shard #${this.id} received RESUMED`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('RESUMED')?.(packet)\n        this.resolves.delete('RESUMED')\n        break\n      case 'READY': {\n        const payload = packet.d as DiscordReady\n        this.events.ready?.(this)\n\n        // Important for future resumes.\n        this.resumeGatewayUrl = payload.resume_gateway_url\n        this.sessionId = payload.session_id\n\n        this.state = ShardState.Connected\n\n        this.logger.debug(`[Shard] Shard #${this.id} received READY`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        // Important when this is a re-identify\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('READY')?.(packet)\n        this.resolves.delete('READY')\n        break\n      }\n    }\n\n    // Update the sequence number if it is present\n    // `s` can be either `null` or a `number`.\n    // In order to prevent update misses when `s` is `0` we check against null.\n    if (packet.s !== null) {\n      this.previousSequenceNumber = packet.s\n    }\n\n    this.forwardToBot(packet)\n  }\n\n  forwardToBot(packet: DiscordGatewayPayload): void {\n    // The necessary handling required for the Shards connection has been finished.\n    // Now the event can be safely forwarded.\n    this.events.message?.(this, camelize(packet))\n  }\n\n  /**\n   * Override in order to make the shards presence.\n   * async in case devs create the presence based on eg. database values.\n   * Passing the shard's id there to make it easier for the dev to use this function.\n   */\n  async makePresence(): Promise<DiscordUpdatePresence | undefined> {\n    return\n  }\n\n  /**\n   * This function communicates with the management process, in order to know whether its free to identify.\n   * When this function resolves, this means that the shard is allowed to send an identify payload to discord.\n   */\n  async requestIdentify(): Promise<void> {}\n\n  /** Start sending heartbeat payloads to Discord in the provided interval. */\n  startHeartbeating(interval: number): void {\n    this.logger.debug(`[Shard] Start heartbeating on Shard #${this.id}`)\n\n    // If old heartbeast exist like after resume, clear the old ones.\n    this.stopHeartbeating()\n\n    this.heart.interval = interval\n\n    // Only set the shard's state to `Unidentified`\n    // if heartbeating has not been started due to an identify or resume action.\n    if ([ShardState.Disconnected, ShardState.Offline].includes(this.state)) {\n      this.logger.debug(`[Shard] Shard is disconnected or offline but the heartbeat was started #${this.id}`)\n      this.state = ShardState.Unidentified\n    }\n\n    // The first heartbeat needs to be send with a random delay between `0` and `interval`\n    // Using a `setTimeout(_, jitter)` here to accomplish that.\n    // `Math.random()` can be `0` so we use `0.5` if this happens\n    // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating\n    const jitter = Math.ceil(this.heart.interval * (Math.random() || 0.5))\n\n    this.heart.timeoutId = setTimeout(() => {\n      this.logger.debug(`[Shard] Beginning heartbeating process for Shard #${this.id}`)\n\n      if (!this.isOpen()) return\n\n      this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n      // Using a direct socket.send call here because heartbeat requests are reserved by us.\n      this.socket?.send(\n        JSON.stringify({\n          op: GatewayOpcodes.Heartbeat,\n          d: this.previousSequenceNumber,\n        }),\n      )\n\n      this.heart.lastBeat = Date.now()\n      this.heart.acknowledged = false\n\n      // After the random heartbeat jitter we can start a normal interval.\n      this.heart.intervalId = setInterval(async () => {\n        if (!this.isOpen()) {\n          this.logger.debug(`[Shard] Shard #${this.id} is not open, but attempted heartbeat, ignoring.`)\n          return\n        }\n\n        // The Shard did not receive a heartbeat ACK from Discord in time,\n        // therefore we have to assume that the connection has failed or got \"zombied\".\n        // The Shard needs to start a re-identify action accordingly.\n        // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating-example-gateway-heartbeat-ack\n        if (!this.heart.acknowledged) {\n          this.logger.debug(`[Shard] Heartbeat not acknowledged for Shard #${this.id}. Assuming zombied connection.`)\n          await this.close(ShardSocketCloseCodes.ZombiedConnection, 'Zombied connection, did not receive an heartbeat ACK in time.')\n          return\n        }\n\n        this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n\n        this.heart.lastBeat = Date.now()\n        this.heart.acknowledged = false\n\n        this.events.heartbeat?.(this)\n      }, this.heart.interval)\n    }, jitter)\n  }\n\n  /** Stop the heartbeating process with discord. */\n  stopHeartbeating(): void {\n    // Clear the regular heartbeat interval.\n    clearInterval(this.heart.intervalId)\n    // It's possible that the Shard got closed before the first jittered heartbeat.\n    // To go safe we should clear the related timeout too.\n    clearTimeout(this.heart.timeoutId)\n  }\n}\n\n/** Check if the buffer ends with the marker */\nfunction endsWithMarker(buffer: Uint8Array, marker: Uint8Array) {\n  if (buffer.length < marker.length) return false\n\n  for (let i = 0; i < marker.length; i++) {\n    if (buffer[buffer.length - marker.length + i] !== marker[i]) return false\n  }\n\n  return true\n}\n\nexport interface ShardCreateOptions {\n  /** The shard id */\n  id: number\n  /** The connection details */\n  connection: ShardGatewayConfig\n  /** The event handlers for events on the shard. */\n  events: ShardEvents\n  /** The logger for the shard */\n  logger?: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /** The handler to request a space to make an identify request. */\n  requestIdentify?: () => Promise<void>\n  /** Function to create the bot status to send on Identify requests */\n  makePresence?: () => Promise<DiscordUpdatePresence | undefined>\n}\n\nexport default DiscordenoShard\n"],"names":["DiscordenoShard","ZLIB_SYNC_FLUSH","Uint8Array","fzstd","getFZStd","options","maxRequestsPerRateLimitTick","previousSequenceNumber","rateLimitResetInterval","state","ShardState","Offline","resumeGatewayUrl","events","offlineSendQueue","resolves","Map","goingOffline","textDecoder","TextDecoder","inflateBuffer","decompressionPromisesQueue","id","connection","logger","heart","acknowledged","interval","requestIdentify","makePresence","bucket","LeakyBucket","max","calculateSafeRequests","refillAmount","refillInterval","gatewayConfig","connectionUrl","url","safeRequests","Math","ceil","checkOffline","highPriority","isOpen","Promise","resolve","unshift","push","close","code","reason","debug","socket","readyState","NodeWebSocket","OPEN","GatewayCloseEventCodes","NormalClosure","GoingAway","promise","resolveAfterClose","undefined","connect","Identifying","Resuming","includes","Connecting","connecting","URL","searchParams","set","version","toString","transportCompression","TransportCompression","zlib","inflate","createInflate","finishFlush","zlibConstants","Z_SYNC_FLUSH","chunkSize","on","e","error","data","newBuffer","byteLength","zstd","catch","warn","delete","zstdDecompress","Decompress","decodedData","decode","parsedData","JSON","parse","shift","compress","shouldUseBuiltin","Reflect","has","globalThis","WebSocket","binaryType","onerror","event","handleError","onclose","closeEvent","handleClose","onmessage","messageEvent","handleMessage","onopen","Unidentified","connected","identify","bypassRequest","ShardSocketCloseCodes","ReIdentifying","identifying","send","op","GatewayOpcodes","Identify","d","token","properties","intents","shard","totalShards","presence","resume","ResumeClosingOldConnection","sessionId","Resume","session_id","seq","message","acquire","stringify","shutdown","Shutdown","stopHeartbeating","TestingFinished","disconnected","Resharded","Disconnected","AuthenticationFailed","InvalidShard","ShardingRequired","InvalidApiVersion","InvalidIntents","DisallowedIntents","Error","NotAuthenticated","InvalidSeq","SessionTimedOut","UnknownError","UnknownOpcode","DecodeError","RateLimited","AlreadyAuthenticated","isCompressed","ArrayBuffer","Buffer","decompressPacket","handleDiscordPacket","compressedData","fatal","writePromise","reject","write","endsWithMarker","decompressionPromise","r","decompressed","inflateSync","packet","lastAck","Date","now","Heartbeat","lastBeat","heartbeat","Hello","heartbeat_interval","startHeartbeating","currentQueue","queue","hello","HeartbeatACK","rtt","heartbeatAck","Reconnect","requestedReconnect","InvalidSession","resumable","invalidSession","delay","floor","random","get","t","Connected","resumed","forEach","length","payload","ready","resume_gateway_url","s","forwardToBot","camelize","jitter","timeoutId","setTimeout","intervalId","setInterval","ZombiedConnection","clearInterval","clearTimeout","buffer","marker","i"],"mappings":";;;;;;;;;;;QA0BaA;eAAAA;;QAmzBb;eAAA;;;4BA70BuB;0BAC8D;uBAE9B;uBACF;2DAE3B;wBASnB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEP,MAAMC,kBAAkB,IAAIC,WAAW;IAAC;IAAK;IAAK;IAAM;CAAK;AAE7D,IAAIC;AAEJ,wEAAwE,GACxE,eAAeC;IACb,OAAQD,UAAU,MAAM,mEAAA,QAAO;AACjC;AAEO,IAAA,AAAMH,kBAAN,MAAMA;IA2DX,YAAYK,OAA2B,CAAE;QApDzC,0HAA0H,QAC1HC,8BAAsC;QACtC,0CAA0C,QAC1CC,yBAAwC;QACxC,4EAA4E,QAC5EC,yBAAiC;QAKjC,wCAAwC,QACxCC,QAAQC,kBAAU,CAACC,OAAO;QAC1B,iFAAiF,QACjFC,mBAA2B;QAC3B,sCAAsC,QACtCC,SAAsB,CAAC;QACvB,mGAAmG,QACnGC,mBAAmC,EAAE;QACrC,iFAAiF,QACjFC,WAAW,IAAIC;QAKf;;;;;;;;GAQC,QACDC,eAAe;QACf,+CAA+C,QAC/CC,cAAc,IAAIC;QAGlB,yBAAyB,QACzBC,gBAAmC;QAGnC,sDAAsD,QACtDC,6BAAwE,EAAE;QAUxE,IAAI,CAACC,EAAE,GAAGjB,QAAQiB,EAAE;QACpB,IAAI,CAACC,UAAU,GAAGlB,QAAQkB,UAAU;QACpC,IAAI,CAACV,MAAM,GAAGR,QAAQQ,MAAM;QAC5B,IAAI,CAACW,MAAM,GAAGnB,QAAQmB,MAAM,IAAIA,aAAM;QAEtC,IAAI,CAACC,KAAK,GAAG;YACXC,cAAc;YACdC,UAAU;QACZ;QAEA,IAAItB,QAAQuB,eAAe,EAAE,IAAI,CAACA,eAAe,GAAGvB,QAAQuB,eAAe;QAC3E,IAAIvB,QAAQwB,YAAY,EAAE,IAAI,CAACA,YAAY,GAAGxB,QAAQwB,YAAY;QAElE,IAAI,CAACC,MAAM,GAAG,IAAIC,kBAAW,CAAC;YAC5BC,KAAK,IAAI,CAACC,qBAAqB;YAC/BC,cAAc,IAAI,CAACD,qBAAqB;YACxCE,gBAAgB;YAChBX,QAAQ,IAAI,CAACA,MAAM;QACrB;IACF;IAEA,mEAAmE,GACnE,IAAIY,gBAAoC;QACtC,OAAO,IAAI,CAACb,UAAU;IACxB;IAEA,2IAA2I,GAC3I,IAAIc,gBAAwB;QAC1B,+CAA+C;QAC/C,OAAO,IAAI,CAACzB,gBAAgB,IAAI,IAAI,CAACwB,aAAa,CAACE,GAAG;IACxD;IAEA,2JAA2J,GAC3JL,wBAAgC;QAC9B,oFAAoF;QACpF,MAAMM,eAAe,IAAI,CAACjC,2BAA2B,GAAGkC,KAAKC,IAAI,CAAC,IAAI,CAACjC,sBAAsB,GAAG,IAAI,CAACiB,KAAK,CAACE,QAAQ,IAAI;QAEvH,OAAOY,eAAe,IAAI,IAAIA;IAChC;IAEA,MAAMG,aAAaC,YAAqB,EAAiB;QACvD,IAAI,IAAI,CAACC,MAAM,IAAI;QAEnB,OAAO,MAAM,IAAIC,QAAc,CAACC;YAC9B,oEAAoE;YACpE,IAAIH,cAAc,IAAI,CAAC7B,gBAAgB,CAACiC,OAAO,CAACD;iBAC3C,IAAI,CAAChC,gBAAgB,CAACkC,IAAI,CAACF;QAClC;IACF;IAEA,uDAAuD,GACvD,MAAMG,MAAMC,IAAY,EAAEC,MAAc,EAAiB;QACvD,IAAI,CAAC3B,MAAM,CAAC4B,KAAK,CAAC,CAAC,2BAA2B,EAAE,IAAI,CAAC9B,EAAE,CAAC,+BAA+B,EAAE4B,KAAK,CAAC,CAAC;QAEhG,IAAI,IAAI,CAACG,MAAM,EAAEC,eAAeC,WAAa,CAACC,IAAI,EAAE;YAClD,IAAI,CAAChC,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,kBAAkB,EAAE,IAAI,CAAC+B,MAAM,EAAEC,WAAW,kBAAkB,CAAC;YAC3G;QACF;QAEA,IAAI,CAACrC,YAAY,GAAGiC,SAASO,6BAAsB,CAACC,aAAa,IAAIR,SAASO,6BAAsB,CAACE,SAAS;QAE9G,sLAAsL;QACtL,MAAMC,UAAU,IAAIf,QAAQ,CAACC;YAC3B,IAAI,CAACe,iBAAiB,GAAGf;QAC3B;QAEA,IAAI,CAACO,MAAM,CAACJ,KAAK,CAACC,MAAMC;QAExB,IAAI,CAAC3B,MAAM,CAAC4B,KAAK,CAAC,CAAC,2BAA2B,EAAE,IAAI,CAAC9B,EAAE,CAAC,+BAA+B,EAAE4B,KAAK,CAAC,CAAC;QAEhG,+JAA+J;QAC/J,MAAMU;QAEN,IAAI,CAACpC,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,6BAA6B,EAAE4B,KAAK,CAAC,CAAC;QAElF,mEAAmE;QACnE,IAAI,CAACW,iBAAiB,GAAGC;IAC3B;IAEA,gHAAgH,GAChH,MAAMC,UAAoC;QACxC,4CAA4C;QAC5C,6EAA6E;QAC7E,IAAI,CAAC;YAACrD,kBAAU,CAACsD,WAAW;YAAEtD,kBAAU,CAACuD,QAAQ;SAAC,CAACC,QAAQ,CAAC,IAAI,CAACzD,KAAK,GAAG;YACvE,IAAI,CAACA,KAAK,GAAGC,kBAAU,CAACyD,UAAU;QACpC;QAEA,IAAI,CAAC3C,MAAM,CAAC4B,KAAK,CAAC,CAAC,0BAA0B,EAAE,IAAI,CAAC9B,EAAE,CAAC,QAAQ,CAAC;QAEhE,IAAI,CAACT,MAAM,CAACuD,UAAU,GAAG,IAAI;QAE7B,MAAM9B,MAAM,IAAI+B,IAAI,IAAI,CAAChC,aAAa;QACtCC,IAAIgC,YAAY,CAACC,GAAG,CAAC,KAAK,IAAI,CAACnC,aAAa,CAACoC,OAAO,CAACC,QAAQ;QAC7DnC,IAAIgC,YAAY,CAACC,GAAG,CAAC,YAAY;QAEjC,uEAAuE;QACvE,IAAI,IAAI,CAACnC,aAAa,CAACsC,oBAAoB,EAAE;YAC3CpC,IAAIgC,YAAY,CAACC,GAAG,CAAC,YAAY,IAAI,CAACnC,aAAa,CAACsC,oBAAoB;YAExE,IAAI,IAAI,CAACtC,aAAa,CAACsC,oBAAoB,KAAKC,4BAAoB,CAACC,IAAI,EAAE;gBACzE,IAAI,CAACxD,aAAa,GAAG;gBACrB,IAAI,CAACyD,OAAO,GAAGC,IAAAA,uBAAa,EAAC;oBAC3BC,aAAaC,mBAAa,CAACC,YAAY;oBACvCC,WAAW,KAAK;gBAClB;gBAEA,IAAI,CAACL,OAAO,CAACM,EAAE,CAAC,SAAS,CAACC;oBACxB,IAAI,CAAC5D,MAAM,CAAC6D,KAAK,CAAC,+DAA+DD;gBACnF;gBAEA,IAAI,CAACP,OAAO,CAACM,EAAE,CAAC,QAAQ,CAACG;oBACvB,IAAI,CAAEA,CAAAA,gBAAgBpF,UAAS,GAAI;oBAEnC,IAAI,IAAI,CAACkB,aAAa,EAAE;wBACtB,MAAMmE,YAAY,IAAIrF,WAAW,IAAI,CAACkB,aAAa,CAACoE,UAAU,GAAGF,KAAKE,UAAU;wBAChFD,UAAUhB,GAAG,CAAC,IAAI,CAACnD,aAAa;wBAChCmE,UAAUhB,GAAG,CAACe,MAAM,IAAI,CAAClE,aAAa,CAACoE,UAAU;wBACjD,IAAI,CAACpE,aAAa,GAAGmE;wBAErB;oBACF;oBAEA,IAAI,CAACnE,aAAa,GAAGkE;gBACvB;YACF;YAEA,IAAI,IAAI,CAAClD,aAAa,CAACsC,oBAAoB,KAAKC,4BAAoB,CAACc,IAAI,EAAE;gBACzE,MAAMtF,QAAQ,MAAMC,WAAWsF,KAAK,CAAC;oBACnC,IAAI,CAAClE,MAAM,CAACmE,IAAI,CAAC;oBACjBrD,IAAIgC,YAAY,CAACsB,MAAM,CAAC;oBAExB,OAAO;gBACT;gBAEA,IAAIzF,OAAO;oBACT,IAAI,CAAC0F,cAAc,GAAG,IAAI1F,MAAM2F,UAAU,CAAC,CAACR;wBAC1C,MAAMS,cAAc,IAAI,CAAC7E,WAAW,CAAC8E,MAAM,CAACV;wBAC5C,MAAMW,aAAaC,KAAKC,KAAK,CAACJ;wBAC9B,IAAI,CAAC1E,0BAA0B,CAAC+E,KAAK,KAAKH;oBAC5C;gBACF;YACF;QACF;QAEA,IAAI,IAAI,CAAC7D,aAAa,CAACiE,QAAQ,IAAI,IAAI,CAACjE,aAAa,CAACsC,oBAAoB,EAAE;YAC1E,IAAI,CAAClD,MAAM,CAACmE,IAAI,CAAC;YACjB,IAAI,CAACvD,aAAa,CAACiE,QAAQ,GAAG;QAChC;QAEA,2LAA2L;QAC3L,MAAMC,mBAAmBC,QAAQC,GAAG,CAACC,YAAY,gBAAiBF,CAAAA,QAAQC,GAAG,CAACC,YAAY,UAAUF,QAAQC,GAAG,CAACC,YAAY,OAAM;QAElI,oIAAoI;QACpI,MAAMpD,SAAoBiD,mBAAmB,IAAII,UAAUpE,OAAO,IAAIiB,WAAa,CAACjB;QACpF,IAAI,CAACe,MAAM,GAAGA;QAEd,+FAA+F;QAC/FA,OAAOsD,UAAU,GAAG;QAEpBtD,OAAOuD,OAAO,GAAG,CAACC,QAAU,IAAI,CAACC,WAAW,CAACD;QAC7CxD,OAAO0D,OAAO,GAAG,CAACC,aAAe,IAAI,CAACC,WAAW,CAACD;QAClD3D,OAAO6D,SAAS,GAAG,CAACC,eAAiB,IAAI,CAACC,aAAa,CAACD;QAExD,OAAO,MAAM,IAAItE,QAAQ,CAACC;YACxBO,OAAOgE,MAAM,GAAG;gBACd,wHAAwH;gBACxH,IAAI,CAAC;oBAAC3G,kBAAU,CAACsD,WAAW;oBAAEtD,kBAAU,CAACuD,QAAQ;iBAAC,CAACC,QAAQ,CAAC,IAAI,CAACzD,KAAK,GAAG;oBACvE,IAAI,CAACA,KAAK,GAAGC,kBAAU,CAAC4G,YAAY;gBACtC;gBAEA,IAAI,CAAC9F,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,kBAAkB,CAAC;gBAE/D,IAAI,CAACT,MAAM,CAAC0G,SAAS,GAAG,IAAI;gBAE5BzE,QAAQ,IAAI;YACd;QACF;IACF;IAEA;;;GAGC,GACD,MAAM0E,SAASC,gBAAgB,KAAK,EAAiB;QACnD,oFAAoF;QACpF,4FAA4F;QAC5F,IAAI,IAAI,CAAC7E,MAAM,IAAI;YACjB,IAAI,CAACpB,MAAM,CAAC4B,KAAK,CAAC,CAAC,gCAAgC,EAAE,IAAI,CAAC9B,EAAE,CAAC,wBAAwB,CAAC;YACtF,MAAM,IAAI,CAAC2B,KAAK,CAACyE,6BAAqB,CAACC,aAAa,EAAE;QACxD;QAEA,IAAI,CAACF,eAAe;YAClB,MAAM,IAAI,CAAC7F,eAAe;QAC5B;QAEA,IAAI,CAACnB,KAAK,GAAGC,kBAAU,CAACsD,WAAW;QACnC,IAAI,CAACnD,MAAM,CAAC+G,WAAW,GAAG,IAAI;QAE9B,6EAA6E;QAC7E,mEAAmE;QACnE,mDAAmD;QACnD,IAAI,CAAC,IAAI,CAAChF,MAAM,IAAI;YAClB,MAAM,IAAI,CAACmB,OAAO;QACpB;QAEA,IAAI,CAACvC,MAAM,CAAC4B,KAAK,CAAC,CAAC,4CAA4C,EAAE,IAAI,CAAC9B,EAAE,CAAC,CAAC,CAAC;QAE3E,IAAI,CAACuG,IAAI,CACP;YACEC,IAAIC,qBAAc,CAACC,QAAQ;YAC3BC,GAAG;gBACDC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC9F,aAAa,CAAC8F,KAAK,EAAE;gBACxC7B,UAAU,IAAI,CAACjE,aAAa,CAACiE,QAAQ;gBACrC8B,YAAY,IAAI,CAAC/F,aAAa,CAAC+F,UAAU;gBACzCC,SAAS,IAAI,CAAChG,aAAa,CAACgG,OAAO;gBACnCC,OAAO;oBAAC,IAAI,CAAC/G,EAAE;oBAAE,IAAI,CAACc,aAAa,CAACkG,WAAW;iBAAC;gBAChDC,UAAU,MAAM,IAAI,CAAC1G,YAAY;YACnC;QACF,GACA;QAGF,OAAO,MAAM,IAAIgB,QAAQ,CAACC;YACxB,IAAI,CAAC/B,QAAQ,CAACwD,GAAG,CAAC,SAAS;gBACzBzB;YACF;YACA,uEAAuE;YACvE,gFAAgF;YAChF,IAAI,CAAC/B,QAAQ,CAACwD,GAAG,CAAC,mBAAmB;gBACnC,IAAI,CAACxD,QAAQ,CAAC6E,MAAM,CAAC;gBACrB9C;YACF;QACF;IACF;IAEA,+DAA+D,GAC/DF,SAAkB;QAChB,OAAO,IAAI,CAACS,MAAM,EAAEC,eAAeC,WAAa,CAACC,IAAI;IACvD;IAEA,oEAAoE,GACpE,MAAMgF,SAAwB;QAC5B,IAAI,CAAChH,MAAM,CAAC4B,KAAK,CAAC,CAAC,wBAAwB,EAAE,IAAI,CAAC9B,EAAE,EAAE;QAEtD,sDAAsD;QACtD,mHAAmH;QACnH,IAAI,IAAI,CAACsB,MAAM,IAAI;YACjB,IAAI,CAACpB,MAAM,CAAC4B,KAAK,CAAC,CAAC,6BAA6B,EAAE,IAAI,CAAC9B,EAAE,CAAC,wBAAwB,CAAC;YACnF,MAAM,IAAI,CAAC2B,KAAK,CAACyE,6BAAqB,CAACe,0BAA0B,EAAE;QACrE;QAEA,mDAAmD;QACnD,IAAI,CAAC,IAAI,CAACC,SAAS,EAAE;YACnB,IAAI,CAAClH,MAAM,CAAC4B,KAAK,CAAC,CAAC,gCAAgC,EAAE,IAAI,CAAC9B,EAAE,CAAC,uDAAuD,CAAC;YAErH,MAAM,IAAI,CAACkG,QAAQ;YACnB;QACF;QAEA,IAAI,CAAC/G,KAAK,GAAGC,kBAAU,CAACuD,QAAQ;QAEhC,mFAAmF;QACnF,MAAM,IAAI,CAACF,OAAO;QAElB,IAAI,CAACvC,MAAM,CAAC4B,KAAK,CAAC,CAAC,wBAAwB,EAAE,IAAI,CAAC9B,EAAE,CAAC,wBAAwB,EAAE,IAAI,CAACoH,SAAS,CAAC,aAAa,EAAE,IAAI,CAACnI,sBAAsB,EAAE;QAE1I,IAAI,CAACsH,IAAI,CACP;YACEC,IAAIC,qBAAc,CAACY,MAAM;YACzBV,GAAG;gBACDC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC9F,aAAa,CAAC8F,KAAK,EAAE;gBACxCU,YAAY,IAAI,CAACF,SAAS;gBAC1BG,KAAK,IAAI,CAACtI,sBAAsB,IAAI;YACtC;QACF,GACA;QAGF,OAAO,MAAM,IAAIsC,QAAQ,CAACC;YACxB,IAAI,CAAC/B,QAAQ,CAACwD,GAAG,CAAC,WAAW,IAAMzB;YAEnC,oGAAoG;YACpG,uFAAuF;YACvF,IAAI,CAAC/B,QAAQ,CAACwD,GAAG,CAAC,mBAAmB;gBACnC,IAAI,CAACxD,QAAQ,CAAC6E,MAAM,CAAC;gBACrB9C;YACF;QACF;IACF;IAEA;;;GAGC,GACD,MAAM+E,KAAKiB,OAA2B,EAAEnG,eAAwB,KAAK,EAAiB;QACpF,iGAAiG;QACjG,mDAAmD;QACnD,MAAM,IAAI,CAACD,YAAY,CAACC;QAExB,MAAM,IAAI,CAACb,MAAM,CAACiH,OAAO,CAACpG;QAE1B,8FAA8F;QAC9F,MAAM,IAAI,CAACD,YAAY,CAACC;QAExB,IAAI,CAACU,MAAM,EAAEwE,KAAK3B,KAAK8C,SAAS,CAACF;IACnC;IAEA,0HAA0H,GAC1H,MAAMG,WAA0B;QAC9B,MAAM,IAAI,CAAChG,KAAK,CAACyE,6BAAqB,CAACwB,QAAQ,EAAE;QACjD,IAAI,CAACzI,KAAK,GAAGC,kBAAU,CAACC,OAAO;IACjC;IAEA,sCAAsC,GACtCmG,YAAYzB,KAAY,EAAQ;QAC9B,IAAI,CAAC7D,MAAM,CAAC6D,KAAK,CAAC,CAAC,6CAA6C,EAAE,IAAI,CAAC/D,EAAE,CAAC,CAAC,CAAC,EAAE+D;IAChF;IAEA,uCAAuC,GACvC,MAAM4B,YAAYhE,KAAiB,EAAiB;QAClD,IAAI,CAACI,MAAM,GAAGS;QACd,IAAI,CAACqF,gBAAgB;QAErB,2BAA2B;QAC3B,IAAI,CAACtE,OAAO,GAAGf;QACf,IAAI,CAAC+B,cAAc,GAAG/B;QACtB,IAAI,CAAC1C,aAAa,GAAG;QACrB,IAAI,CAACC,0BAA0B,GAAG,EAAE;QAEpC,IAAI,CAACG,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,kBAAkB,EAAE2B,MAAMC,IAAI,GAAGD,MAAME,MAAM,GAAG,CAAC,cAAc,EAAEF,MAAME,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC;QAEnI,yCAAyC;QACzC,IAAI,CAACU,iBAAiB,GAAGZ;QAEzB,OAAQA,MAAMC,IAAI;YAChB,KAAKwE,6BAAqB,CAAC0B,eAAe;gBAAE;oBAC1C,IAAI,CAAC3I,KAAK,GAAGC,kBAAU,CAACC,OAAO;oBAC/B,IAAI,CAACE,MAAM,CAACwI,YAAY,GAAG,IAAI;oBAE/B;gBACF;YACA,8CAA8C;YAC9C,KAAK3B,6BAAqB,CAACwB,QAAQ;YACnC,KAAKxB,6BAAqB,CAACC,aAAa;YACxC,KAAKD,6BAAqB,CAAC4B,SAAS;YACpC,KAAK5B,6BAAqB,CAACe,0BAA0B;gBAAE;oBACrD,IAAI,CAAChI,KAAK,GAAGC,kBAAU,CAAC6I,YAAY;oBACpC,IAAI,CAAC1I,MAAM,CAACwI,YAAY,GAAG,IAAI;oBAE/B;gBACF;YACA,6DAA6D;YAC7D,gDAAgD;YAChD,KAAK5F,6BAAsB,CAAC+F,oBAAoB;YAChD,KAAK/F,6BAAsB,CAACgG,YAAY;YACxC,KAAKhG,6BAAsB,CAACiG,gBAAgB;YAC5C,KAAKjG,6BAAsB,CAACkG,iBAAiB;YAC7C,KAAKlG,6BAAsB,CAACmG,cAAc;YAC1C,KAAKnG,6BAAsB,CAACoG,iBAAiB;gBAAE;oBAC7C,IAAI,CAACpJ,KAAK,GAAGC,kBAAU,CAACC,OAAO;oBAC/B,IAAI,CAACE,MAAM,CAACwI,YAAY,GAAG,IAAI;oBAE/B,MAAM,IAAIS,MAAM7G,MAAME,MAAM,IAAI;gBAClC;YACA,0DAA0D;YAC1D,KAAKM,6BAAsB,CAACsG,gBAAgB;YAC5C,KAAKtG,6BAAsB,CAACuG,UAAU;YACtC,KAAKvG,6BAAsB,CAACwG,eAAe;gBAAE;oBAC3C,IAAI,CAACzI,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,8BAA8B,CAAC;oBAC3E,IAAI,CAACb,KAAK,GAAGC,kBAAU,CAACsD,WAAW;oBACnC,IAAI,CAACnD,MAAM,CAACwI,YAAY,GAAG,IAAI;oBAE/B,MAAM,IAAI,CAAC7B,QAAQ;oBACnB;gBACF;YACA,+JAA+J;YAC/J,KAAK/D,6BAAsB,CAACC,aAAa;YACzC,KAAKD,6BAAsB,CAACE,SAAS;gBAAE;oBACrC,iEAAiE;oBACjE,IAAI,IAAI,CAAC1C,YAAY,EAAE;wBACrB,IAAI,CAACR,KAAK,GAAGC,kBAAU,CAAC6I,YAAY;wBACpC,IAAI,CAAC1I,MAAM,CAACwI,YAAY,GAAG,IAAI;wBAE/B,IAAI,CAACpI,YAAY,GAAG;wBAEpB;oBACF;gBAEA,uMAAuM;gBACzM;YACA,0DAA0D;YAC1D,KAAKwC,6BAAsB,CAACyG,YAAY;YACxC,KAAKzG,6BAAsB,CAAC0G,aAAa;YACzC,KAAK1G,6BAAsB,CAAC2G,WAAW;YACvC,KAAK3G,6BAAsB,CAAC4G,WAAW;YACvC,KAAK5G,6BAAsB,CAAC6G,oBAAoB;YAChD;gBAAS;oBACP,yHAAyH;oBACzH,IAAI,CAAC7J,KAAK,GAAG,IAAI,CAACA,KAAK,KAAKC,kBAAU,CAACuD,QAAQ,GAAGvD,kBAAU,CAACsD,WAAW,GAAGtD,kBAAU,CAACuD,QAAQ;oBAC9F,IAAI,CAACpD,MAAM,CAACwI,YAAY,GAAG,IAAI;oBAE/B,IAAI,IAAI,CAAC5I,KAAK,KAAKC,kBAAU,CAACuD,QAAQ,EAAE;wBACtC,MAAM,IAAI,CAACuE,MAAM;oBACnB,OAAO;wBACL,MAAM,IAAI,CAAChB,QAAQ;oBACrB;oBAEA;gBACF;QACF;IACF;IAEA,wCAAwC,GACxC,MAAMJ,cAAc0B,OAAqB,EAAiB;QACxD,uFAAuF;QACvF,MAAMyB,eAAezB,QAAQxD,IAAI,YAAYkF,eAAe1B,QAAQxD,IAAI,YAAYmF,kBAAM;QAE1F,MAAMnF,OAAOiF,eAAe,MAAM,IAAI,CAACG,gBAAgB,CAAC5B,QAAQxD,IAAI,IAAKY,KAAKC,KAAK,CAAC2C,QAAQxD,IAAI;QAEhG,gDAAgD;QAChD,IAAI,CAACA,MAAM;QAEX,MAAM,IAAI,CAACqF,mBAAmB,CAACrF;IACjC;IAEA;;;;GAIC,GACD,MAAMoF,iBAAiBpF,IAA0B,EAAyC;QACxF,0IAA0I;QAC1I,MAAMsF,iBAA6BtF,gBAAgBmF,kBAAM,GAAGnF,OAAO,IAAIpF,WAAWoF;QAElF,IAAI,IAAI,CAAClD,aAAa,CAACsC,oBAAoB,KAAKC,4BAAoB,CAACC,IAAI,EAAE;YACzE,IAAI,CAAC,IAAI,CAACC,OAAO,EAAE;gBACjB,IAAI,CAACrD,MAAM,CAACqJ,KAAK,CAAC;gBAClB,OAAO;YACT;YAEA,mEAAmE;YACnE,MAAMhG,UAAU,IAAI,CAACA,OAAO;YAE5B,MAAMiG,eAAe,IAAIjI,QAAc,CAACC,SAASiI;gBAC/ClG,QAAQmG,KAAK,CAACJ,gBAAgB,UAAU,CAACvF,QAAWA,QAAQ0F,OAAO1F,SAASvC;YAC9E;YAEA,IAAI,CAACmI,eAAeL,gBAAgB3K,kBAAkB,OAAO;YAE7D,MAAM6K;YAEN,IAAI,CAAC,IAAI,CAAC1J,aAAa,EAAE;gBACvB,IAAI,CAACI,MAAM,CAACmE,IAAI,CAAC;gBACjB,OAAO;YACT;YAEA,MAAMI,cAAc,IAAI,CAAC7E,WAAW,CAAC8E,MAAM,CAAC,IAAI,CAAC5E,aAAa;YAC9D,IAAI,CAACA,aAAa,GAAG;YAErB,OAAO8E,KAAKC,KAAK,CAACJ;QACpB;QAEA,IAAI,IAAI,CAAC3D,aAAa,CAACsC,oBAAoB,KAAKC,4BAAoB,CAACc,IAAI,EAAE;YACzE,IAAI,CAAC,IAAI,CAACI,cAAc,EAAE;gBACxB,IAAI,CAACrE,MAAM,CAACqJ,KAAK,CAAC;gBAClB,OAAO;YACT;YAEA,IAAI,CAAChF,cAAc,CAAC7C,IAAI,CAAC4H;YAEzB,MAAMM,uBAAuB,IAAIrI,QAA+B,CAACsI,IAAM,IAAI,CAAC9J,0BAA0B,CAAC2B,IAAI,CAACmI;YAC5G,OAAO,MAAMD;QACf;QAEA,IAAI,IAAI,CAAC9I,aAAa,CAACiE,QAAQ,EAAE;YAC/B,MAAM+E,eAAeC,IAAAA,qBAAW,EAACT;YACjC,MAAM7E,cAAc,IAAI,CAAC7E,WAAW,CAAC8E,MAAM,CAACoF;YAE5C,OAAOlF,KAAKC,KAAK,CAACJ;QACpB;QAEA,OAAO;IACT;IAEA,uCAAuC,GACvC,MAAM4E,oBAAoBW,MAA6B,EAAiB;QACtE,wEAAwE;QACxE,IAAI,CAAC7J,KAAK,CAAC8J,OAAO,GAAGC,KAAKC,GAAG;QAC7B,IAAI,CAAChK,KAAK,CAACC,YAAY,GAAG;QAC1B,iBAAiB;QAEjB,OAAQ4J,OAAOxD,EAAE;YACf,KAAKC,qBAAc,CAAC2D,SAAS;gBAAE;oBAC7B,IAAI,CAAC,IAAI,CAAC9I,MAAM,IAAI;oBAEpB,IAAI,CAACnB,KAAK,CAACkK,QAAQ,GAAGH,KAAKC,GAAG;oBAC9B,qEAAqE;oBACrE,sFAAsF;oBACtF,IAAI,CAACpI,MAAM,EAAEwE,KACX3B,KAAK8C,SAAS,CAAC;wBACblB,IAAIC,qBAAc,CAAC2D,SAAS;wBAC5BzD,GAAG,IAAI,CAAC1H,sBAAsB;oBAChC;oBAEF,IAAI,CAACM,MAAM,CAAC+K,SAAS,GAAG,IAAI;oBAE5B;gBACF;YACA,KAAK7D,qBAAc,CAAC8D,KAAK;gBAAE;oBACzB,MAAMlK,WAAW,AAAC2J,OAAOrD,CAAC,CAAkB6D,kBAAkB;oBAC9D,IAAI,CAACtK,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,eAAe,CAAC;oBAC5D,IAAI,CAACyK,iBAAiB,CAACpK;oBAEvB,IAAI,IAAI,CAAClB,KAAK,KAAKC,kBAAU,CAACuD,QAAQ,EAAE;wBACtC,MAAM+H,eAAe;+BAAI,IAAI,CAAClK,MAAM,CAACmK,KAAK;yBAAC;wBAC3C,8CAA8C;wBAC9C,kDAAkD;wBAClD,wDAAwD;wBACxD,IAAI,CAACnK,MAAM,GAAG,IAAIC,kBAAW,CAAC;4BAC5BC,KAAK,IAAI,CAACC,qBAAqB;4BAC/BE,gBAAgB;4BAChBD,cAAc,IAAI,CAACD,qBAAqB;4BACxCT,QAAQ,IAAI,CAACA,MAAM;wBACrB;wBAEA,6CAA6C;wBAC7C,IAAI,CAACM,MAAM,CAACmK,KAAK,CAAClJ,OAAO,IAAIiJ;oBAC/B;oBAEA,IAAI,CAACnL,MAAM,CAACqL,KAAK,GAAG,IAAI;oBAExB;gBACF;YACA,KAAKnE,qBAAc,CAACoE,YAAY;gBAAE;oBAChC,kEAAkE;oBAClE,IAAI,IAAI,CAAC1K,KAAK,CAACkK,QAAQ,EAAE;wBACvB,IAAI,CAAClK,KAAK,CAAC2K,GAAG,GAAG,IAAI,CAAC3K,KAAK,CAAC8J,OAAO,GAAG,IAAI,CAAC9J,KAAK,CAACkK,QAAQ;oBAC3D;oBAEA,IAAI,CAAC9K,MAAM,CAACwL,YAAY,GAAG,IAAI;oBAE/B;gBACF;YACA,KAAKtE,qBAAc,CAACuE,SAAS;gBAAE;oBAC7B,IAAI,CAAC9K,MAAM,CAAC4B,KAAK,CAAC,CAAC,wCAAwC,EAAE,IAAI,CAAC9B,EAAE,EAAE;oBACtE,IAAI,CAACT,MAAM,CAAC0L,kBAAkB,GAAG,IAAI;oBAErC,MAAM,IAAI,CAAC/D,MAAM;oBAEjB;gBACF;YACA,KAAKT,qBAAc,CAACyE,cAAc;gBAAE;oBAClC,MAAMC,YAAYnB,OAAOrD,CAAC;oBAC1B,IAAI,CAACzG,MAAM,CAAC4B,KAAK,CAAC,CAAC,4CAA4C,EAAE,IAAI,CAAC9B,EAAE,CAAC,mBAAmB,EAAEmL,WAAW;oBAEzG,IAAI,CAAC5L,MAAM,CAAC6L,cAAc,GAAG,IAAI,EAAED;oBAEnC,8DAA8D;oBAC9D,yEAAyE;oBACzE,MAAME,IAAAA,YAAK,EAACnK,KAAKoK,KAAK,CAAC,AAACpK,CAAAA,KAAKqK,MAAM,KAAK,IAAI,CAAA,IAAK;oBAEjD,IAAI,CAAC9L,QAAQ,CAAC+L,GAAG,CAAC,qBAAqBxB;oBACvC,IAAI,CAACvK,QAAQ,CAAC6E,MAAM,CAAC;oBAErB,iDAAiD;oBACjD,IAAI,CAAC6G,WAAW;wBACd,MAAM,IAAI,CAACjF,QAAQ;wBAEnB;oBACF;oBAEA,wDAAwD;oBACxD,MAAM,IAAI,CAACgB,MAAM;oBAEjB;gBACF;QACF;QAEA,OAAQ8C,OAAOyB,CAAC;YACd,KAAK;gBACH,IAAI,CAACtM,KAAK,GAAGC,kBAAU,CAACsM,SAAS;gBACjC,IAAI,CAACnM,MAAM,CAACoM,OAAO,GAAG,IAAI;gBAE1B,IAAI,CAACzL,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,iBAAiB,CAAC;gBAE9D,6EAA6E;gBAC7E,IAAI,CAACR,gBAAgB,CAACoM,OAAO,CAAC,CAACpK,UAAYA;gBAC3C,yDAAyD;gBACzD,IAAI,CAAChC,gBAAgB,CAACqM,MAAM,GAAG;gBAE/B,IAAI,CAACpM,QAAQ,CAAC+L,GAAG,CAAC,aAAaxB;gBAC/B,IAAI,CAACvK,QAAQ,CAAC6E,MAAM,CAAC;gBACrB;YACF,KAAK;gBAAS;oBACZ,MAAMwH,UAAU9B,OAAOrD,CAAC;oBACxB,IAAI,CAACpH,MAAM,CAACwM,KAAK,GAAG,IAAI;oBAExB,gCAAgC;oBAChC,IAAI,CAACzM,gBAAgB,GAAGwM,QAAQE,kBAAkB;oBAClD,IAAI,CAAC5E,SAAS,GAAG0E,QAAQxE,UAAU;oBAEnC,IAAI,CAACnI,KAAK,GAAGC,kBAAU,CAACsM,SAAS;oBAEjC,IAAI,CAACxL,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,eAAe,CAAC;oBAE5D,6EAA6E;oBAC7E,uCAAuC;oBACvC,IAAI,CAACR,gBAAgB,CAACoM,OAAO,CAAC,CAACpK,UAAYA;oBAC3C,yDAAyD;oBACzD,IAAI,CAAChC,gBAAgB,CAACqM,MAAM,GAAG;oBAE/B,IAAI,CAACpM,QAAQ,CAAC+L,GAAG,CAAC,WAAWxB;oBAC7B,IAAI,CAACvK,QAAQ,CAAC6E,MAAM,CAAC;oBACrB;gBACF;QACF;QAEA,8CAA8C;QAC9C,0CAA0C;QAC1C,2EAA2E;QAC3E,IAAI0F,OAAOiC,CAAC,KAAK,MAAM;YACrB,IAAI,CAAChN,sBAAsB,GAAG+K,OAAOiC,CAAC;QACxC;QAEA,IAAI,CAACC,YAAY,CAAClC;IACpB;IAEAkC,aAAalC,MAA6B,EAAQ;QAChD,+EAA+E;QAC/E,yCAAyC;QACzC,IAAI,CAACzK,MAAM,CAACiI,OAAO,GAAG,IAAI,EAAE2E,IAAAA,eAAQ,EAACnC;IACvC;IAEA;;;;GAIC,GACD,MAAMzJ,eAA2D;QAC/D;IACF;IAEA;;;GAGC,GACD,MAAMD,kBAAiC,CAAC;IAExC,0EAA0E,GAC1EmK,kBAAkBpK,QAAgB,EAAQ;QACxC,IAAI,CAACH,MAAM,CAAC4B,KAAK,CAAC,CAAC,qCAAqC,EAAE,IAAI,CAAC9B,EAAE,EAAE;QAEnE,iEAAiE;QACjE,IAAI,CAAC6H,gBAAgB;QAErB,IAAI,CAAC1H,KAAK,CAACE,QAAQ,GAAGA;QAEtB,+CAA+C;QAC/C,4EAA4E;QAC5E,IAAI;YAACjB,kBAAU,CAAC6I,YAAY;YAAE7I,kBAAU,CAACC,OAAO;SAAC,CAACuD,QAAQ,CAAC,IAAI,CAACzD,KAAK,GAAG;YACtE,IAAI,CAACe,MAAM,CAAC4B,KAAK,CAAC,CAAC,wEAAwE,EAAE,IAAI,CAAC9B,EAAE,EAAE;YACtG,IAAI,CAACb,KAAK,GAAGC,kBAAU,CAAC4G,YAAY;QACtC;QAEA,sFAAsF;QACtF,2DAA2D;QAC3D,6DAA6D;QAC7D,6EAA6E;QAC7E,MAAMoG,SAASlL,KAAKC,IAAI,CAAC,IAAI,CAAChB,KAAK,CAACE,QAAQ,GAAIa,CAAAA,KAAKqK,MAAM,MAAM,GAAE;QAEnE,IAAI,CAACpL,KAAK,CAACkM,SAAS,GAAGC,WAAW;YAChC,IAAI,CAACpM,MAAM,CAAC4B,KAAK,CAAC,CAAC,kDAAkD,EAAE,IAAI,CAAC9B,EAAE,EAAE;YAEhF,IAAI,CAAC,IAAI,CAACsB,MAAM,IAAI;YAEpB,IAAI,CAACpB,MAAM,CAAC4B,KAAK,CAAC,CAAC,+BAA+B,EAAE,IAAI,CAAC9B,EAAE,CAAC,4BAA4B,EAAE,IAAI,CAACf,sBAAsB,EAAE;YAEvH,sFAAsF;YACtF,IAAI,CAAC8C,MAAM,EAAEwE,KACX3B,KAAK8C,SAAS,CAAC;gBACblB,IAAIC,qBAAc,CAAC2D,SAAS;gBAC5BzD,GAAG,IAAI,CAAC1H,sBAAsB;YAChC;YAGF,IAAI,CAACkB,KAAK,CAACkK,QAAQ,GAAGH,KAAKC,GAAG;YAC9B,IAAI,CAAChK,KAAK,CAACC,YAAY,GAAG;YAE1B,oEAAoE;YACpE,IAAI,CAACD,KAAK,CAACoM,UAAU,GAAGC,YAAY;gBAClC,IAAI,CAAC,IAAI,CAAClL,MAAM,IAAI;oBAClB,IAAI,CAACpB,MAAM,CAAC4B,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC9B,EAAE,CAAC,gDAAgD,CAAC;oBAC7F;gBACF;gBAEA,kEAAkE;gBAClE,+EAA+E;gBAC/E,6DAA6D;gBAC7D,2GAA2G;gBAC3G,IAAI,CAAC,IAAI,CAACG,KAAK,CAACC,YAAY,EAAE;oBAC5B,IAAI,CAACF,MAAM,CAAC4B,KAAK,CAAC,CAAC,8CAA8C,EAAE,IAAI,CAAC9B,EAAE,CAAC,8BAA8B,CAAC;oBAC1G,MAAM,IAAI,CAAC2B,KAAK,CAACyE,6BAAqB,CAACqG,iBAAiB,EAAE;oBAC1D;gBACF;gBAEA,IAAI,CAACvM,MAAM,CAAC4B,KAAK,CAAC,CAAC,+BAA+B,EAAE,IAAI,CAAC9B,EAAE,CAAC,4BAA4B,EAAE,IAAI,CAACf,sBAAsB,EAAE;gBAEvH,sFAAsF;gBACtF,IAAI,CAAC8C,MAAM,EAAEwE,KACX3B,KAAK8C,SAAS,CAAC;oBACblB,IAAIC,qBAAc,CAAC2D,SAAS;oBAC5BzD,GAAG,IAAI,CAAC1H,sBAAsB;gBAChC;gBAGF,IAAI,CAACkB,KAAK,CAACkK,QAAQ,GAAGH,KAAKC,GAAG;gBAC9B,IAAI,CAAChK,KAAK,CAACC,YAAY,GAAG;gBAE1B,IAAI,CAACb,MAAM,CAAC+K,SAAS,GAAG,IAAI;YAC9B,GAAG,IAAI,CAACnK,KAAK,CAACE,QAAQ;QACxB,GAAG+L;IACL;IAEA,gDAAgD,GAChDvE,mBAAyB;QACvB,wCAAwC;QACxC6E,cAAc,IAAI,CAACvM,KAAK,CAACoM,UAAU;QACnC,+EAA+E;QAC/E,sDAAsD;QACtDI,aAAa,IAAI,CAACxM,KAAK,CAACkM,SAAS;IACnC;AACF;AAEA,6CAA6C,GAC7C,SAAS1C,eAAeiD,MAAkB,EAAEC,MAAkB;IAC5D,IAAID,OAAOf,MAAM,GAAGgB,OAAOhB,MAAM,EAAE,OAAO;IAE1C,IAAK,IAAIiB,IAAI,GAAGA,IAAID,OAAOhB,MAAM,EAAEiB,IAAK;QACtC,IAAIF,MAAM,CAACA,OAAOf,MAAM,GAAGgB,OAAOhB,MAAM,GAAGiB,EAAE,KAAKD,MAAM,CAACC,EAAE,EAAE,OAAO;IACtE;IAEA,OAAO;AACT;MAiBA,WAAepO"}
729
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/Shard.ts"],"sourcesContent":["import { Buffer } from 'node:buffer'\nimport zlib from 'node:zlib'\nimport type { DiscordGatewayPayload, DiscordHello, DiscordReady, DiscordUpdatePresence } from '@discordeno/types'\nimport { GatewayCloseEventCodes, GatewayOpcodes } from '@discordeno/types'\nimport { camelize, delay, LeakyBucket, logger } from '@discordeno/utils'\nimport type { Decompress as FZstdDecompress } from 'fzstd'\nimport NodeWebSocket from 'ws'\nimport {\n  type ShardEvents,\n  type ShardGatewayConfig,\n  type ShardHeart,\n  ShardSocketCloseCodes,\n  type ShardSocketRequest,\n  ShardState,\n  TransportCompression,\n} from './types.js'\n\nconst ZLIB_SYNC_FLUSH = new Uint8Array([0x0, 0x0, 0xff, 0xff])\n\nlet fzstd: typeof import('fzstd')\n\n/** Since fzstd is an optional dependency, we need to import it lazily. */\nasync function getFZStd() {\n  return (fzstd ??= await import('fzstd'))\n}\n\nexport class DiscordenoShard {\n  /** The id of the shard. */\n  id: number\n  /** The connection config details that this shard will used to connect to discord. */\n  connection: ShardGatewayConfig\n  /** This contains all the heartbeat information */\n  heart: ShardHeart\n  /** The maximum of requests which can be send to discord per rate limit tick. Typically this value should not be changed. */\n  maxRequestsPerRateLimitTick: number = 120\n  /** The previous payload sequence number. */\n  previousSequenceNumber: number | null = null\n  /** In which interval (in milliseconds) the gateway resets it's rate limit. */\n  rateLimitResetInterval: number = 60000\n  /** Current session id of the shard if present. */\n  sessionId?: string\n  /** This contains the WebSocket connection to Discord, if currently connected. */\n  socket?: WebSocket\n  /** Current internal state of the this. */\n  state = ShardState.Offline\n  /** The url provided by discord to use when resuming a connection for this this. */\n  resumeGatewayUrl: string = ''\n  /** The shard related event handlers. */\n  events: ShardEvents = {}\n  /** Cache for pending gateway requests which should have been send while the gateway went offline. */\n  offlineSendQueue: (() => void)[] = []\n  /** Resolve internal waiting states. Mapped by SelectedEvents => ResolveFunction */\n  resolves = new Map<'READY' | 'RESUMED' | 'INVALID_SESSION', (payload: DiscordGatewayPayload) => void>()\n  /** Shard bucket. Only access this if you know what you are doing. Bucket for handling shard request rate limits. */\n  bucket: LeakyBucket\n  /** Logger for the bucket. */\n  logger: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /**\n   * Is the shard going offline?\n   *\n   * @remarks\n   * This will be true if the close method has been called with either 1000 or 1001\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  goingOffline = false\n  /** Text decoder used for compressed payloads. */\n  textDecoder = new TextDecoder()\n  /** zlib Inflate or zstd decompress (from node:zlib) instance for transport payloads. */\n  inflate?: zlib.Inflate | zlib.ZstdDecompress\n  /** ZLib inflate buffer. */\n  inflateBuffer: Uint8Array | null = null\n  /** ZStd Decompress instance for ZStd-stream transport payloads. */\n  zstdDecompress?: FZstdDecompress\n  /** Queue for compressed payloads for Zstd Decompress */\n  decompressionPromisesQueue: ((data: DiscordGatewayPayload) => void)[] = []\n  /**\n   * A function that will be called once the socket is closed and handleClose() has finished updating internal states.\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  resolveAfterClose?: (close: CloseEvent) => void\n\n  constructor(options: ShardCreateOptions) {\n    this.id = options.id\n    this.connection = options.connection\n    this.events = options.events\n    this.logger = options.logger ?? logger\n\n    this.heart = {\n      acknowledged: false,\n      interval: 45000,\n    }\n\n    if (options.requestIdentify) this.requestIdentify = options.requestIdentify\n    if (options.makePresence) this.makePresence = options.makePresence\n\n    this.bucket = new LeakyBucket({\n      max: this.calculateSafeRequests(),\n      refillAmount: this.calculateSafeRequests(),\n      refillInterval: 60000,\n      logger: this.logger,\n    })\n  }\n\n  /** The gateway configuration which is used to connect to Discord. */\n  get gatewayConfig(): ShardGatewayConfig {\n    return this.connection\n  }\n\n  /** The url to connect to. Initially this is the discord gateway url, and then is switched to resume gateway url once a READY is received. */\n  get connectionUrl(): string {\n    // Use || and not ?? here. ?? will cause a bug.\n    return this.resumeGatewayUrl || this.gatewayConfig.url\n  }\n\n  /** Calculate the amount of requests which can safely be made per rate limit interval, before the gateway gets disconnected due to an exceeded rate limit. */\n  calculateSafeRequests(): number {\n    // * 2 adds extra safety layer for discords OP 1 requests that we need to respond to\n    const safeRequests = this.maxRequestsPerRateLimitTick - Math.ceil(this.rateLimitResetInterval / this.heart.interval) * 2\n\n    return safeRequests < 0 ? 0 : safeRequests\n  }\n\n  async checkOffline(highPriority: boolean): Promise<void> {\n    if (this.isOpen()) return\n\n    return await new Promise<void>((resolve) => {\n      // Higher priority requests get added at the beginning of the array.\n      if (highPriority) this.offlineSendQueue.unshift(resolve)\n      else this.offlineSendQueue.push(resolve)\n    })\n  }\n\n  /** Close the socket connection to discord if present. */\n  async close(code: number, reason: string): Promise<void> {\n    this.logger.debug(`[Shard] Request for Shard #${this.id} to close the socket with code ${code}.`)\n\n    if (this.socket?.readyState !== NodeWebSocket.OPEN) {\n      this.logger.debug(`[Shard] Shard #${this.id}'s ready state is ${this.socket?.readyState}, Unable to close.`)\n      return\n    }\n\n    this.goingOffline = code === GatewayCloseEventCodes.NormalClosure || code === GatewayCloseEventCodes.GoingAway\n\n    // This has to be created before the actual call to socket.close as for example Bun calls socket.onclose immediately on the .close() call instead of waiting for the connection to end\n    const promise = new Promise((resolve) => {\n      this.resolveAfterClose = resolve\n    })\n\n    this.socket.close(code, reason)\n\n    this.logger.debug(`[Shard] Waiting for Shard #${this.id} to close the socket with code ${code}.`)\n\n    // We need to wait for the socket to be fully closed, otherwise there'll be race condition issues if we try to connect again, resulting in unexpected behavior.\n    await promise\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed the socket with code ${code}.`)\n\n    // Reset the resolveAfterClose function after it has been resolved.\n    this.resolveAfterClose = undefined\n  }\n\n  /** Connect the shard with the gateway and start heartbeating. This will not identify the shard to the gateway. */\n  async connect(): Promise<DiscordenoShard> {\n    // Only set the shard to `Connecting` state,\n    // if the connection request does not come from an identify or resume action.\n    if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n      this.state = ShardState.Connecting\n    }\n\n    this.logger.debug(`[Shard] Connecting Shard #${this.id} socket.`)\n\n    this.events.connecting?.(this)\n\n    const url = new URL(this.connectionUrl)\n    url.searchParams.set('v', this.gatewayConfig.version.toString())\n    url.searchParams.set('encoding', 'json')\n\n    // Set the compress url param and initialize the decompression contexts\n    if (this.gatewayConfig.transportCompression) {\n      url.searchParams.set('compress', this.gatewayConfig.transportCompression)\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n        this.inflateBuffer = null\n        this.inflate = zlib.createInflate({\n          finishFlush: zlib.constants.Z_SYNC_FLUSH,\n          chunkSize: 64 * 1024,\n        })\n\n        this.inflate.on('error', (e) => {\n          this.logger.error('The was an error in decompressing a ZLib compressed payload', e)\n        })\n\n        this.inflate.on('data', (data) => {\n          if (!(data instanceof Uint8Array)) return\n\n          if (this.inflateBuffer) {\n            const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength)\n            newBuffer.set(this.inflateBuffer)\n            newBuffer.set(data, this.inflateBuffer.byteLength)\n            this.inflateBuffer = newBuffer\n\n            return\n          }\n\n          this.inflateBuffer = data\n        })\n      }\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n        if ('createZstdDecompress' in zlib) {\n          this.logger.debug('[Shard] Using node:zlib zstd decompression.')\n\n          this.inflateBuffer = null\n          this.inflate = zlib.createZstdDecompress({\n            chunkSize: 64 * 1024,\n          })\n\n          this.inflate.on('error', (e) => {\n            this.logger.error('The was an error in decompressing a Zstd compressed payload', e)\n          })\n\n          this.inflate.on('data', (data) => {\n            if (!(data instanceof Uint8Array)) return\n\n            if (this.inflateBuffer) {\n              const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength)\n              newBuffer.set(this.inflateBuffer)\n              newBuffer.set(data, this.inflateBuffer.byteLength)\n              this.inflateBuffer = newBuffer\n\n              return\n            }\n\n            this.inflateBuffer = data\n          })\n        } else {\n          const fzstd = await getFZStd().catch(() => {\n            this.logger.warn('[Shard] \"fzstd\" is not installed. Disabled transport compression.')\n            url.searchParams.delete('compress')\n\n            return null\n          })\n\n          if (fzstd) {\n            this.logger.debug('[Shard] Using fzstd zstd decompression.')\n\n            this.zstdDecompress = new fzstd.Decompress((data) => {\n              const decodedData = this.textDecoder.decode(data)\n              const parsedData = JSON.parse(decodedData)\n              this.decompressionPromisesQueue.shift()?.(parsedData)\n            })\n          }\n        }\n      }\n    }\n\n    if (this.gatewayConfig.compress && this.gatewayConfig.transportCompression) {\n      this.logger.warn('[Shard] Payload compression has been disabled since transport compression is enabled as well.')\n      this.gatewayConfig.compress = false\n    }\n\n    // We check for built-in WebSocket implementations in Bun or Deno, NodeJS v22 has an implementation too but it seems to be less optimized so for now it is better to use the ws npm package\n    const shouldUseBuiltin = Reflect.has(globalThis, 'WebSocket') && (Reflect.has(globalThis, 'Bun') || Reflect.has(globalThis, 'Deno'))\n\n    // @ts-expect-error NodeWebSocket doesn't support \"dispatchEvent\", and while we don't use it, it is required on the \"WebSocket\" type\n    const socket: WebSocket = shouldUseBuiltin ? new WebSocket(url) : new NodeWebSocket(url)\n    this.socket = socket\n\n    // By default WebSocket will give us a Blob, this changes it so that it gives us an ArrayBuffer\n    socket.binaryType = 'arraybuffer'\n\n    socket.onerror = (event) => this.handleError(event)\n    socket.onclose = (closeEvent) => this.handleClose(closeEvent)\n    socket.onmessage = (messageEvent) => this.handleMessage(messageEvent)\n\n    return await new Promise((resolve) => {\n      socket.onopen = () => {\n        // Only set the shard to `Unidentified` state if the connection request does not come from an identify or resume action.\n        if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n          this.state = ShardState.Unidentified\n        }\n\n        this.logger.debug(`[Shard] Shard #${this.id} socket connected.`)\n\n        this.events.connected?.(this)\n\n        resolve(this)\n      }\n    })\n  }\n\n  /**\n   * Identify the shard to the gateway. If not connected, this will also connect the shard to the gateway.\n   * @param bypassRequest - Whether to bypass the requestIdentify handler and identify immediately. This should be used carefully as it can cause invalid sessions.\n   */\n  async identify(bypassRequest = false): Promise<void> {\n    // A new identify has been requested even though there is already a connection open.\n    // Therefore we need to close the old connection and heartbeating before creating a new one.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Identifying open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ReIdentifying, 'Re-identifying closure of old connection.')\n    }\n\n    if (!bypassRequest) {\n      await this.requestIdentify()\n    }\n\n    this.state = ShardState.Identifying\n    this.events.identifying?.(this)\n\n    // It is possible that the shard is in Heartbeating state but not identified,\n    // so check whether there is already a gateway connection existing.\n    // If not we need to create one before we identify.\n    if (!this.isOpen()) {\n      await this.connect()\n    }\n\n    this.logger.debug(`[Shard] Sending Identify payload for Shard #${this.id}.`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Identify,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          compress: this.gatewayConfig.compress,\n          properties: this.gatewayConfig.properties,\n          intents: this.gatewayConfig.intents,\n          shard: [this.id, this.gatewayConfig.totalShards],\n          presence: await this.makePresence(),\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('READY', () => {\n        resolve()\n      })\n      // When identifying too fast, Discord sends an invalid session payload.\n      // This can safely be ignored though and the shard starts a new identify action.\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('READY')\n        resolve()\n      })\n    })\n  }\n\n  /** Check whether the connection to Discord is currently open. */\n  isOpen(): boolean {\n    return this.socket?.readyState === NodeWebSocket.OPEN\n  }\n\n  /** Attempt to resume the previous shards session with the gateway. */\n  async resume(): Promise<void> {\n    this.logger.debug(`[Shard] Resuming Shard #${this.id}`)\n\n    // It has been requested to resume the Shards session.\n    // It's possible that the shard is still connected with Discord's gateway therefore we need to forcefully close it.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Resuming open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ResumeClosingOldConnection, 'Reconnecting the shard, closing old connection.')\n    }\n\n    // Shard has never identified, so we cannot resume.\n    if (!this.sessionId) {\n      this.logger.debug(`[Shard] Trying to resume Shard #${this.id} without the session id. Identifying the shard instead.`)\n\n      await this.identify()\n      return\n    }\n\n    this.state = ShardState.Resuming\n\n    // Before we can resume, we need to create a new connection with Discord's gateway.\n    await this.connect()\n\n    this.logger.debug(`[Shard] Resuming Shard #${this.id} connected. Session id: ${this.sessionId} | Sequence: ${this.previousSequenceNumber}`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Resume,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          session_id: this.sessionId,\n          seq: this.previousSequenceNumber ?? 0,\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('RESUMED', () => resolve())\n\n      // If it is attempted to resume with an invalid session id, Discord sends an invalid session payload\n      // Not erroring here since it is easy that this happens, also it would be not catchable\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('RESUMED')\n        resolve()\n      })\n    })\n  }\n\n  /**\n   * Send a message to Discord.\n   * @param highPriority - Whether this message should be send asap.\n   */\n  async send(message: ShardSocketRequest, highPriority: boolean = false): Promise<void> {\n    // Before acquiring a token from the bucket, check whether the shard is currently offline or not.\n    // Else bucket and token wait time just get wasted.\n    await this.checkOffline(highPriority)\n\n    await this.bucket.acquire(highPriority)\n\n    // It's possible, that the shard went offline after a token has been acquired from the bucket.\n    await this.checkOffline(highPriority)\n\n    this.socket?.send(JSON.stringify(message))\n  }\n\n  /** Shutdown the this. Forcefully disconnect the shard from Discord. The shard may not attempt to reconnect with Discord. */\n  async shutdown(): Promise<void> {\n    await this.close(ShardSocketCloseCodes.Shutdown, 'Shard shutting down.')\n    this.state = ShardState.Offline\n  }\n\n  /** Handle a gateway connection error */\n  handleError(error: Event): void {\n    this.logger.error(`[Shard] There was an error connecting Shard #${this.id}.`, error)\n  }\n\n  /** Handle a gateway connection close. */\n  async handleClose(close: CloseEvent): Promise<void> {\n    this.socket = undefined\n    this.stopHeartbeating()\n\n    // Clear the zlib/zstd data\n    this.inflate = undefined\n    this.zstdDecompress = undefined\n    this.inflateBuffer = null\n    this.decompressionPromisesQueue = []\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed with code ${close.code}${close.reason ? `, and reason: ${close.reason}` : ''}.`)\n\n    // Resolve the close promise if it exists\n    this.resolveAfterClose?.(close)\n\n    switch (close.code) {\n      case ShardSocketCloseCodes.TestingFinished: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // On these codes a manual start will be done.\n      case ShardSocketCloseCodes.Shutdown:\n      case ShardSocketCloseCodes.ReIdentifying:\n      case ShardSocketCloseCodes.Resharded:\n      case ShardSocketCloseCodes.ResumeClosingOldConnection: {\n        this.state = ShardState.Disconnected\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // When these codes are received something went really wrong.\n      // On those we cannot start a reconnect attempt.\n      case GatewayCloseEventCodes.AuthenticationFailed:\n      case GatewayCloseEventCodes.InvalidShard:\n      case GatewayCloseEventCodes.ShardingRequired:\n      case GatewayCloseEventCodes.InvalidApiVersion:\n      case GatewayCloseEventCodes.InvalidIntents:\n      case GatewayCloseEventCodes.DisallowedIntents: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        throw new Error(close.reason || 'Discord gave no reason! GG! You broke Discord!')\n      }\n      // Gateway connection closes which require a new identify.\n      case GatewayCloseEventCodes.NotAuthenticated:\n      case GatewayCloseEventCodes.InvalidSeq:\n      case GatewayCloseEventCodes.SessionTimedOut: {\n        this.logger.debug(`[Shard] Shard #${this.id} closed requiring re-identify.`)\n        this.state = ShardState.Identifying\n        this.events.disconnected?.(this)\n\n        await this.identify()\n        return\n      }\n      // NOTE: This case must always be right above the cases that runs with default case because of how switch works when you don't break / return, more info below.\n      case GatewayCloseEventCodes.NormalClosure:\n      case GatewayCloseEventCodes.GoingAway: {\n        // If the shard is marked as goingOffline, it stays disconnected.\n        if (this.goingOffline) {\n          this.state = ShardState.Disconnected\n          this.events.disconnected?.(this)\n\n          this.goingOffline = false\n\n          return\n        }\n\n        // Otherwise, we want the shard to go through the default case where it gets resumed, as it might be an unexpected closure from Discord or Cloudflare for example, so we don't use break / return here.\n      }\n      // Gateway connection closes on which a resume is allowed.\n      case GatewayCloseEventCodes.UnknownError:\n      case GatewayCloseEventCodes.UnknownOpcode:\n      case GatewayCloseEventCodes.DecodeError:\n      case GatewayCloseEventCodes.RateLimited:\n      case GatewayCloseEventCodes.AlreadyAuthenticated:\n      default: {\n        // We don't want to get into an infinite loop where we resume forever, so if we were already resuming we identify instead\n        this.state = this.state === ShardState.Resuming ? ShardState.Identifying : ShardState.Resuming\n        this.events.disconnected?.(this)\n\n        if (this.state === ShardState.Resuming) {\n          await this.resume()\n        } else {\n          await this.identify()\n        }\n\n        return\n      }\n    }\n  }\n\n  /** Handle an incoming gateway message. */\n  async handleMessage(message: MessageEvent): Promise<void> {\n    // The ws npm package will use a Buffer, while the global built-in will use ArrayBuffer\n    const isCompressed = message.data instanceof ArrayBuffer || message.data instanceof Buffer\n\n    const data = isCompressed ? await this.decompressPacket(message.data) : (JSON.parse(message.data) as DiscordGatewayPayload)\n\n    // Check if the decompression was not successful\n    if (!data) return\n\n    await this.handleDiscordPacket(data)\n  }\n\n  /**\n   * Decompress a zlib/zstd compressed packet\n   *\n   * @private\n   */\n  async decompressPacket(data: ArrayBuffer | Buffer): Promise<DiscordGatewayPayload | null> {\n    // A buffer is a Uint8Array under the hood. An ArrayBuffer is generic, so we need to create the Uint8Array that uses the whole ArrayBuffer\n    const compressedData: Uint8Array = data instanceof Buffer ? data : new Uint8Array(data)\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n      if (!this.inflate) {\n        this.logger.fatal('[Shard] zlib-stream transport compression was enabled but no instance of Inflate was found.')\n        return null\n      }\n\n      // Alias, used to avoid some null checks in the Promise constructor\n      const inflate = this.inflate\n\n      const writePromise = new Promise<void>((resolve, reject) => {\n        inflate.write(compressedData, 'binary', (error) => (error ? reject(error) : resolve()))\n      })\n\n      if (!endsWithMarker(compressedData, ZLIB_SYNC_FLUSH)) return null\n\n      await writePromise\n\n      if (!this.inflateBuffer) {\n        this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.')\n        return null\n      }\n\n      const decodedData = this.textDecoder.decode(this.inflateBuffer)\n      this.inflateBuffer = null\n\n      return JSON.parse(decodedData)\n    }\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n      if (this.zstdDecompress) {\n        this.zstdDecompress.push(compressedData)\n\n        const decompressionPromise = new Promise<DiscordGatewayPayload>((r) => this.decompressionPromisesQueue.push(r))\n        return await decompressionPromise\n      }\n\n      if (this.inflate) {\n        // Alias, used to avoid some null checks in the Promise constructor\n        const decompress = this.inflate\n\n        const writePromise = new Promise<void>((resolve, reject) => {\n          decompress.write(compressedData, 'binary', (error) => (error ? reject(error) : resolve()))\n        })\n\n        await writePromise\n\n        if (!this.inflateBuffer) {\n          this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.')\n          return null\n        }\n\n        const decodedData = this.textDecoder.decode(this.inflateBuffer)\n        this.inflateBuffer = null\n\n        return JSON.parse(decodedData)\n      }\n\n      this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no zstd decompressor was found.')\n      return null\n    }\n\n    if (this.gatewayConfig.compress) {\n      const decompressed = zlib.inflateSync(compressedData)\n      const decodedData = this.textDecoder.decode(decompressed)\n\n      return JSON.parse(decodedData)\n    }\n\n    return null\n  }\n\n  /** Handles a incoming gateway packet. */\n  async handleDiscordPacket(packet: DiscordGatewayPayload): Promise<void> {\n    // Edge case start: https://github.com/discordeno/discordeno/issues/2311\n    this.heart.lastAck = Date.now()\n    this.heart.acknowledged = true\n    // Edge case end!\n\n    switch (packet.op) {\n      case GatewayOpcodes.Heartbeat: {\n        if (!this.isOpen()) return\n\n        this.heart.lastBeat = Date.now()\n        // Discord randomly sends this requiring an immediate heartbeat back.\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n        this.events.heartbeat?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Hello: {\n        const interval = (packet.d as DiscordHello).heartbeat_interval\n        this.logger.debug(`[Shard] Shard #${this.id} received Hello`)\n        this.startHeartbeating(interval)\n\n        if (this.state !== ShardState.Resuming) {\n          const currentQueue = [...this.bucket.queue]\n          // HELLO has been send on a non resume action.\n          // This means that the shard starts a new session,\n          // therefore the rate limit interval has been reset too.\n          this.bucket = new LeakyBucket({\n            max: this.calculateSafeRequests(),\n            refillInterval: 60000,\n            refillAmount: this.calculateSafeRequests(),\n            logger: this.logger,\n          })\n\n          // Queue should not be lost on a re-identify.\n          this.bucket.queue.unshift(...currentQueue)\n        }\n\n        this.events.hello?.(this)\n\n        break\n      }\n      case GatewayOpcodes.HeartbeatACK: {\n        // Manually calculating the round trip time for users who need it.\n        if (this.heart.lastBeat) {\n          this.heart.rtt = this.heart.lastAck - this.heart.lastBeat\n        }\n\n        this.events.heartbeatAck?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Reconnect: {\n        this.logger.debug(`[Shard] Received a Reconnect for Shard #${this.id}`)\n        this.events.requestedReconnect?.(this)\n\n        await this.resume()\n\n        break\n      }\n      case GatewayOpcodes.InvalidSession: {\n        const resumable = packet.d as boolean\n        this.logger.debug(`[Shard] Received Invalid Session for Shard #${this.id} with resumable as ${resumable}`)\n\n        this.events.invalidSession?.(this, resumable)\n\n        // We need to wait for a random amount of time between 1 and 5\n        // Reference: https://discord.com/developers/docs/topics/gateway#resuming\n        await delay(Math.floor((Math.random() * 4 + 1) * 1000))\n\n        this.resolves.get('INVALID_SESSION')?.(packet)\n        this.resolves.delete('INVALID_SESSION')\n\n        // When resumable is false we need to re-identify\n        if (!resumable) {\n          await this.identify()\n\n          break\n        }\n\n        // The session is invalid but apparently it is resumable\n        await this.resume()\n\n        break\n      }\n    }\n\n    switch (packet.t) {\n      case 'RESUMED':\n        this.state = ShardState.Connected\n        this.events.resumed?.(this)\n\n        this.logger.debug(`[Shard] Shard #${this.id} received RESUMED`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('RESUMED')?.(packet)\n        this.resolves.delete('RESUMED')\n        break\n      case 'READY': {\n        const payload = packet.d as DiscordReady\n        this.events.ready?.(this)\n\n        // Important for future resumes.\n        this.resumeGatewayUrl = payload.resume_gateway_url\n        this.sessionId = payload.session_id\n\n        this.state = ShardState.Connected\n\n        this.logger.debug(`[Shard] Shard #${this.id} received READY`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        // Important when this is a re-identify\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('READY')?.(packet)\n        this.resolves.delete('READY')\n        break\n      }\n    }\n\n    // Update the sequence number if it is present\n    // `s` can be either `null` or a `number`.\n    // In order to prevent update misses when `s` is `0` we check against null.\n    if (packet.s !== null) {\n      this.previousSequenceNumber = packet.s\n    }\n\n    this.forwardToBot(packet)\n  }\n\n  forwardToBot(packet: DiscordGatewayPayload): void {\n    // The necessary handling required for the Shards connection has been finished.\n    // Now the event can be safely forwarded.\n    this.events.message?.(this, camelize(packet))\n  }\n\n  /**\n   * Override in order to make the shards presence.\n   * async in case devs create the presence based on eg. database values.\n   * Passing the shard's id there to make it easier for the dev to use this function.\n   */\n  async makePresence(): Promise<DiscordUpdatePresence | undefined> {\n    return\n  }\n\n  /**\n   * This function communicates with the management process, in order to know whether its free to identify.\n   * When this function resolves, this means that the shard is allowed to send an identify payload to discord.\n   */\n  async requestIdentify(): Promise<void> {}\n\n  /** Start sending heartbeat payloads to Discord in the provided interval. */\n  startHeartbeating(interval: number): void {\n    this.logger.debug(`[Shard] Start heartbeating on Shard #${this.id}`)\n\n    // If old heartbeast exist like after resume, clear the old ones.\n    this.stopHeartbeating()\n\n    this.heart.interval = interval\n\n    // Only set the shard's state to `Unidentified`\n    // if heartbeating has not been started due to an identify or resume action.\n    if ([ShardState.Disconnected, ShardState.Offline].includes(this.state)) {\n      this.logger.debug(`[Shard] Shard is disconnected or offline but the heartbeat was started #${this.id}`)\n      this.state = ShardState.Unidentified\n    }\n\n    // The first heartbeat needs to be send with a random delay between `0` and `interval`\n    // Using a `setTimeout(_, jitter)` here to accomplish that.\n    // `Math.random()` can be `0` so we use `0.5` if this happens\n    // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating\n    const jitter = Math.ceil(this.heart.interval * (Math.random() || 0.5))\n\n    this.heart.timeoutId = setTimeout(() => {\n      this.logger.debug(`[Shard] Beginning heartbeating process for Shard #${this.id}`)\n\n      if (!this.isOpen()) return\n\n      this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n      // Using a direct socket.send call here because heartbeat requests are reserved by us.\n      this.socket?.send(\n        JSON.stringify({\n          op: GatewayOpcodes.Heartbeat,\n          d: this.previousSequenceNumber,\n        }),\n      )\n\n      this.heart.lastBeat = Date.now()\n      this.heart.acknowledged = false\n\n      // After the random heartbeat jitter we can start a normal interval.\n      this.heart.intervalId = setInterval(async () => {\n        if (!this.isOpen()) {\n          this.logger.debug(`[Shard] Shard #${this.id} is not open, but attempted heartbeat, ignoring.`)\n          return\n        }\n\n        // The Shard did not receive a heartbeat ACK from Discord in time,\n        // therefore we have to assume that the connection has failed or got \"zombied\".\n        // The Shard needs to start a re-identify action accordingly.\n        // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating-example-gateway-heartbeat-ack\n        if (!this.heart.acknowledged) {\n          this.logger.debug(`[Shard] Heartbeat not acknowledged for Shard #${this.id}. Assuming zombied connection.`)\n          await this.close(ShardSocketCloseCodes.ZombiedConnection, 'Zombied connection, did not receive an heartbeat ACK in time.')\n          return\n        }\n\n        this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n\n        this.heart.lastBeat = Date.now()\n        this.heart.acknowledged = false\n\n        this.events.heartbeat?.(this)\n      }, this.heart.interval)\n    }, jitter)\n  }\n\n  /** Stop the heartbeating process with discord. */\n  stopHeartbeating(): void {\n    // Clear the regular heartbeat interval.\n    clearInterval(this.heart.intervalId)\n    // It's possible that the Shard got closed before the first jittered heartbeat.\n    // To go safe we should clear the related timeout too.\n    clearTimeout(this.heart.timeoutId)\n  }\n}\n\n/** Check if the buffer ends with the marker */\nfunction endsWithMarker(buffer: Uint8Array, marker: Uint8Array) {\n  if (buffer.length < marker.length) return false\n\n  for (let i = 0; i < marker.length; i++) {\n    if (buffer[buffer.length - marker.length + i] !== marker[i]) return false\n  }\n\n  return true\n}\n\nexport interface ShardCreateOptions {\n  /** The shard id */\n  id: number\n  /** The connection details */\n  connection: ShardGatewayConfig\n  /** The event handlers for events on the shard. */\n  events: ShardEvents\n  /** The logger for the shard */\n  logger?: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /** The handler to request a space to make an identify request. */\n  requestIdentify?: () => Promise<void>\n  /** Function to create the bot status to send on Identify requests */\n  makePresence?: () => Promise<DiscordUpdatePresence | undefined>\n}\n\nexport default DiscordenoShard\n"],"names":["DiscordenoShard","ZLIB_SYNC_FLUSH","Uint8Array","fzstd","getFZStd","options","maxRequestsPerRateLimitTick","previousSequenceNumber","rateLimitResetInterval","state","ShardState","Offline","resumeGatewayUrl","events","offlineSendQueue","resolves","Map","goingOffline","textDecoder","TextDecoder","inflateBuffer","decompressionPromisesQueue","id","connection","logger","heart","acknowledged","interval","requestIdentify","makePresence","bucket","LeakyBucket","max","calculateSafeRequests","refillAmount","refillInterval","gatewayConfig","connectionUrl","url","safeRequests","Math","ceil","checkOffline","highPriority","isOpen","Promise","resolve","unshift","push","close","code","reason","debug","socket","readyState","NodeWebSocket","OPEN","GatewayCloseEventCodes","NormalClosure","GoingAway","promise","resolveAfterClose","undefined","connect","Identifying","Resuming","includes","Connecting","connecting","URL","searchParams","set","version","toString","transportCompression","TransportCompression","zlib","inflate","createInflate","finishFlush","constants","Z_SYNC_FLUSH","chunkSize","on","e","error","data","newBuffer","byteLength","zstd","createZstdDecompress","catch","warn","delete","zstdDecompress","Decompress","decodedData","decode","parsedData","JSON","parse","shift","compress","shouldUseBuiltin","Reflect","has","globalThis","WebSocket","binaryType","onerror","event","handleError","onclose","closeEvent","handleClose","onmessage","messageEvent","handleMessage","onopen","Unidentified","connected","identify","bypassRequest","ShardSocketCloseCodes","ReIdentifying","identifying","send","op","GatewayOpcodes","Identify","d","token","properties","intents","shard","totalShards","presence","resume","ResumeClosingOldConnection","sessionId","Resume","session_id","seq","message","acquire","stringify","shutdown","Shutdown","stopHeartbeating","TestingFinished","disconnected","Resharded","Disconnected","AuthenticationFailed","InvalidShard","ShardingRequired","InvalidApiVersion","InvalidIntents","DisallowedIntents","Error","NotAuthenticated","InvalidSeq","SessionTimedOut","UnknownError","UnknownOpcode","DecodeError","RateLimited","AlreadyAuthenticated","isCompressed","ArrayBuffer","Buffer","decompressPacket","handleDiscordPacket","compressedData","fatal","writePromise","reject","write","endsWithMarker","decompressionPromise","r","decompress","decompressed","inflateSync","packet","lastAck","Date","now","Heartbeat","lastBeat","heartbeat","Hello","heartbeat_interval","startHeartbeating","currentQueue","queue","hello","HeartbeatACK","rtt","heartbeatAck","Reconnect","requestedReconnect","InvalidSession","resumable","invalidSession","delay","floor","random","get","t","Connected","resumed","forEach","length","payload","ready","resume_gateway_url","s","forwardToBot","camelize","jitter","timeoutId","setTimeout","intervalId","setInterval","ZombiedConnection","clearInterval","clearTimeout","buffer","marker","i"],"mappings":"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"}
@@ -42,7 +42,9 @@ var TransportCompression = /*#__PURE__*/ function(TransportCompression) {
42
42
  * ZStd-Stream Transport Compression.
43
43
  *
44
44
  * @remarks
45
- * Uses `fzstd` to decompress the payloads. `fzstd` is an optional dependency, it is required to be installed for this compression.
45
+ * This will use `node:zlib` zstd implementation if available (node v22.15+ or node v23.8+) or `fzstd` otherwise.
46
+ *
47
+ * `fzstd` is an optional dependency. You will need to install it to be able to use it.
46
48
  *
47
49
  * @see https://discord.com/developers/docs/topics/gateway#zstdstream
48
50
  */ TransportCompression["zstd"] = "zstd-stream";
@@ -61,4 +63,4 @@ var ShardSocketCloseCodes = /*#__PURE__*/ function(ShardSocketCloseCodes) {
61
63
  return ShardSocketCloseCodes;
62
64
  }({});
63
65
 
64
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types.ts"],"sourcesContent":["import type { Camelize, DiscordGatewayPayload, GatewayOpcodes } from '@discordeno/types'\nimport type Shard from './Shard.js'\n\nexport enum ShardState {\n  /** Shard is fully connected to the gateway and receiving events from Discord. */\n  Connected = 0,\n  /** Shard started to connect to the gateway. This is only used if the shard is not currently trying to identify or resume. */\n  Connecting = 1,\n  /** Shard got disconnected and reconnection actions have been started. */\n  Disconnected = 2,\n  /** The shard is connected to the gateway but only heartbeating. At this state the shard has not been identified with discord. */\n  Unidentified = 3,\n  /** Shard is trying to identify with the gateway to create a new session. */\n  Identifying = 4,\n  /** Shard is trying to resume a session with the gateway. */\n  Resuming = 5,\n  /** Shard got shut down studied or due to a not (self) fixable error and may not attempt to reconnect on its own. */\n  Offline = 6,\n}\n\nexport enum TransportCompression {\n  /**\n   * ZLib-Stream Transport Compression.\n   *\n   * @remarks\n   * Uses `node:zlib` to decompress the payloads\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zlibstream\n   */\n  zlib = 'zlib-stream',\n  /**\n   * ZStd-Stream Transport Compression.\n   *\n   * @remarks\n   * Uses `fzstd` to decompress the payloads. `fzstd` is an optional dependency, it is required to be installed for this compression.\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zstdstream\n   */\n  zstd = 'zstd-stream',\n}\n\nexport interface ShardGatewayConfig {\n  /**\n   * Whatever to enable Payload compression.\n   *\n   * @remarks\n   * This is compatible with {@link transportCompression}\n   *\n   * @default false\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#payload-compression\n   */\n  compress: boolean\n  /**\n   * What Transport Compression should be use\n   *\n   * @default null\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#transport-compression\n   */\n  transportCompression: TransportCompression | null\n  /** The calculated intent value of the events which the shard should receive.\n   *\n   * @default 0\n   */\n  intents: number\n  /** Identify properties to use */\n  properties: {\n    /** Operating system the shard runs on.\n     *\n     * @default \"darwin\" | \"linux\" | \"windows\"\n     */\n    os: string\n    /** The \"browser\" where this shard is running on.\n     *\n     * @default \"Discordeno\"\n     */\n    browser: string\n    /** The device on which the shard is running.\n     *\n     * @default \"Discordeno\"\n     */\n    device: string\n  }\n  /** Bot token which is used to connect to Discord */\n  token: string\n  /** The URL of the gateway which should be connected to.\n   *\n   * @default \"wss://gateway.discord.gg\"\n   */\n  url: string\n  /** The gateway version which should be used.\n   *\n   * @default 10\n   */\n  version: number\n  /**\n   * The total number of shards to connect to across the entire bot.\n   * @default 1\n   */\n  totalShards: number\n}\n\nexport interface ShardHeart {\n  /** Whether or not the heartbeat was acknowledged by Discord in time. */\n  acknowledged: boolean\n  /** Interval between heartbeats requested by Discord. */\n  interval: number\n  /** Id of the interval, which is used for sending the heartbeats. */\n  intervalId?: NodeJS.Timeout\n  /** Unix (in milliseconds) timestamp when the last heartbeat ACK was received from Discord. */\n  lastAck?: number\n  /** Unix timestamp (in milliseconds) when the last heartbeat was sent. */\n  lastBeat?: number\n  /** Round trip time (in milliseconds) from Shard to Discord and back.\n   * Calculated using the heartbeat system.\n   * Note: this value is undefined until the first heartbeat to Discord has happened.\n   */\n  rtt?: number\n  /** Id of the timeout which is used for sending the first heartbeat to Discord since it's \"special\". */\n  timeoutId?: NodeJS.Timeout\n}\n\nexport interface ShardEvents {\n  /** A heartbeat has been send. */\n  heartbeat?: (shard: Shard) => unknown\n  /** A heartbeat ACK was received. */\n  heartbeatAck?: (shard: Shard) => unknown\n  /** Shard has received a Hello payload. */\n  hello?: (shard: Shard) => unknown\n  /** The Shards session has been invalidated. */\n  invalidSession?: (shard: Shard, resumable: boolean) => unknown\n  /** The shard has started a resume action. */\n  resuming?: (shard: Shard) => unknown\n  /** The shard has successfully resumed an old session. */\n  resumed?: (shard: Shard) => unknown\n  /** Discord has requested the Shard to reconnect. */\n  requestedReconnect?: (shard: Shard) => unknown\n  /** The shard started to connect to Discord's gateway. */\n  connecting?: (shard: Shard) => unknown\n  /** The shard is connected with Discord's gateway. */\n  connected?: (shard: Shard) => unknown\n  /** The shard has been disconnected from Discord's gateway. */\n  disconnected?: (shard: Shard) => unknown\n  /** The shard has started to identify itself to Discord. */\n  identifying?: (shard: Shard) => unknown\n  /** The shard has successfully been identified itself with Discord. */\n  ready?: (shard: Shard) => unknown\n  /** The shard has received a message from Discord. */\n  message?: (shard: Shard, payload: Camelize<DiscordGatewayPayload>) => unknown\n}\n\nexport enum ShardSocketCloseCodes {\n  /** A regular Shard shutdown. */\n  Shutdown = 3000,\n  /** A resume has been requested and therefore the old connection needs to be closed. */\n  ResumeClosingOldConnection = 3024,\n  /**\n   * Did not receive a heartbeat ACK in time.\n   * Closing the shard and creating a new session.\n   */\n  ZombiedConnection = 3010,\n  /** Discordeno's gateway tests hae been finished, therefore the Shard can be turned off. */\n  TestingFinished = 3064,\n  /** Special close code reserved for Discordeno's zero-downtime resharding system. */\n  Resharded = 3065,\n  /** Shard is re-identifying therefore the old connection needs to be closed. */\n  ReIdentifying = 3066,\n}\n\nexport interface ShardSocketRequest {\n  /** The OP-Code for the payload to send. */\n  op: GatewayOpcodes\n  /** Payload data. */\n  d: unknown\n}\n\n/** https://discord.com/developers/docs/topics/gateway#update-voice-state */\nexport interface UpdateVoiceState {\n  /** id of the guild */\n  guildId: string\n  /** id of the voice channel client wants to join (null if disconnecting) */\n  channelId: string | null\n  /** Is the client muted */\n  selfMute: boolean\n  /** Is the client deafened */\n  selfDeaf: boolean\n}\n"],"names":["ShardSocketCloseCodes","ShardState","TransportCompression"],"mappings":";;;;;;;;;;;QAwJYA;eAAAA;;QArJAC;eAAAA;;QAiBAC;eAAAA;;;AAjBL,IAAA,AAAKD,oCAAAA;IACV,+EAA+E;IAE/E,2HAA2H;IAE3H,uEAAuE;IAEvE,+HAA+H;IAE/H,0EAA0E;IAE1E,0DAA0D;IAE1D,kHAAkH;WAbxGA;;AAiBL,IAAA,AAAKC,8CAAAA;IACV;;;;;;;GAOC;IAED;;;;;;;GAOC;WAjBSA;;AAoIL,IAAA,AAAKF,+CAAAA;IACV,8BAA8B;IAE9B,qFAAqF;IAErF;;;GAGC;IAED,yFAAyF;IAEzF,kFAAkF;IAElF,6EAA6E;WAdnEA"}
66
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types.ts"],"sourcesContent":["import type { Camelize, DiscordGatewayPayload, GatewayOpcodes } from '@discordeno/types'\nimport type Shard from './Shard.js'\n\nexport enum ShardState {\n  /** Shard is fully connected to the gateway and receiving events from Discord. */\n  Connected = 0,\n  /** Shard started to connect to the gateway. This is only used if the shard is not currently trying to identify or resume. */\n  Connecting = 1,\n  /** Shard got disconnected and reconnection actions have been started. */\n  Disconnected = 2,\n  /** The shard is connected to the gateway but only heartbeating. At this state the shard has not been identified with discord. */\n  Unidentified = 3,\n  /** Shard is trying to identify with the gateway to create a new session. */\n  Identifying = 4,\n  /** Shard is trying to resume a session with the gateway. */\n  Resuming = 5,\n  /** Shard got shut down studied or due to a not (self) fixable error and may not attempt to reconnect on its own. */\n  Offline = 6,\n}\n\nexport enum TransportCompression {\n  /**\n   * ZLib-Stream Transport Compression.\n   *\n   * @remarks\n   * Uses `node:zlib` to decompress the payloads\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zlibstream\n   */\n  zlib = 'zlib-stream',\n  /**\n   * ZStd-Stream Transport Compression.\n   *\n   * @remarks\n   * This will use `node:zlib` zstd implementation if available (node v22.15+ or node v23.8+) or `fzstd` otherwise.\n   *\n   * `fzstd` is an optional dependency. You will need to install it to be able to use it.\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zstdstream\n   */\n  zstd = 'zstd-stream',\n}\n\nexport interface ShardGatewayConfig {\n  /**\n   * Whatever to enable Payload compression.\n   *\n   * @remarks\n   * This is compatible with {@link transportCompression}\n   *\n   * @default false\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#payload-compression\n   */\n  compress: boolean\n  /**\n   * What Transport Compression should be use\n   *\n   * @default null\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#transport-compression\n   */\n  transportCompression: TransportCompression | null\n  /** The calculated intent value of the events which the shard should receive.\n   *\n   * @default 0\n   */\n  intents: number\n  /** Identify properties to use */\n  properties: {\n    /** Operating system the shard runs on.\n     *\n     * @default \"darwin\" | \"linux\" | \"windows\"\n     */\n    os: string\n    /** The \"browser\" where this shard is running on.\n     *\n     * @default \"Discordeno\"\n     */\n    browser: string\n    /** The device on which the shard is running.\n     *\n     * @default \"Discordeno\"\n     */\n    device: string\n  }\n  /** Bot token which is used to connect to Discord */\n  token: string\n  /** The URL of the gateway which should be connected to.\n   *\n   * @default \"wss://gateway.discord.gg\"\n   */\n  url: string\n  /** The gateway version which should be used.\n   *\n   * @default 10\n   */\n  version: number\n  /**\n   * The total number of shards to connect to across the entire bot.\n   * @default 1\n   */\n  totalShards: number\n}\n\nexport interface ShardHeart {\n  /** Whether or not the heartbeat was acknowledged by Discord in time. */\n  acknowledged: boolean\n  /** Interval between heartbeats requested by Discord. */\n  interval: number\n  /** Id of the interval, which is used for sending the heartbeats. */\n  intervalId?: NodeJS.Timeout\n  /** Unix (in milliseconds) timestamp when the last heartbeat ACK was received from Discord. */\n  lastAck?: number\n  /** Unix timestamp (in milliseconds) when the last heartbeat was sent. */\n  lastBeat?: number\n  /** Round trip time (in milliseconds) from Shard to Discord and back.\n   * Calculated using the heartbeat system.\n   * Note: this value is undefined until the first heartbeat to Discord has happened.\n   */\n  rtt?: number\n  /** Id of the timeout which is used for sending the first heartbeat to Discord since it's \"special\". */\n  timeoutId?: NodeJS.Timeout\n}\n\nexport interface ShardEvents {\n  /** A heartbeat has been send. */\n  heartbeat?: (shard: Shard) => unknown\n  /** A heartbeat ACK was received. */\n  heartbeatAck?: (shard: Shard) => unknown\n  /** Shard has received a Hello payload. */\n  hello?: (shard: Shard) => unknown\n  /** The Shards session has been invalidated. */\n  invalidSession?: (shard: Shard, resumable: boolean) => unknown\n  /** The shard has started a resume action. */\n  resuming?: (shard: Shard) => unknown\n  /** The shard has successfully resumed an old session. */\n  resumed?: (shard: Shard) => unknown\n  /** Discord has requested the Shard to reconnect. */\n  requestedReconnect?: (shard: Shard) => unknown\n  /** The shard started to connect to Discord's gateway. */\n  connecting?: (shard: Shard) => unknown\n  /** The shard is connected with Discord's gateway. */\n  connected?: (shard: Shard) => unknown\n  /** The shard has been disconnected from Discord's gateway. */\n  disconnected?: (shard: Shard) => unknown\n  /** The shard has started to identify itself to Discord. */\n  identifying?: (shard: Shard) => unknown\n  /** The shard has successfully been identified itself with Discord. */\n  ready?: (shard: Shard) => unknown\n  /** The shard has received a message from Discord. */\n  message?: (shard: Shard, payload: Camelize<DiscordGatewayPayload>) => unknown\n}\n\nexport enum ShardSocketCloseCodes {\n  /** A regular Shard shutdown. */\n  Shutdown = 3000,\n  /** A resume has been requested and therefore the old connection needs to be closed. */\n  ResumeClosingOldConnection = 3024,\n  /**\n   * Did not receive a heartbeat ACK in time.\n   * Closing the shard and creating a new session.\n   */\n  ZombiedConnection = 3010,\n  /** Discordeno's gateway tests hae been finished, therefore the Shard can be turned off. */\n  TestingFinished = 3064,\n  /** Special close code reserved for Discordeno's zero-downtime resharding system. */\n  Resharded = 3065,\n  /** Shard is re-identifying therefore the old connection needs to be closed. */\n  ReIdentifying = 3066,\n}\n\nexport interface ShardSocketRequest {\n  /** The OP-Code for the payload to send. */\n  op: GatewayOpcodes\n  /** Payload data. */\n  d: unknown\n}\n\n/** https://discord.com/developers/docs/topics/gateway#update-voice-state */\nexport interface UpdateVoiceState {\n  /** id of the guild */\n  guildId: string\n  /** id of the voice channel client wants to join (null if disconnecting) */\n  channelId: string | null\n  /** Is the client muted */\n  selfMute: boolean\n  /** Is the client deafened */\n  selfDeaf: boolean\n}\n"],"names":["ShardSocketCloseCodes","ShardState","TransportCompression"],"mappings":";;;;;;;;;;;QA0JYA;eAAAA;;QAvJAC;eAAAA;;QAiBAC;eAAAA;;;AAjBL,IAAA,AAAKD,oCAAAA;IACV,+EAA+E;IAE/E,2HAA2H;IAE3H,uEAAuE;IAEvE,+HAA+H;IAE/H,0EAA0E;IAE1E,0DAA0D;IAE1D,kHAAkH;WAbxGA;;AAiBL,IAAA,AAAKC,8CAAAA;IACV;;;;;;;GAOC;IAED;;;;;;;;;GASC;WAnBSA;;AAsIL,IAAA,AAAKF,+CAAAA;IACV,8BAA8B;IAE9B,qFAAqF;IAErF;;;GAGC;IAED,yFAAyF;IAEzF,kFAAkF;IAElF,6EAA6E;WAdnEA"}
package/dist/esm/Shard.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { Buffer } from 'node:buffer';
2
- import { createInflate, inflateSync, constants as zlibConstants } from 'node:zlib';
2
+ import zlib from 'node:zlib';
3
3
  import { GatewayCloseEventCodes, GatewayOpcodes } from '@discordeno/types';
4
4
  import { camelize, delay, LeakyBucket, logger } from '@discordeno/utils';
5
5
  import NodeWebSocket from 'ws';
@@ -111,8 +111,8 @@ export class DiscordenoShard {
111
111
  url.searchParams.set('compress', this.gatewayConfig.transportCompression);
112
112
  if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {
113
113
  this.inflateBuffer = null;
114
- this.inflate = createInflate({
115
- finishFlush: zlibConstants.Z_SYNC_FLUSH,
114
+ this.inflate = zlib.createInflate({
115
+ finishFlush: zlib.constants.Z_SYNC_FLUSH,
116
116
  chunkSize: 64 * 1024
117
117
  });
118
118
  this.inflate.on('error', (e)=>{
@@ -131,17 +131,40 @@ export class DiscordenoShard {
131
131
  });
132
132
  }
133
133
  if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {
134
- const fzstd = await getFZStd().catch(()=>{
135
- this.logger.warn('[Shard] "fzstd" is not installed. Disabled transport compression.');
136
- url.searchParams.delete('compress');
137
- return null;
138
- });
139
- if (fzstd) {
140
- this.zstdDecompress = new fzstd.Decompress((data)=>{
141
- const decodedData = this.textDecoder.decode(data);
142
- const parsedData = JSON.parse(decodedData);
143
- this.decompressionPromisesQueue.shift()?.(parsedData);
134
+ if ('createZstdDecompress' in zlib) {
135
+ this.logger.debug('[Shard] Using node:zlib zstd decompression.');
136
+ this.inflateBuffer = null;
137
+ this.inflate = zlib.createZstdDecompress({
138
+ chunkSize: 64 * 1024
139
+ });
140
+ this.inflate.on('error', (e)=>{
141
+ this.logger.error('The was an error in decompressing a Zstd compressed payload', e);
142
+ });
143
+ this.inflate.on('data', (data)=>{
144
+ if (!(data instanceof Uint8Array)) return;
145
+ if (this.inflateBuffer) {
146
+ const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength);
147
+ newBuffer.set(this.inflateBuffer);
148
+ newBuffer.set(data, this.inflateBuffer.byteLength);
149
+ this.inflateBuffer = newBuffer;
150
+ return;
151
+ }
152
+ this.inflateBuffer = data;
144
153
  });
154
+ } else {
155
+ const fzstd = await getFZStd().catch(()=>{
156
+ this.logger.warn('[Shard] "fzstd" is not installed. Disabled transport compression.');
157
+ url.searchParams.delete('compress');
158
+ return null;
159
+ });
160
+ if (fzstd) {
161
+ this.logger.debug('[Shard] Using fzstd zstd decompression.');
162
+ this.zstdDecompress = new fzstd.Decompress((data)=>{
163
+ const decodedData = this.textDecoder.decode(data);
164
+ const parsedData = JSON.parse(decodedData);
165
+ this.decompressionPromisesQueue.shift()?.(parsedData);
166
+ });
167
+ }
145
168
  }
146
169
  }
147
170
  }
@@ -401,16 +424,31 @@ export class DiscordenoShard {
401
424
  return JSON.parse(decodedData);
402
425
  }
403
426
  if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {
404
- if (!this.zstdDecompress) {
405
- this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no instance of Decompress was found.');
406
- return null;
427
+ if (this.zstdDecompress) {
428
+ this.zstdDecompress.push(compressedData);
429
+ const decompressionPromise = new Promise((r)=>this.decompressionPromisesQueue.push(r));
430
+ return await decompressionPromise;
431
+ }
432
+ if (this.inflate) {
433
+ // Alias, used to avoid some null checks in the Promise constructor
434
+ const decompress = this.inflate;
435
+ const writePromise = new Promise((resolve, reject)=>{
436
+ decompress.write(compressedData, 'binary', (error)=>error ? reject(error) : resolve());
437
+ });
438
+ await writePromise;
439
+ if (!this.inflateBuffer) {
440
+ this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.');
441
+ return null;
442
+ }
443
+ const decodedData = this.textDecoder.decode(this.inflateBuffer);
444
+ this.inflateBuffer = null;
445
+ return JSON.parse(decodedData);
407
446
  }
408
- this.zstdDecompress.push(compressedData);
409
- const decompressionPromise = new Promise((r)=>this.decompressionPromisesQueue.push(r));
410
- return await decompressionPromise;
447
+ this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no zstd decompressor was found.');
448
+ return null;
411
449
  }
412
450
  if (this.gatewayConfig.compress) {
413
- const decompressed = inflateSync(compressedData);
451
+ const decompressed = zlib.inflateSync(compressedData);
414
452
  const decodedData = this.textDecoder.decode(decompressed);
415
453
  return JSON.parse(decodedData);
416
454
  }
@@ -624,4 +662,4 @@ export class DiscordenoShard {
624
662
  }
625
663
  export default DiscordenoShard;
626
664
 
627
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/Shard.ts"],"sourcesContent":["import { Buffer } from 'node:buffer'\nimport { createInflate, type Inflate, inflateSync, constants as zlibConstants } from 'node:zlib'\nimport type { DiscordGatewayPayload, DiscordHello, DiscordReady, DiscordUpdatePresence } from '@discordeno/types'\nimport { GatewayCloseEventCodes, GatewayOpcodes } from '@discordeno/types'\nimport { camelize, delay, LeakyBucket, logger } from '@discordeno/utils'\nimport type { Decompress as ZstdDecompress } from 'fzstd'\nimport NodeWebSocket from 'ws'\nimport {\n  type ShardEvents,\n  type ShardGatewayConfig,\n  type ShardHeart,\n  ShardSocketCloseCodes,\n  type ShardSocketRequest,\n  ShardState,\n  TransportCompression,\n} from './types.js'\n\nconst ZLIB_SYNC_FLUSH = new Uint8Array([0x0, 0x0, 0xff, 0xff])\n\nlet fzstd: typeof import('fzstd')\n\n/** Since fzstd is an optional dependency, we need to import it lazily. */\nasync function getFZStd() {\n  return (fzstd ??= await import('fzstd'))\n}\n\nexport class DiscordenoShard {\n  /** The id of the shard. */\n  id: number\n  /** The connection config details that this shard will used to connect to discord. */\n  connection: ShardGatewayConfig\n  /** This contains all the heartbeat information */\n  heart: ShardHeart\n  /** The maximum of requests which can be send to discord per rate limit tick. Typically this value should not be changed. */\n  maxRequestsPerRateLimitTick: number = 120\n  /** The previous payload sequence number. */\n  previousSequenceNumber: number | null = null\n  /** In which interval (in milliseconds) the gateway resets it's rate limit. */\n  rateLimitResetInterval: number = 60000\n  /** Current session id of the shard if present. */\n  sessionId?: string\n  /** This contains the WebSocket connection to Discord, if currently connected. */\n  socket?: WebSocket\n  /** Current internal state of the this. */\n  state = ShardState.Offline\n  /** The url provided by discord to use when resuming a connection for this this. */\n  resumeGatewayUrl: string = ''\n  /** The shard related event handlers. */\n  events: ShardEvents = {}\n  /** Cache for pending gateway requests which should have been send while the gateway went offline. */\n  offlineSendQueue: (() => void)[] = []\n  /** Resolve internal waiting states. Mapped by SelectedEvents => ResolveFunction */\n  resolves = new Map<'READY' | 'RESUMED' | 'INVALID_SESSION', (payload: DiscordGatewayPayload) => void>()\n  /** Shard bucket. Only access this if you know what you are doing. Bucket for handling shard request rate limits. */\n  bucket: LeakyBucket\n  /** Logger for the bucket. */\n  logger: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /**\n   * Is the shard going offline?\n   *\n   * @remarks\n   * This will be true if the close method has been called with either 1000 or 1001\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  goingOffline = false\n  /** Text decoder used for compressed payloads. */\n  textDecoder = new TextDecoder()\n  /** ZLib Inflate instance for ZLib-stream transport payloads. */\n  inflate?: Inflate\n  /** ZLib inflate buffer. */\n  inflateBuffer: Uint8Array | null = null\n  /** ZStd Decompress instance for ZStd-stream transport payloads. */\n  zstdDecompress?: ZstdDecompress\n  /** Queue for compressed payloads for Zstd Decompress */\n  decompressionPromisesQueue: ((data: DiscordGatewayPayload) => void)[] = []\n  /**\n   * A function that will be called once the socket is closed and handleClose() has finished updating internal states.\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  resolveAfterClose?: (close: CloseEvent) => void\n\n  constructor(options: ShardCreateOptions) {\n    this.id = options.id\n    this.connection = options.connection\n    this.events = options.events\n    this.logger = options.logger ?? logger\n\n    this.heart = {\n      acknowledged: false,\n      interval: 45000,\n    }\n\n    if (options.requestIdentify) this.requestIdentify = options.requestIdentify\n    if (options.makePresence) this.makePresence = options.makePresence\n\n    this.bucket = new LeakyBucket({\n      max: this.calculateSafeRequests(),\n      refillAmount: this.calculateSafeRequests(),\n      refillInterval: 60000,\n      logger: this.logger,\n    })\n  }\n\n  /** The gateway configuration which is used to connect to Discord. */\n  get gatewayConfig(): ShardGatewayConfig {\n    return this.connection\n  }\n\n  /** The url to connect to. Initially this is the discord gateway url, and then is switched to resume gateway url once a READY is received. */\n  get connectionUrl(): string {\n    // Use || and not ?? here. ?? will cause a bug.\n    return this.resumeGatewayUrl || this.gatewayConfig.url\n  }\n\n  /** Calculate the amount of requests which can safely be made per rate limit interval, before the gateway gets disconnected due to an exceeded rate limit. */\n  calculateSafeRequests(): number {\n    // * 2 adds extra safety layer for discords OP 1 requests that we need to respond to\n    const safeRequests = this.maxRequestsPerRateLimitTick - Math.ceil(this.rateLimitResetInterval / this.heart.interval) * 2\n\n    return safeRequests < 0 ? 0 : safeRequests\n  }\n\n  async checkOffline(highPriority: boolean): Promise<void> {\n    if (this.isOpen()) return\n\n    return await new Promise<void>((resolve) => {\n      // Higher priority requests get added at the beginning of the array.\n      if (highPriority) this.offlineSendQueue.unshift(resolve)\n      else this.offlineSendQueue.push(resolve)\n    })\n  }\n\n  /** Close the socket connection to discord if present. */\n  async close(code: number, reason: string): Promise<void> {\n    this.logger.debug(`[Shard] Request for Shard #${this.id} to close the socket with code ${code}.`)\n\n    if (this.socket?.readyState !== NodeWebSocket.OPEN) {\n      this.logger.debug(`[Shard] Shard #${this.id}'s ready state is ${this.socket?.readyState}, Unable to close.`)\n      return\n    }\n\n    this.goingOffline = code === GatewayCloseEventCodes.NormalClosure || code === GatewayCloseEventCodes.GoingAway\n\n    // This has to be created before the actual call to socket.close as for example Bun calls socket.onclose immediately on the .close() call instead of waiting for the connection to end\n    const promise = new Promise((resolve) => {\n      this.resolveAfterClose = resolve\n    })\n\n    this.socket.close(code, reason)\n\n    this.logger.debug(`[Shard] Waiting for Shard #${this.id} to close the socket with code ${code}.`)\n\n    // We need to wait for the socket to be fully closed, otherwise there'll be race condition issues if we try to connect again, resulting in unexpected behavior.\n    await promise\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed the socket with code ${code}.`)\n\n    // Reset the resolveAfterClose function after it has been resolved.\n    this.resolveAfterClose = undefined\n  }\n\n  /** Connect the shard with the gateway and start heartbeating. This will not identify the shard to the gateway. */\n  async connect(): Promise<DiscordenoShard> {\n    // Only set the shard to `Connecting` state,\n    // if the connection request does not come from an identify or resume action.\n    if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n      this.state = ShardState.Connecting\n    }\n\n    this.logger.debug(`[Shard] Connecting Shard #${this.id} socket.`)\n\n    this.events.connecting?.(this)\n\n    const url = new URL(this.connectionUrl)\n    url.searchParams.set('v', this.gatewayConfig.version.toString())\n    url.searchParams.set('encoding', 'json')\n\n    // Set the compress url param and initialize the decompression contexts\n    if (this.gatewayConfig.transportCompression) {\n      url.searchParams.set('compress', this.gatewayConfig.transportCompression)\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n        this.inflateBuffer = null\n        this.inflate = createInflate({\n          finishFlush: zlibConstants.Z_SYNC_FLUSH,\n          chunkSize: 64 * 1024,\n        })\n\n        this.inflate.on('error', (e) => {\n          this.logger.error('The was an error in decompressing a ZLib compressed payload', e)\n        })\n\n        this.inflate.on('data', (data) => {\n          if (!(data instanceof Uint8Array)) return\n\n          if (this.inflateBuffer) {\n            const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength)\n            newBuffer.set(this.inflateBuffer)\n            newBuffer.set(data, this.inflateBuffer.byteLength)\n            this.inflateBuffer = newBuffer\n\n            return\n          }\n\n          this.inflateBuffer = data\n        })\n      }\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n        const fzstd = await getFZStd().catch(() => {\n          this.logger.warn('[Shard] \"fzstd\" is not installed. Disabled transport compression.')\n          url.searchParams.delete('compress')\n\n          return null\n        })\n\n        if (fzstd) {\n          this.zstdDecompress = new fzstd.Decompress((data) => {\n            const decodedData = this.textDecoder.decode(data)\n            const parsedData = JSON.parse(decodedData)\n            this.decompressionPromisesQueue.shift()?.(parsedData)\n          })\n        }\n      }\n    }\n\n    if (this.gatewayConfig.compress && this.gatewayConfig.transportCompression) {\n      this.logger.warn('[Shard] Payload compression has been disabled since transport compression is enabled as well.')\n      this.gatewayConfig.compress = false\n    }\n\n    // We check for built-in WebSocket implementations in Bun or Deno, NodeJS v22 has an implementation too but it seems to be less optimized so for now it is better to use the ws npm package\n    const shouldUseBuiltin = Reflect.has(globalThis, 'WebSocket') && (Reflect.has(globalThis, 'Bun') || Reflect.has(globalThis, 'Deno'))\n\n    // @ts-expect-error NodeWebSocket doesn't support \"dispatchEvent\", and while we don't use it, it is required on the \"WebSocket\" type\n    const socket: WebSocket = shouldUseBuiltin ? new WebSocket(url) : new NodeWebSocket(url)\n    this.socket = socket\n\n    // By default WebSocket will give us a Blob, this changes it so that it gives us an ArrayBuffer\n    socket.binaryType = 'arraybuffer'\n\n    socket.onerror = (event) => this.handleError(event)\n    socket.onclose = (closeEvent) => this.handleClose(closeEvent)\n    socket.onmessage = (messageEvent) => this.handleMessage(messageEvent)\n\n    return await new Promise((resolve) => {\n      socket.onopen = () => {\n        // Only set the shard to `Unidentified` state if the connection request does not come from an identify or resume action.\n        if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n          this.state = ShardState.Unidentified\n        }\n\n        this.logger.debug(`[Shard] Shard #${this.id} socket connected.`)\n\n        this.events.connected?.(this)\n\n        resolve(this)\n      }\n    })\n  }\n\n  /**\n   * Identify the shard to the gateway. If not connected, this will also connect the shard to the gateway.\n   * @param bypassRequest - Whether to bypass the requestIdentify handler and identify immediately. This should be used carefully as it can cause invalid sessions.\n   */\n  async identify(bypassRequest = false): Promise<void> {\n    // A new identify has been requested even though there is already a connection open.\n    // Therefore we need to close the old connection and heartbeating before creating a new one.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Identifying open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ReIdentifying, 'Re-identifying closure of old connection.')\n    }\n\n    if (!bypassRequest) {\n      await this.requestIdentify()\n    }\n\n    this.state = ShardState.Identifying\n    this.events.identifying?.(this)\n\n    // It is possible that the shard is in Heartbeating state but not identified,\n    // so check whether there is already a gateway connection existing.\n    // If not we need to create one before we identify.\n    if (!this.isOpen()) {\n      await this.connect()\n    }\n\n    this.logger.debug(`[Shard] Sending Identify payload for Shard #${this.id}.`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Identify,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          compress: this.gatewayConfig.compress,\n          properties: this.gatewayConfig.properties,\n          intents: this.gatewayConfig.intents,\n          shard: [this.id, this.gatewayConfig.totalShards],\n          presence: await this.makePresence(),\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('READY', () => {\n        resolve()\n      })\n      // When identifying too fast, Discord sends an invalid session payload.\n      // This can safely be ignored though and the shard starts a new identify action.\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('READY')\n        resolve()\n      })\n    })\n  }\n\n  /** Check whether the connection to Discord is currently open. */\n  isOpen(): boolean {\n    return this.socket?.readyState === NodeWebSocket.OPEN\n  }\n\n  /** Attempt to resume the previous shards session with the gateway. */\n  async resume(): Promise<void> {\n    this.logger.debug(`[Shard] Resuming Shard #${this.id}`)\n\n    // It has been requested to resume the Shards session.\n    // It's possible that the shard is still connected with Discord's gateway therefore we need to forcefully close it.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Resuming open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ResumeClosingOldConnection, 'Reconnecting the shard, closing old connection.')\n    }\n\n    // Shard has never identified, so we cannot resume.\n    if (!this.sessionId) {\n      this.logger.debug(`[Shard] Trying to resume Shard #${this.id} without the session id. Identifying the shard instead.`)\n\n      await this.identify()\n      return\n    }\n\n    this.state = ShardState.Resuming\n\n    // Before we can resume, we need to create a new connection with Discord's gateway.\n    await this.connect()\n\n    this.logger.debug(`[Shard] Resuming Shard #${this.id} connected. Session id: ${this.sessionId} | Sequence: ${this.previousSequenceNumber}`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Resume,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          session_id: this.sessionId,\n          seq: this.previousSequenceNumber ?? 0,\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('RESUMED', () => resolve())\n\n      // If it is attempted to resume with an invalid session id, Discord sends an invalid session payload\n      // Not erroring here since it is easy that this happens, also it would be not catchable\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('RESUMED')\n        resolve()\n      })\n    })\n  }\n\n  /**\n   * Send a message to Discord.\n   * @param highPriority - Whether this message should be send asap.\n   */\n  async send(message: ShardSocketRequest, highPriority: boolean = false): Promise<void> {\n    // Before acquiring a token from the bucket, check whether the shard is currently offline or not.\n    // Else bucket and token wait time just get wasted.\n    await this.checkOffline(highPriority)\n\n    await this.bucket.acquire(highPriority)\n\n    // It's possible, that the shard went offline after a token has been acquired from the bucket.\n    await this.checkOffline(highPriority)\n\n    this.socket?.send(JSON.stringify(message))\n  }\n\n  /** Shutdown the this. Forcefully disconnect the shard from Discord. The shard may not attempt to reconnect with Discord. */\n  async shutdown(): Promise<void> {\n    await this.close(ShardSocketCloseCodes.Shutdown, 'Shard shutting down.')\n    this.state = ShardState.Offline\n  }\n\n  /** Handle a gateway connection error */\n  handleError(error: Event): void {\n    this.logger.error(`[Shard] There was an error connecting Shard #${this.id}.`, error)\n  }\n\n  /** Handle a gateway connection close. */\n  async handleClose(close: CloseEvent): Promise<void> {\n    this.socket = undefined\n    this.stopHeartbeating()\n\n    // Clear the zlib/zstd data\n    this.inflate = undefined\n    this.zstdDecompress = undefined\n    this.inflateBuffer = null\n    this.decompressionPromisesQueue = []\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed with code ${close.code}${close.reason ? `, and reason: ${close.reason}` : ''}.`)\n\n    // Resolve the close promise if it exists\n    this.resolveAfterClose?.(close)\n\n    switch (close.code) {\n      case ShardSocketCloseCodes.TestingFinished: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // On these codes a manual start will be done.\n      case ShardSocketCloseCodes.Shutdown:\n      case ShardSocketCloseCodes.ReIdentifying:\n      case ShardSocketCloseCodes.Resharded:\n      case ShardSocketCloseCodes.ResumeClosingOldConnection: {\n        this.state = ShardState.Disconnected\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // When these codes are received something went really wrong.\n      // On those we cannot start a reconnect attempt.\n      case GatewayCloseEventCodes.AuthenticationFailed:\n      case GatewayCloseEventCodes.InvalidShard:\n      case GatewayCloseEventCodes.ShardingRequired:\n      case GatewayCloseEventCodes.InvalidApiVersion:\n      case GatewayCloseEventCodes.InvalidIntents:\n      case GatewayCloseEventCodes.DisallowedIntents: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        throw new Error(close.reason || 'Discord gave no reason! GG! You broke Discord!')\n      }\n      // Gateway connection closes which require a new identify.\n      case GatewayCloseEventCodes.NotAuthenticated:\n      case GatewayCloseEventCodes.InvalidSeq:\n      case GatewayCloseEventCodes.SessionTimedOut: {\n        this.logger.debug(`[Shard] Shard #${this.id} closed requiring re-identify.`)\n        this.state = ShardState.Identifying\n        this.events.disconnected?.(this)\n\n        await this.identify()\n        return\n      }\n      // NOTE: This case must always be right above the cases that runs with default case because of how switch works when you don't break / return, more info below.\n      case GatewayCloseEventCodes.NormalClosure:\n      case GatewayCloseEventCodes.GoingAway: {\n        // If the shard is marked as goingOffline, it stays disconnected.\n        if (this.goingOffline) {\n          this.state = ShardState.Disconnected\n          this.events.disconnected?.(this)\n\n          this.goingOffline = false\n\n          return\n        }\n\n        // Otherwise, we want the shard to go through the default case where it gets resumed, as it might be an unexpected closure from Discord or Cloudflare for example, so we don't use break / return here.\n      }\n      // Gateway connection closes on which a resume is allowed.\n      case GatewayCloseEventCodes.UnknownError:\n      case GatewayCloseEventCodes.UnknownOpcode:\n      case GatewayCloseEventCodes.DecodeError:\n      case GatewayCloseEventCodes.RateLimited:\n      case GatewayCloseEventCodes.AlreadyAuthenticated:\n      default: {\n        // We don't want to get into an infinite loop where we resume forever, so if we were already resuming we identify instead\n        this.state = this.state === ShardState.Resuming ? ShardState.Identifying : ShardState.Resuming\n        this.events.disconnected?.(this)\n\n        if (this.state === ShardState.Resuming) {\n          await this.resume()\n        } else {\n          await this.identify()\n        }\n\n        return\n      }\n    }\n  }\n\n  /** Handle an incoming gateway message. */\n  async handleMessage(message: MessageEvent): Promise<void> {\n    // The ws npm package will use a Buffer, while the global built-in will use ArrayBuffer\n    const isCompressed = message.data instanceof ArrayBuffer || message.data instanceof Buffer\n\n    const data = isCompressed ? await this.decompressPacket(message.data) : (JSON.parse(message.data) as DiscordGatewayPayload)\n\n    // Check if the decompression was not successful\n    if (!data) return\n\n    await this.handleDiscordPacket(data)\n  }\n\n  /**\n   * Decompress a zlib/zstd compressed packet\n   *\n   * @private\n   */\n  async decompressPacket(data: ArrayBuffer | Buffer): Promise<DiscordGatewayPayload | null> {\n    // A buffer is a Uint8Array under the hood. An ArrayBuffer is generic, so we need to create the Uint8Array that uses the whole ArrayBuffer\n    const compressedData: Uint8Array = data instanceof Buffer ? data : new Uint8Array(data)\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n      if (!this.inflate) {\n        this.logger.fatal('[Shard] zlib-stream transport compression was enabled but no instance of Inflate was found.')\n        return null\n      }\n\n      // Alias, used to avoid some null checks in the Promise constructor\n      const inflate = this.inflate\n\n      const writePromise = new Promise<void>((resolve, reject) => {\n        inflate.write(compressedData, 'binary', (error) => (error ? reject(error) : resolve()))\n      })\n\n      if (!endsWithMarker(compressedData, ZLIB_SYNC_FLUSH)) return null\n\n      await writePromise\n\n      if (!this.inflateBuffer) {\n        this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.')\n        return null\n      }\n\n      const decodedData = this.textDecoder.decode(this.inflateBuffer)\n      this.inflateBuffer = null\n\n      return JSON.parse(decodedData)\n    }\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n      if (!this.zstdDecompress) {\n        this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no instance of Decompress was found.')\n        return null\n      }\n\n      this.zstdDecompress.push(compressedData)\n\n      const decompressionPromise = new Promise<DiscordGatewayPayload>((r) => this.decompressionPromisesQueue.push(r))\n      return await decompressionPromise\n    }\n\n    if (this.gatewayConfig.compress) {\n      const decompressed = inflateSync(compressedData)\n      const decodedData = this.textDecoder.decode(decompressed)\n\n      return JSON.parse(decodedData)\n    }\n\n    return null\n  }\n\n  /** Handles a incoming gateway packet. */\n  async handleDiscordPacket(packet: DiscordGatewayPayload): Promise<void> {\n    // Edge case start: https://github.com/discordeno/discordeno/issues/2311\n    this.heart.lastAck = Date.now()\n    this.heart.acknowledged = true\n    // Edge case end!\n\n    switch (packet.op) {\n      case GatewayOpcodes.Heartbeat: {\n        if (!this.isOpen()) return\n\n        this.heart.lastBeat = Date.now()\n        // Discord randomly sends this requiring an immediate heartbeat back.\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n        this.events.heartbeat?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Hello: {\n        const interval = (packet.d as DiscordHello).heartbeat_interval\n        this.logger.debug(`[Shard] Shard #${this.id} received Hello`)\n        this.startHeartbeating(interval)\n\n        if (this.state !== ShardState.Resuming) {\n          const currentQueue = [...this.bucket.queue]\n          // HELLO has been send on a non resume action.\n          // This means that the shard starts a new session,\n          // therefore the rate limit interval has been reset too.\n          this.bucket = new LeakyBucket({\n            max: this.calculateSafeRequests(),\n            refillInterval: 60000,\n            refillAmount: this.calculateSafeRequests(),\n            logger: this.logger,\n          })\n\n          // Queue should not be lost on a re-identify.\n          this.bucket.queue.unshift(...currentQueue)\n        }\n\n        this.events.hello?.(this)\n\n        break\n      }\n      case GatewayOpcodes.HeartbeatACK: {\n        // Manually calculating the round trip time for users who need it.\n        if (this.heart.lastBeat) {\n          this.heart.rtt = this.heart.lastAck - this.heart.lastBeat\n        }\n\n        this.events.heartbeatAck?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Reconnect: {\n        this.logger.debug(`[Shard] Received a Reconnect for Shard #${this.id}`)\n        this.events.requestedReconnect?.(this)\n\n        await this.resume()\n\n        break\n      }\n      case GatewayOpcodes.InvalidSession: {\n        const resumable = packet.d as boolean\n        this.logger.debug(`[Shard] Received Invalid Session for Shard #${this.id} with resumable as ${resumable}`)\n\n        this.events.invalidSession?.(this, resumable)\n\n        // We need to wait for a random amount of time between 1 and 5\n        // Reference: https://discord.com/developers/docs/topics/gateway#resuming\n        await delay(Math.floor((Math.random() * 4 + 1) * 1000))\n\n        this.resolves.get('INVALID_SESSION')?.(packet)\n        this.resolves.delete('INVALID_SESSION')\n\n        // When resumable is false we need to re-identify\n        if (!resumable) {\n          await this.identify()\n\n          break\n        }\n\n        // The session is invalid but apparently it is resumable\n        await this.resume()\n\n        break\n      }\n    }\n\n    switch (packet.t) {\n      case 'RESUMED':\n        this.state = ShardState.Connected\n        this.events.resumed?.(this)\n\n        this.logger.debug(`[Shard] Shard #${this.id} received RESUMED`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('RESUMED')?.(packet)\n        this.resolves.delete('RESUMED')\n        break\n      case 'READY': {\n        const payload = packet.d as DiscordReady\n        this.events.ready?.(this)\n\n        // Important for future resumes.\n        this.resumeGatewayUrl = payload.resume_gateway_url\n        this.sessionId = payload.session_id\n\n        this.state = ShardState.Connected\n\n        this.logger.debug(`[Shard] Shard #${this.id} received READY`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        // Important when this is a re-identify\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('READY')?.(packet)\n        this.resolves.delete('READY')\n        break\n      }\n    }\n\n    // Update the sequence number if it is present\n    // `s` can be either `null` or a `number`.\n    // In order to prevent update misses when `s` is `0` we check against null.\n    if (packet.s !== null) {\n      this.previousSequenceNumber = packet.s\n    }\n\n    this.forwardToBot(packet)\n  }\n\n  forwardToBot(packet: DiscordGatewayPayload): void {\n    // The necessary handling required for the Shards connection has been finished.\n    // Now the event can be safely forwarded.\n    this.events.message?.(this, camelize(packet))\n  }\n\n  /**\n   * Override in order to make the shards presence.\n   * async in case devs create the presence based on eg. database values.\n   * Passing the shard's id there to make it easier for the dev to use this function.\n   */\n  async makePresence(): Promise<DiscordUpdatePresence | undefined> {\n    return\n  }\n\n  /**\n   * This function communicates with the management process, in order to know whether its free to identify.\n   * When this function resolves, this means that the shard is allowed to send an identify payload to discord.\n   */\n  async requestIdentify(): Promise<void> {}\n\n  /** Start sending heartbeat payloads to Discord in the provided interval. */\n  startHeartbeating(interval: number): void {\n    this.logger.debug(`[Shard] Start heartbeating on Shard #${this.id}`)\n\n    // If old heartbeast exist like after resume, clear the old ones.\n    this.stopHeartbeating()\n\n    this.heart.interval = interval\n\n    // Only set the shard's state to `Unidentified`\n    // if heartbeating has not been started due to an identify or resume action.\n    if ([ShardState.Disconnected, ShardState.Offline].includes(this.state)) {\n      this.logger.debug(`[Shard] Shard is disconnected or offline but the heartbeat was started #${this.id}`)\n      this.state = ShardState.Unidentified\n    }\n\n    // The first heartbeat needs to be send with a random delay between `0` and `interval`\n    // Using a `setTimeout(_, jitter)` here to accomplish that.\n    // `Math.random()` can be `0` so we use `0.5` if this happens\n    // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating\n    const jitter = Math.ceil(this.heart.interval * (Math.random() || 0.5))\n\n    this.heart.timeoutId = setTimeout(() => {\n      this.logger.debug(`[Shard] Beginning heartbeating process for Shard #${this.id}`)\n\n      if (!this.isOpen()) return\n\n      this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n      // Using a direct socket.send call here because heartbeat requests are reserved by us.\n      this.socket?.send(\n        JSON.stringify({\n          op: GatewayOpcodes.Heartbeat,\n          d: this.previousSequenceNumber,\n        }),\n      )\n\n      this.heart.lastBeat = Date.now()\n      this.heart.acknowledged = false\n\n      // After the random heartbeat jitter we can start a normal interval.\n      this.heart.intervalId = setInterval(async () => {\n        if (!this.isOpen()) {\n          this.logger.debug(`[Shard] Shard #${this.id} is not open, but attempted heartbeat, ignoring.`)\n          return\n        }\n\n        // The Shard did not receive a heartbeat ACK from Discord in time,\n        // therefore we have to assume that the connection has failed or got \"zombied\".\n        // The Shard needs to start a re-identify action accordingly.\n        // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating-example-gateway-heartbeat-ack\n        if (!this.heart.acknowledged) {\n          this.logger.debug(`[Shard] Heartbeat not acknowledged for Shard #${this.id}. Assuming zombied connection.`)\n          await this.close(ShardSocketCloseCodes.ZombiedConnection, 'Zombied connection, did not receive an heartbeat ACK in time.')\n          return\n        }\n\n        this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n\n        this.heart.lastBeat = Date.now()\n        this.heart.acknowledged = false\n\n        this.events.heartbeat?.(this)\n      }, this.heart.interval)\n    }, jitter)\n  }\n\n  /** Stop the heartbeating process with discord. */\n  stopHeartbeating(): void {\n    // Clear the regular heartbeat interval.\n    clearInterval(this.heart.intervalId)\n    // It's possible that the Shard got closed before the first jittered heartbeat.\n    // To go safe we should clear the related timeout too.\n    clearTimeout(this.heart.timeoutId)\n  }\n}\n\n/** Check if the buffer ends with the marker */\nfunction endsWithMarker(buffer: Uint8Array, marker: Uint8Array) {\n  if (buffer.length < marker.length) return false\n\n  for (let i = 0; i < marker.length; i++) {\n    if (buffer[buffer.length - marker.length + i] !== marker[i]) return false\n  }\n\n  return true\n}\n\nexport interface ShardCreateOptions {\n  /** The shard id */\n  id: number\n  /** The connection details */\n  connection: ShardGatewayConfig\n  /** The event handlers for events on the shard. */\n  events: ShardEvents\n  /** The logger for the shard */\n  logger?: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /** The handler to request a space to make an identify request. */\n  requestIdentify?: () => Promise<void>\n  /** Function to create the bot status to send on Identify requests */\n  makePresence?: () => Promise<DiscordUpdatePresence | undefined>\n}\n\nexport default DiscordenoShard\n"],"names":["Buffer","createInflate","inflateSync","constants","zlibConstants","GatewayCloseEventCodes","GatewayOpcodes","camelize","delay","LeakyBucket","logger","NodeWebSocket","ShardSocketCloseCodes","ShardState","TransportCompression","ZLIB_SYNC_FLUSH","Uint8Array","fzstd","getFZStd","DiscordenoShard","options","maxRequestsPerRateLimitTick","previousSequenceNumber","rateLimitResetInterval","state","Offline","resumeGatewayUrl","events","offlineSendQueue","resolves","Map","goingOffline","textDecoder","TextDecoder","inflateBuffer","decompressionPromisesQueue","id","connection","heart","acknowledged","interval","requestIdentify","makePresence","bucket","max","calculateSafeRequests","refillAmount","refillInterval","gatewayConfig","connectionUrl","url","safeRequests","Math","ceil","checkOffline","highPriority","isOpen","Promise","resolve","unshift","push","close","code","reason","debug","socket","readyState","OPEN","NormalClosure","GoingAway","promise","resolveAfterClose","undefined","connect","Identifying","Resuming","includes","Connecting","connecting","URL","searchParams","set","version","toString","transportCompression","zlib","inflate","finishFlush","Z_SYNC_FLUSH","chunkSize","on","e","error","data","newBuffer","byteLength","zstd","catch","warn","delete","zstdDecompress","Decompress","decodedData","decode","parsedData","JSON","parse","shift","compress","shouldUseBuiltin","Reflect","has","globalThis","WebSocket","binaryType","onerror","event","handleError","onclose","closeEvent","handleClose","onmessage","messageEvent","handleMessage","onopen","Unidentified","connected","identify","bypassRequest","ReIdentifying","identifying","send","op","Identify","d","token","properties","intents","shard","totalShards","presence","resume","ResumeClosingOldConnection","sessionId","Resume","session_id","seq","message","acquire","stringify","shutdown","Shutdown","stopHeartbeating","TestingFinished","disconnected","Resharded","Disconnected","AuthenticationFailed","InvalidShard","ShardingRequired","InvalidApiVersion","InvalidIntents","DisallowedIntents","Error","NotAuthenticated","InvalidSeq","SessionTimedOut","UnknownError","UnknownOpcode","DecodeError","RateLimited","AlreadyAuthenticated","isCompressed","ArrayBuffer","decompressPacket","handleDiscordPacket","compressedData","fatal","writePromise","reject","write","endsWithMarker","decompressionPromise","r","decompressed","packet","lastAck","Date","now","Heartbeat","lastBeat","heartbeat","Hello","heartbeat_interval","startHeartbeating","currentQueue","queue","hello","HeartbeatACK","rtt","heartbeatAck","Reconnect","requestedReconnect","InvalidSession","resumable","invalidSession","floor","random","get","t","Connected","resumed","forEach","length","payload","ready","resume_gateway_url","s","forwardToBot","jitter","timeoutId","setTimeout","intervalId","setInterval","ZombiedConnection","clearInterval","clearTimeout","buffer","marker","i"],"mappings":"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"}
665
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/Shard.ts"],"sourcesContent":["import { Buffer } from 'node:buffer'\nimport zlib from 'node:zlib'\nimport type { DiscordGatewayPayload, DiscordHello, DiscordReady, DiscordUpdatePresence } from '@discordeno/types'\nimport { GatewayCloseEventCodes, GatewayOpcodes } from '@discordeno/types'\nimport { camelize, delay, LeakyBucket, logger } from '@discordeno/utils'\nimport type { Decompress as FZstdDecompress } from 'fzstd'\nimport NodeWebSocket from 'ws'\nimport {\n  type ShardEvents,\n  type ShardGatewayConfig,\n  type ShardHeart,\n  ShardSocketCloseCodes,\n  type ShardSocketRequest,\n  ShardState,\n  TransportCompression,\n} from './types.js'\n\nconst ZLIB_SYNC_FLUSH = new Uint8Array([0x0, 0x0, 0xff, 0xff])\n\nlet fzstd: typeof import('fzstd')\n\n/** Since fzstd is an optional dependency, we need to import it lazily. */\nasync function getFZStd() {\n  return (fzstd ??= await import('fzstd'))\n}\n\nexport class DiscordenoShard {\n  /** The id of the shard. */\n  id: number\n  /** The connection config details that this shard will used to connect to discord. */\n  connection: ShardGatewayConfig\n  /** This contains all the heartbeat information */\n  heart: ShardHeart\n  /** The maximum of requests which can be send to discord per rate limit tick. Typically this value should not be changed. */\n  maxRequestsPerRateLimitTick: number = 120\n  /** The previous payload sequence number. */\n  previousSequenceNumber: number | null = null\n  /** In which interval (in milliseconds) the gateway resets it's rate limit. */\n  rateLimitResetInterval: number = 60000\n  /** Current session id of the shard if present. */\n  sessionId?: string\n  /** This contains the WebSocket connection to Discord, if currently connected. */\n  socket?: WebSocket\n  /** Current internal state of the this. */\n  state = ShardState.Offline\n  /** The url provided by discord to use when resuming a connection for this this. */\n  resumeGatewayUrl: string = ''\n  /** The shard related event handlers. */\n  events: ShardEvents = {}\n  /** Cache for pending gateway requests which should have been send while the gateway went offline. */\n  offlineSendQueue: (() => void)[] = []\n  /** Resolve internal waiting states. Mapped by SelectedEvents => ResolveFunction */\n  resolves = new Map<'READY' | 'RESUMED' | 'INVALID_SESSION', (payload: DiscordGatewayPayload) => void>()\n  /** Shard bucket. Only access this if you know what you are doing. Bucket for handling shard request rate limits. */\n  bucket: LeakyBucket\n  /** Logger for the bucket. */\n  logger: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /**\n   * Is the shard going offline?\n   *\n   * @remarks\n   * This will be true if the close method has been called with either 1000 or 1001\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  goingOffline = false\n  /** Text decoder used for compressed payloads. */\n  textDecoder = new TextDecoder()\n  /** zlib Inflate or zstd decompress (from node:zlib) instance for transport payloads. */\n  inflate?: zlib.Inflate | zlib.ZstdDecompress\n  /** ZLib inflate buffer. */\n  inflateBuffer: Uint8Array | null = null\n  /** ZStd Decompress instance for ZStd-stream transport payloads. */\n  zstdDecompress?: FZstdDecompress\n  /** Queue for compressed payloads for Zstd Decompress */\n  decompressionPromisesQueue: ((data: DiscordGatewayPayload) => void)[] = []\n  /**\n   * A function that will be called once the socket is closed and handleClose() has finished updating internal states.\n   *\n   * @internal\n   * This is for internal purposes only, and subject to breaking changes.\n   */\n  resolveAfterClose?: (close: CloseEvent) => void\n\n  constructor(options: ShardCreateOptions) {\n    this.id = options.id\n    this.connection = options.connection\n    this.events = options.events\n    this.logger = options.logger ?? logger\n\n    this.heart = {\n      acknowledged: false,\n      interval: 45000,\n    }\n\n    if (options.requestIdentify) this.requestIdentify = options.requestIdentify\n    if (options.makePresence) this.makePresence = options.makePresence\n\n    this.bucket = new LeakyBucket({\n      max: this.calculateSafeRequests(),\n      refillAmount: this.calculateSafeRequests(),\n      refillInterval: 60000,\n      logger: this.logger,\n    })\n  }\n\n  /** The gateway configuration which is used to connect to Discord. */\n  get gatewayConfig(): ShardGatewayConfig {\n    return this.connection\n  }\n\n  /** The url to connect to. Initially this is the discord gateway url, and then is switched to resume gateway url once a READY is received. */\n  get connectionUrl(): string {\n    // Use || and not ?? here. ?? will cause a bug.\n    return this.resumeGatewayUrl || this.gatewayConfig.url\n  }\n\n  /** Calculate the amount of requests which can safely be made per rate limit interval, before the gateway gets disconnected due to an exceeded rate limit. */\n  calculateSafeRequests(): number {\n    // * 2 adds extra safety layer for discords OP 1 requests that we need to respond to\n    const safeRequests = this.maxRequestsPerRateLimitTick - Math.ceil(this.rateLimitResetInterval / this.heart.interval) * 2\n\n    return safeRequests < 0 ? 0 : safeRequests\n  }\n\n  async checkOffline(highPriority: boolean): Promise<void> {\n    if (this.isOpen()) return\n\n    return await new Promise<void>((resolve) => {\n      // Higher priority requests get added at the beginning of the array.\n      if (highPriority) this.offlineSendQueue.unshift(resolve)\n      else this.offlineSendQueue.push(resolve)\n    })\n  }\n\n  /** Close the socket connection to discord if present. */\n  async close(code: number, reason: string): Promise<void> {\n    this.logger.debug(`[Shard] Request for Shard #${this.id} to close the socket with code ${code}.`)\n\n    if (this.socket?.readyState !== NodeWebSocket.OPEN) {\n      this.logger.debug(`[Shard] Shard #${this.id}'s ready state is ${this.socket?.readyState}, Unable to close.`)\n      return\n    }\n\n    this.goingOffline = code === GatewayCloseEventCodes.NormalClosure || code === GatewayCloseEventCodes.GoingAway\n\n    // This has to be created before the actual call to socket.close as for example Bun calls socket.onclose immediately on the .close() call instead of waiting for the connection to end\n    const promise = new Promise((resolve) => {\n      this.resolveAfterClose = resolve\n    })\n\n    this.socket.close(code, reason)\n\n    this.logger.debug(`[Shard] Waiting for Shard #${this.id} to close the socket with code ${code}.`)\n\n    // We need to wait for the socket to be fully closed, otherwise there'll be race condition issues if we try to connect again, resulting in unexpected behavior.\n    await promise\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed the socket with code ${code}.`)\n\n    // Reset the resolveAfterClose function after it has been resolved.\n    this.resolveAfterClose = undefined\n  }\n\n  /** Connect the shard with the gateway and start heartbeating. This will not identify the shard to the gateway. */\n  async connect(): Promise<DiscordenoShard> {\n    // Only set the shard to `Connecting` state,\n    // if the connection request does not come from an identify or resume action.\n    if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n      this.state = ShardState.Connecting\n    }\n\n    this.logger.debug(`[Shard] Connecting Shard #${this.id} socket.`)\n\n    this.events.connecting?.(this)\n\n    const url = new URL(this.connectionUrl)\n    url.searchParams.set('v', this.gatewayConfig.version.toString())\n    url.searchParams.set('encoding', 'json')\n\n    // Set the compress url param and initialize the decompression contexts\n    if (this.gatewayConfig.transportCompression) {\n      url.searchParams.set('compress', this.gatewayConfig.transportCompression)\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n        this.inflateBuffer = null\n        this.inflate = zlib.createInflate({\n          finishFlush: zlib.constants.Z_SYNC_FLUSH,\n          chunkSize: 64 * 1024,\n        })\n\n        this.inflate.on('error', (e) => {\n          this.logger.error('The was an error in decompressing a ZLib compressed payload', e)\n        })\n\n        this.inflate.on('data', (data) => {\n          if (!(data instanceof Uint8Array)) return\n\n          if (this.inflateBuffer) {\n            const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength)\n            newBuffer.set(this.inflateBuffer)\n            newBuffer.set(data, this.inflateBuffer.byteLength)\n            this.inflateBuffer = newBuffer\n\n            return\n          }\n\n          this.inflateBuffer = data\n        })\n      }\n\n      if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n        if ('createZstdDecompress' in zlib) {\n          this.logger.debug('[Shard] Using node:zlib zstd decompression.')\n\n          this.inflateBuffer = null\n          this.inflate = zlib.createZstdDecompress({\n            chunkSize: 64 * 1024,\n          })\n\n          this.inflate.on('error', (e) => {\n            this.logger.error('The was an error in decompressing a Zstd compressed payload', e)\n          })\n\n          this.inflate.on('data', (data) => {\n            if (!(data instanceof Uint8Array)) return\n\n            if (this.inflateBuffer) {\n              const newBuffer = new Uint8Array(this.inflateBuffer.byteLength + data.byteLength)\n              newBuffer.set(this.inflateBuffer)\n              newBuffer.set(data, this.inflateBuffer.byteLength)\n              this.inflateBuffer = newBuffer\n\n              return\n            }\n\n            this.inflateBuffer = data\n          })\n        } else {\n          const fzstd = await getFZStd().catch(() => {\n            this.logger.warn('[Shard] \"fzstd\" is not installed. Disabled transport compression.')\n            url.searchParams.delete('compress')\n\n            return null\n          })\n\n          if (fzstd) {\n            this.logger.debug('[Shard] Using fzstd zstd decompression.')\n\n            this.zstdDecompress = new fzstd.Decompress((data) => {\n              const decodedData = this.textDecoder.decode(data)\n              const parsedData = JSON.parse(decodedData)\n              this.decompressionPromisesQueue.shift()?.(parsedData)\n            })\n          }\n        }\n      }\n    }\n\n    if (this.gatewayConfig.compress && this.gatewayConfig.transportCompression) {\n      this.logger.warn('[Shard] Payload compression has been disabled since transport compression is enabled as well.')\n      this.gatewayConfig.compress = false\n    }\n\n    // We check for built-in WebSocket implementations in Bun or Deno, NodeJS v22 has an implementation too but it seems to be less optimized so for now it is better to use the ws npm package\n    const shouldUseBuiltin = Reflect.has(globalThis, 'WebSocket') && (Reflect.has(globalThis, 'Bun') || Reflect.has(globalThis, 'Deno'))\n\n    // @ts-expect-error NodeWebSocket doesn't support \"dispatchEvent\", and while we don't use it, it is required on the \"WebSocket\" type\n    const socket: WebSocket = shouldUseBuiltin ? new WebSocket(url) : new NodeWebSocket(url)\n    this.socket = socket\n\n    // By default WebSocket will give us a Blob, this changes it so that it gives us an ArrayBuffer\n    socket.binaryType = 'arraybuffer'\n\n    socket.onerror = (event) => this.handleError(event)\n    socket.onclose = (closeEvent) => this.handleClose(closeEvent)\n    socket.onmessage = (messageEvent) => this.handleMessage(messageEvent)\n\n    return await new Promise((resolve) => {\n      socket.onopen = () => {\n        // Only set the shard to `Unidentified` state if the connection request does not come from an identify or resume action.\n        if (![ShardState.Identifying, ShardState.Resuming].includes(this.state)) {\n          this.state = ShardState.Unidentified\n        }\n\n        this.logger.debug(`[Shard] Shard #${this.id} socket connected.`)\n\n        this.events.connected?.(this)\n\n        resolve(this)\n      }\n    })\n  }\n\n  /**\n   * Identify the shard to the gateway. If not connected, this will also connect the shard to the gateway.\n   * @param bypassRequest - Whether to bypass the requestIdentify handler and identify immediately. This should be used carefully as it can cause invalid sessions.\n   */\n  async identify(bypassRequest = false): Promise<void> {\n    // A new identify has been requested even though there is already a connection open.\n    // Therefore we need to close the old connection and heartbeating before creating a new one.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Identifying open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ReIdentifying, 'Re-identifying closure of old connection.')\n    }\n\n    if (!bypassRequest) {\n      await this.requestIdentify()\n    }\n\n    this.state = ShardState.Identifying\n    this.events.identifying?.(this)\n\n    // It is possible that the shard is in Heartbeating state but not identified,\n    // so check whether there is already a gateway connection existing.\n    // If not we need to create one before we identify.\n    if (!this.isOpen()) {\n      await this.connect()\n    }\n\n    this.logger.debug(`[Shard] Sending Identify payload for Shard #${this.id}.`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Identify,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          compress: this.gatewayConfig.compress,\n          properties: this.gatewayConfig.properties,\n          intents: this.gatewayConfig.intents,\n          shard: [this.id, this.gatewayConfig.totalShards],\n          presence: await this.makePresence(),\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('READY', () => {\n        resolve()\n      })\n      // When identifying too fast, Discord sends an invalid session payload.\n      // This can safely be ignored though and the shard starts a new identify action.\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('READY')\n        resolve()\n      })\n    })\n  }\n\n  /** Check whether the connection to Discord is currently open. */\n  isOpen(): boolean {\n    return this.socket?.readyState === NodeWebSocket.OPEN\n  }\n\n  /** Attempt to resume the previous shards session with the gateway. */\n  async resume(): Promise<void> {\n    this.logger.debug(`[Shard] Resuming Shard #${this.id}`)\n\n    // It has been requested to resume the Shards session.\n    // It's possible that the shard is still connected with Discord's gateway therefore we need to forcefully close it.\n    if (this.isOpen()) {\n      this.logger.debug(`[Shard] Resuming open Shard #${this.id}, closing the connection`)\n      await this.close(ShardSocketCloseCodes.ResumeClosingOldConnection, 'Reconnecting the shard, closing old connection.')\n    }\n\n    // Shard has never identified, so we cannot resume.\n    if (!this.sessionId) {\n      this.logger.debug(`[Shard] Trying to resume Shard #${this.id} without the session id. Identifying the shard instead.`)\n\n      await this.identify()\n      return\n    }\n\n    this.state = ShardState.Resuming\n\n    // Before we can resume, we need to create a new connection with Discord's gateway.\n    await this.connect()\n\n    this.logger.debug(`[Shard] Resuming Shard #${this.id} connected. Session id: ${this.sessionId} | Sequence: ${this.previousSequenceNumber}`)\n\n    this.send(\n      {\n        op: GatewayOpcodes.Resume,\n        d: {\n          token: `Bot ${this.gatewayConfig.token}`,\n          session_id: this.sessionId,\n          seq: this.previousSequenceNumber ?? 0,\n        },\n      },\n      true,\n    )\n\n    return await new Promise((resolve) => {\n      this.resolves.set('RESUMED', () => resolve())\n\n      // If it is attempted to resume with an invalid session id, Discord sends an invalid session payload\n      // Not erroring here since it is easy that this happens, also it would be not catchable\n      this.resolves.set('INVALID_SESSION', () => {\n        this.resolves.delete('RESUMED')\n        resolve()\n      })\n    })\n  }\n\n  /**\n   * Send a message to Discord.\n   * @param highPriority - Whether this message should be send asap.\n   */\n  async send(message: ShardSocketRequest, highPriority: boolean = false): Promise<void> {\n    // Before acquiring a token from the bucket, check whether the shard is currently offline or not.\n    // Else bucket and token wait time just get wasted.\n    await this.checkOffline(highPriority)\n\n    await this.bucket.acquire(highPriority)\n\n    // It's possible, that the shard went offline after a token has been acquired from the bucket.\n    await this.checkOffline(highPriority)\n\n    this.socket?.send(JSON.stringify(message))\n  }\n\n  /** Shutdown the this. Forcefully disconnect the shard from Discord. The shard may not attempt to reconnect with Discord. */\n  async shutdown(): Promise<void> {\n    await this.close(ShardSocketCloseCodes.Shutdown, 'Shard shutting down.')\n    this.state = ShardState.Offline\n  }\n\n  /** Handle a gateway connection error */\n  handleError(error: Event): void {\n    this.logger.error(`[Shard] There was an error connecting Shard #${this.id}.`, error)\n  }\n\n  /** Handle a gateway connection close. */\n  async handleClose(close: CloseEvent): Promise<void> {\n    this.socket = undefined\n    this.stopHeartbeating()\n\n    // Clear the zlib/zstd data\n    this.inflate = undefined\n    this.zstdDecompress = undefined\n    this.inflateBuffer = null\n    this.decompressionPromisesQueue = []\n\n    this.logger.debug(`[Shard] Shard #${this.id} closed with code ${close.code}${close.reason ? `, and reason: ${close.reason}` : ''}.`)\n\n    // Resolve the close promise if it exists\n    this.resolveAfterClose?.(close)\n\n    switch (close.code) {\n      case ShardSocketCloseCodes.TestingFinished: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // On these codes a manual start will be done.\n      case ShardSocketCloseCodes.Shutdown:\n      case ShardSocketCloseCodes.ReIdentifying:\n      case ShardSocketCloseCodes.Resharded:\n      case ShardSocketCloseCodes.ResumeClosingOldConnection: {\n        this.state = ShardState.Disconnected\n        this.events.disconnected?.(this)\n\n        return\n      }\n      // When these codes are received something went really wrong.\n      // On those we cannot start a reconnect attempt.\n      case GatewayCloseEventCodes.AuthenticationFailed:\n      case GatewayCloseEventCodes.InvalidShard:\n      case GatewayCloseEventCodes.ShardingRequired:\n      case GatewayCloseEventCodes.InvalidApiVersion:\n      case GatewayCloseEventCodes.InvalidIntents:\n      case GatewayCloseEventCodes.DisallowedIntents: {\n        this.state = ShardState.Offline\n        this.events.disconnected?.(this)\n\n        throw new Error(close.reason || 'Discord gave no reason! GG! You broke Discord!')\n      }\n      // Gateway connection closes which require a new identify.\n      case GatewayCloseEventCodes.NotAuthenticated:\n      case GatewayCloseEventCodes.InvalidSeq:\n      case GatewayCloseEventCodes.SessionTimedOut: {\n        this.logger.debug(`[Shard] Shard #${this.id} closed requiring re-identify.`)\n        this.state = ShardState.Identifying\n        this.events.disconnected?.(this)\n\n        await this.identify()\n        return\n      }\n      // NOTE: This case must always be right above the cases that runs with default case because of how switch works when you don't break / return, more info below.\n      case GatewayCloseEventCodes.NormalClosure:\n      case GatewayCloseEventCodes.GoingAway: {\n        // If the shard is marked as goingOffline, it stays disconnected.\n        if (this.goingOffline) {\n          this.state = ShardState.Disconnected\n          this.events.disconnected?.(this)\n\n          this.goingOffline = false\n\n          return\n        }\n\n        // Otherwise, we want the shard to go through the default case where it gets resumed, as it might be an unexpected closure from Discord or Cloudflare for example, so we don't use break / return here.\n      }\n      // Gateway connection closes on which a resume is allowed.\n      case GatewayCloseEventCodes.UnknownError:\n      case GatewayCloseEventCodes.UnknownOpcode:\n      case GatewayCloseEventCodes.DecodeError:\n      case GatewayCloseEventCodes.RateLimited:\n      case GatewayCloseEventCodes.AlreadyAuthenticated:\n      default: {\n        // We don't want to get into an infinite loop where we resume forever, so if we were already resuming we identify instead\n        this.state = this.state === ShardState.Resuming ? ShardState.Identifying : ShardState.Resuming\n        this.events.disconnected?.(this)\n\n        if (this.state === ShardState.Resuming) {\n          await this.resume()\n        } else {\n          await this.identify()\n        }\n\n        return\n      }\n    }\n  }\n\n  /** Handle an incoming gateway message. */\n  async handleMessage(message: MessageEvent): Promise<void> {\n    // The ws npm package will use a Buffer, while the global built-in will use ArrayBuffer\n    const isCompressed = message.data instanceof ArrayBuffer || message.data instanceof Buffer\n\n    const data = isCompressed ? await this.decompressPacket(message.data) : (JSON.parse(message.data) as DiscordGatewayPayload)\n\n    // Check if the decompression was not successful\n    if (!data) return\n\n    await this.handleDiscordPacket(data)\n  }\n\n  /**\n   * Decompress a zlib/zstd compressed packet\n   *\n   * @private\n   */\n  async decompressPacket(data: ArrayBuffer | Buffer): Promise<DiscordGatewayPayload | null> {\n    // A buffer is a Uint8Array under the hood. An ArrayBuffer is generic, so we need to create the Uint8Array that uses the whole ArrayBuffer\n    const compressedData: Uint8Array = data instanceof Buffer ? data : new Uint8Array(data)\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zlib) {\n      if (!this.inflate) {\n        this.logger.fatal('[Shard] zlib-stream transport compression was enabled but no instance of Inflate was found.')\n        return null\n      }\n\n      // Alias, used to avoid some null checks in the Promise constructor\n      const inflate = this.inflate\n\n      const writePromise = new Promise<void>((resolve, reject) => {\n        inflate.write(compressedData, 'binary', (error) => (error ? reject(error) : resolve()))\n      })\n\n      if (!endsWithMarker(compressedData, ZLIB_SYNC_FLUSH)) return null\n\n      await writePromise\n\n      if (!this.inflateBuffer) {\n        this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.')\n        return null\n      }\n\n      const decodedData = this.textDecoder.decode(this.inflateBuffer)\n      this.inflateBuffer = null\n\n      return JSON.parse(decodedData)\n    }\n\n    if (this.gatewayConfig.transportCompression === TransportCompression.zstd) {\n      if (this.zstdDecompress) {\n        this.zstdDecompress.push(compressedData)\n\n        const decompressionPromise = new Promise<DiscordGatewayPayload>((r) => this.decompressionPromisesQueue.push(r))\n        return await decompressionPromise\n      }\n\n      if (this.inflate) {\n        // Alias, used to avoid some null checks in the Promise constructor\n        const decompress = this.inflate\n\n        const writePromise = new Promise<void>((resolve, reject) => {\n          decompress.write(compressedData, 'binary', (error) => (error ? reject(error) : resolve()))\n        })\n\n        await writePromise\n\n        if (!this.inflateBuffer) {\n          this.logger.warn('[Shard] The ZLib inflate buffer was cleared at an unexpected moment.')\n          return null\n        }\n\n        const decodedData = this.textDecoder.decode(this.inflateBuffer)\n        this.inflateBuffer = null\n\n        return JSON.parse(decodedData)\n      }\n\n      this.logger.fatal('[Shard] zstd-stream transport compression was enabled but no zstd decompressor was found.')\n      return null\n    }\n\n    if (this.gatewayConfig.compress) {\n      const decompressed = zlib.inflateSync(compressedData)\n      const decodedData = this.textDecoder.decode(decompressed)\n\n      return JSON.parse(decodedData)\n    }\n\n    return null\n  }\n\n  /** Handles a incoming gateway packet. */\n  async handleDiscordPacket(packet: DiscordGatewayPayload): Promise<void> {\n    // Edge case start: https://github.com/discordeno/discordeno/issues/2311\n    this.heart.lastAck = Date.now()\n    this.heart.acknowledged = true\n    // Edge case end!\n\n    switch (packet.op) {\n      case GatewayOpcodes.Heartbeat: {\n        if (!this.isOpen()) return\n\n        this.heart.lastBeat = Date.now()\n        // Discord randomly sends this requiring an immediate heartbeat back.\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n        this.events.heartbeat?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Hello: {\n        const interval = (packet.d as DiscordHello).heartbeat_interval\n        this.logger.debug(`[Shard] Shard #${this.id} received Hello`)\n        this.startHeartbeating(interval)\n\n        if (this.state !== ShardState.Resuming) {\n          const currentQueue = [...this.bucket.queue]\n          // HELLO has been send on a non resume action.\n          // This means that the shard starts a new session,\n          // therefore the rate limit interval has been reset too.\n          this.bucket = new LeakyBucket({\n            max: this.calculateSafeRequests(),\n            refillInterval: 60000,\n            refillAmount: this.calculateSafeRequests(),\n            logger: this.logger,\n          })\n\n          // Queue should not be lost on a re-identify.\n          this.bucket.queue.unshift(...currentQueue)\n        }\n\n        this.events.hello?.(this)\n\n        break\n      }\n      case GatewayOpcodes.HeartbeatACK: {\n        // Manually calculating the round trip time for users who need it.\n        if (this.heart.lastBeat) {\n          this.heart.rtt = this.heart.lastAck - this.heart.lastBeat\n        }\n\n        this.events.heartbeatAck?.(this)\n\n        break\n      }\n      case GatewayOpcodes.Reconnect: {\n        this.logger.debug(`[Shard] Received a Reconnect for Shard #${this.id}`)\n        this.events.requestedReconnect?.(this)\n\n        await this.resume()\n\n        break\n      }\n      case GatewayOpcodes.InvalidSession: {\n        const resumable = packet.d as boolean\n        this.logger.debug(`[Shard] Received Invalid Session for Shard #${this.id} with resumable as ${resumable}`)\n\n        this.events.invalidSession?.(this, resumable)\n\n        // We need to wait for a random amount of time between 1 and 5\n        // Reference: https://discord.com/developers/docs/topics/gateway#resuming\n        await delay(Math.floor((Math.random() * 4 + 1) * 1000))\n\n        this.resolves.get('INVALID_SESSION')?.(packet)\n        this.resolves.delete('INVALID_SESSION')\n\n        // When resumable is false we need to re-identify\n        if (!resumable) {\n          await this.identify()\n\n          break\n        }\n\n        // The session is invalid but apparently it is resumable\n        await this.resume()\n\n        break\n      }\n    }\n\n    switch (packet.t) {\n      case 'RESUMED':\n        this.state = ShardState.Connected\n        this.events.resumed?.(this)\n\n        this.logger.debug(`[Shard] Shard #${this.id} received RESUMED`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('RESUMED')?.(packet)\n        this.resolves.delete('RESUMED')\n        break\n      case 'READY': {\n        const payload = packet.d as DiscordReady\n        this.events.ready?.(this)\n\n        // Important for future resumes.\n        this.resumeGatewayUrl = payload.resume_gateway_url\n        this.sessionId = payload.session_id\n\n        this.state = ShardState.Connected\n\n        this.logger.debug(`[Shard] Shard #${this.id} received READY`)\n\n        // Continue the requests which have been queued since the shard went offline.\n        // Important when this is a re-identify\n        this.offlineSendQueue.forEach((resolve) => resolve())\n        // Setting the length to 0 will delete the elements in it\n        this.offlineSendQueue.length = 0\n\n        this.resolves.get('READY')?.(packet)\n        this.resolves.delete('READY')\n        break\n      }\n    }\n\n    // Update the sequence number if it is present\n    // `s` can be either `null` or a `number`.\n    // In order to prevent update misses when `s` is `0` we check against null.\n    if (packet.s !== null) {\n      this.previousSequenceNumber = packet.s\n    }\n\n    this.forwardToBot(packet)\n  }\n\n  forwardToBot(packet: DiscordGatewayPayload): void {\n    // The necessary handling required for the Shards connection has been finished.\n    // Now the event can be safely forwarded.\n    this.events.message?.(this, camelize(packet))\n  }\n\n  /**\n   * Override in order to make the shards presence.\n   * async in case devs create the presence based on eg. database values.\n   * Passing the shard's id there to make it easier for the dev to use this function.\n   */\n  async makePresence(): Promise<DiscordUpdatePresence | undefined> {\n    return\n  }\n\n  /**\n   * This function communicates with the management process, in order to know whether its free to identify.\n   * When this function resolves, this means that the shard is allowed to send an identify payload to discord.\n   */\n  async requestIdentify(): Promise<void> {}\n\n  /** Start sending heartbeat payloads to Discord in the provided interval. */\n  startHeartbeating(interval: number): void {\n    this.logger.debug(`[Shard] Start heartbeating on Shard #${this.id}`)\n\n    // If old heartbeast exist like after resume, clear the old ones.\n    this.stopHeartbeating()\n\n    this.heart.interval = interval\n\n    // Only set the shard's state to `Unidentified`\n    // if heartbeating has not been started due to an identify or resume action.\n    if ([ShardState.Disconnected, ShardState.Offline].includes(this.state)) {\n      this.logger.debug(`[Shard] Shard is disconnected or offline but the heartbeat was started #${this.id}`)\n      this.state = ShardState.Unidentified\n    }\n\n    // The first heartbeat needs to be send with a random delay between `0` and `interval`\n    // Using a `setTimeout(_, jitter)` here to accomplish that.\n    // `Math.random()` can be `0` so we use `0.5` if this happens\n    // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating\n    const jitter = Math.ceil(this.heart.interval * (Math.random() || 0.5))\n\n    this.heart.timeoutId = setTimeout(() => {\n      this.logger.debug(`[Shard] Beginning heartbeating process for Shard #${this.id}`)\n\n      if (!this.isOpen()) return\n\n      this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n      // Using a direct socket.send call here because heartbeat requests are reserved by us.\n      this.socket?.send(\n        JSON.stringify({\n          op: GatewayOpcodes.Heartbeat,\n          d: this.previousSequenceNumber,\n        }),\n      )\n\n      this.heart.lastBeat = Date.now()\n      this.heart.acknowledged = false\n\n      // After the random heartbeat jitter we can start a normal interval.\n      this.heart.intervalId = setInterval(async () => {\n        if (!this.isOpen()) {\n          this.logger.debug(`[Shard] Shard #${this.id} is not open, but attempted heartbeat, ignoring.`)\n          return\n        }\n\n        // The Shard did not receive a heartbeat ACK from Discord in time,\n        // therefore we have to assume that the connection has failed or got \"zombied\".\n        // The Shard needs to start a re-identify action accordingly.\n        // Reference: https://discord.com/developers/docs/topics/gateway#heartbeating-example-gateway-heartbeat-ack\n        if (!this.heart.acknowledged) {\n          this.logger.debug(`[Shard] Heartbeat not acknowledged for Shard #${this.id}. Assuming zombied connection.`)\n          await this.close(ShardSocketCloseCodes.ZombiedConnection, 'Zombied connection, did not receive an heartbeat ACK in time.')\n          return\n        }\n\n        this.logger.debug(`[Shard] Heartbeating on Shard #${this.id}. Previous sequence number: ${this.previousSequenceNumber}`)\n\n        // Using a direct socket.send call here because heartbeat requests are reserved by us.\n        this.socket?.send(\n          JSON.stringify({\n            op: GatewayOpcodes.Heartbeat,\n            d: this.previousSequenceNumber,\n          }),\n        )\n\n        this.heart.lastBeat = Date.now()\n        this.heart.acknowledged = false\n\n        this.events.heartbeat?.(this)\n      }, this.heart.interval)\n    }, jitter)\n  }\n\n  /** Stop the heartbeating process with discord. */\n  stopHeartbeating(): void {\n    // Clear the regular heartbeat interval.\n    clearInterval(this.heart.intervalId)\n    // It's possible that the Shard got closed before the first jittered heartbeat.\n    // To go safe we should clear the related timeout too.\n    clearTimeout(this.heart.timeoutId)\n  }\n}\n\n/** Check if the buffer ends with the marker */\nfunction endsWithMarker(buffer: Uint8Array, marker: Uint8Array) {\n  if (buffer.length < marker.length) return false\n\n  for (let i = 0; i < marker.length; i++) {\n    if (buffer[buffer.length - marker.length + i] !== marker[i]) return false\n  }\n\n  return true\n}\n\nexport interface ShardCreateOptions {\n  /** The shard id */\n  id: number\n  /** The connection details */\n  connection: ShardGatewayConfig\n  /** The event handlers for events on the shard. */\n  events: ShardEvents\n  /** The logger for the shard */\n  logger?: Pick<typeof logger, 'debug' | 'info' | 'warn' | 'error' | 'fatal'>\n  /** The handler to request a space to make an identify request. */\n  requestIdentify?: () => Promise<void>\n  /** Function to create the bot status to send on Identify requests */\n  makePresence?: () => Promise<DiscordUpdatePresence | undefined>\n}\n\nexport default DiscordenoShard\n"],"names":["Buffer","zlib","GatewayCloseEventCodes","GatewayOpcodes","camelize","delay","LeakyBucket","logger","NodeWebSocket","ShardSocketCloseCodes","ShardState","TransportCompression","ZLIB_SYNC_FLUSH","Uint8Array","fzstd","getFZStd","DiscordenoShard","options","maxRequestsPerRateLimitTick","previousSequenceNumber","rateLimitResetInterval","state","Offline","resumeGatewayUrl","events","offlineSendQueue","resolves","Map","goingOffline","textDecoder","TextDecoder","inflateBuffer","decompressionPromisesQueue","id","connection","heart","acknowledged","interval","requestIdentify","makePresence","bucket","max","calculateSafeRequests","refillAmount","refillInterval","gatewayConfig","connectionUrl","url","safeRequests","Math","ceil","checkOffline","highPriority","isOpen","Promise","resolve","unshift","push","close","code","reason","debug","socket","readyState","OPEN","NormalClosure","GoingAway","promise","resolveAfterClose","undefined","connect","Identifying","Resuming","includes","Connecting","connecting","URL","searchParams","set","version","toString","transportCompression","inflate","createInflate","finishFlush","constants","Z_SYNC_FLUSH","chunkSize","on","e","error","data","newBuffer","byteLength","zstd","createZstdDecompress","catch","warn","delete","zstdDecompress","Decompress","decodedData","decode","parsedData","JSON","parse","shift","compress","shouldUseBuiltin","Reflect","has","globalThis","WebSocket","binaryType","onerror","event","handleError","onclose","closeEvent","handleClose","onmessage","messageEvent","handleMessage","onopen","Unidentified","connected","identify","bypassRequest","ReIdentifying","identifying","send","op","Identify","d","token","properties","intents","shard","totalShards","presence","resume","ResumeClosingOldConnection","sessionId","Resume","session_id","seq","message","acquire","stringify","shutdown","Shutdown","stopHeartbeating","TestingFinished","disconnected","Resharded","Disconnected","AuthenticationFailed","InvalidShard","ShardingRequired","InvalidApiVersion","InvalidIntents","DisallowedIntents","Error","NotAuthenticated","InvalidSeq","SessionTimedOut","UnknownError","UnknownOpcode","DecodeError","RateLimited","AlreadyAuthenticated","isCompressed","ArrayBuffer","decompressPacket","handleDiscordPacket","compressedData","fatal","writePromise","reject","write","endsWithMarker","decompressionPromise","r","decompress","decompressed","inflateSync","packet","lastAck","Date","now","Heartbeat","lastBeat","heartbeat","Hello","heartbeat_interval","startHeartbeating","currentQueue","queue","hello","HeartbeatACK","rtt","heartbeatAck","Reconnect","requestedReconnect","InvalidSession","resumable","invalidSession","floor","random","get","t","Connected","resumed","forEach","length","payload","ready","resume_gateway_url","s","forwardToBot","jitter","timeoutId","setTimeout","intervalId","setInterval","ZombiedConnection","clearInterval","clearTimeout","buffer","marker","i"],"mappings":"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"}
package/dist/esm/types.js CHANGED
@@ -21,7 +21,9 @@ export var TransportCompression = /*#__PURE__*/ function(TransportCompression) {
21
21
  * ZStd-Stream Transport Compression.
22
22
  *
23
23
  * @remarks
24
- * Uses `fzstd` to decompress the payloads. `fzstd` is an optional dependency, it is required to be installed for this compression.
24
+ * This will use `node:zlib` zstd implementation if available (node v22.15+ or node v23.8+) or `fzstd` otherwise.
25
+ *
26
+ * `fzstd` is an optional dependency. You will need to install it to be able to use it.
25
27
  *
26
28
  * @see https://discord.com/developers/docs/topics/gateway#zstdstream
27
29
  */ TransportCompression["zstd"] = "zstd-stream";
@@ -40,4 +42,4 @@ export var ShardSocketCloseCodes = /*#__PURE__*/ function(ShardSocketCloseCodes)
40
42
  return ShardSocketCloseCodes;
41
43
  }({});
42
44
 
43
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types.ts"],"sourcesContent":["import type { Camelize, DiscordGatewayPayload, GatewayOpcodes } from '@discordeno/types'\nimport type Shard from './Shard.js'\n\nexport enum ShardState {\n  /** Shard is fully connected to the gateway and receiving events from Discord. */\n  Connected = 0,\n  /** Shard started to connect to the gateway. This is only used if the shard is not currently trying to identify or resume. */\n  Connecting = 1,\n  /** Shard got disconnected and reconnection actions have been started. */\n  Disconnected = 2,\n  /** The shard is connected to the gateway but only heartbeating. At this state the shard has not been identified with discord. */\n  Unidentified = 3,\n  /** Shard is trying to identify with the gateway to create a new session. */\n  Identifying = 4,\n  /** Shard is trying to resume a session with the gateway. */\n  Resuming = 5,\n  /** Shard got shut down studied or due to a not (self) fixable error and may not attempt to reconnect on its own. */\n  Offline = 6,\n}\n\nexport enum TransportCompression {\n  /**\n   * ZLib-Stream Transport Compression.\n   *\n   * @remarks\n   * Uses `node:zlib` to decompress the payloads\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zlibstream\n   */\n  zlib = 'zlib-stream',\n  /**\n   * ZStd-Stream Transport Compression.\n   *\n   * @remarks\n   * Uses `fzstd` to decompress the payloads. `fzstd` is an optional dependency, it is required to be installed for this compression.\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zstdstream\n   */\n  zstd = 'zstd-stream',\n}\n\nexport interface ShardGatewayConfig {\n  /**\n   * Whatever to enable Payload compression.\n   *\n   * @remarks\n   * This is compatible with {@link transportCompression}\n   *\n   * @default false\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#payload-compression\n   */\n  compress: boolean\n  /**\n   * What Transport Compression should be use\n   *\n   * @default null\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#transport-compression\n   */\n  transportCompression: TransportCompression | null\n  /** The calculated intent value of the events which the shard should receive.\n   *\n   * @default 0\n   */\n  intents: number\n  /** Identify properties to use */\n  properties: {\n    /** Operating system the shard runs on.\n     *\n     * @default \"darwin\" | \"linux\" | \"windows\"\n     */\n    os: string\n    /** The \"browser\" where this shard is running on.\n     *\n     * @default \"Discordeno\"\n     */\n    browser: string\n    /** The device on which the shard is running.\n     *\n     * @default \"Discordeno\"\n     */\n    device: string\n  }\n  /** Bot token which is used to connect to Discord */\n  token: string\n  /** The URL of the gateway which should be connected to.\n   *\n   * @default \"wss://gateway.discord.gg\"\n   */\n  url: string\n  /** The gateway version which should be used.\n   *\n   * @default 10\n   */\n  version: number\n  /**\n   * The total number of shards to connect to across the entire bot.\n   * @default 1\n   */\n  totalShards: number\n}\n\nexport interface ShardHeart {\n  /** Whether or not the heartbeat was acknowledged by Discord in time. */\n  acknowledged: boolean\n  /** Interval between heartbeats requested by Discord. */\n  interval: number\n  /** Id of the interval, which is used for sending the heartbeats. */\n  intervalId?: NodeJS.Timeout\n  /** Unix (in milliseconds) timestamp when the last heartbeat ACK was received from Discord. */\n  lastAck?: number\n  /** Unix timestamp (in milliseconds) when the last heartbeat was sent. */\n  lastBeat?: number\n  /** Round trip time (in milliseconds) from Shard to Discord and back.\n   * Calculated using the heartbeat system.\n   * Note: this value is undefined until the first heartbeat to Discord has happened.\n   */\n  rtt?: number\n  /** Id of the timeout which is used for sending the first heartbeat to Discord since it's \"special\". */\n  timeoutId?: NodeJS.Timeout\n}\n\nexport interface ShardEvents {\n  /** A heartbeat has been send. */\n  heartbeat?: (shard: Shard) => unknown\n  /** A heartbeat ACK was received. */\n  heartbeatAck?: (shard: Shard) => unknown\n  /** Shard has received a Hello payload. */\n  hello?: (shard: Shard) => unknown\n  /** The Shards session has been invalidated. */\n  invalidSession?: (shard: Shard, resumable: boolean) => unknown\n  /** The shard has started a resume action. */\n  resuming?: (shard: Shard) => unknown\n  /** The shard has successfully resumed an old session. */\n  resumed?: (shard: Shard) => unknown\n  /** Discord has requested the Shard to reconnect. */\n  requestedReconnect?: (shard: Shard) => unknown\n  /** The shard started to connect to Discord's gateway. */\n  connecting?: (shard: Shard) => unknown\n  /** The shard is connected with Discord's gateway. */\n  connected?: (shard: Shard) => unknown\n  /** The shard has been disconnected from Discord's gateway. */\n  disconnected?: (shard: Shard) => unknown\n  /** The shard has started to identify itself to Discord. */\n  identifying?: (shard: Shard) => unknown\n  /** The shard has successfully been identified itself with Discord. */\n  ready?: (shard: Shard) => unknown\n  /** The shard has received a message from Discord. */\n  message?: (shard: Shard, payload: Camelize<DiscordGatewayPayload>) => unknown\n}\n\nexport enum ShardSocketCloseCodes {\n  /** A regular Shard shutdown. */\n  Shutdown = 3000,\n  /** A resume has been requested and therefore the old connection needs to be closed. */\n  ResumeClosingOldConnection = 3024,\n  /**\n   * Did not receive a heartbeat ACK in time.\n   * Closing the shard and creating a new session.\n   */\n  ZombiedConnection = 3010,\n  /** Discordeno's gateway tests hae been finished, therefore the Shard can be turned off. */\n  TestingFinished = 3064,\n  /** Special close code reserved for Discordeno's zero-downtime resharding system. */\n  Resharded = 3065,\n  /** Shard is re-identifying therefore the old connection needs to be closed. */\n  ReIdentifying = 3066,\n}\n\nexport interface ShardSocketRequest {\n  /** The OP-Code for the payload to send. */\n  op: GatewayOpcodes\n  /** Payload data. */\n  d: unknown\n}\n\n/** https://discord.com/developers/docs/topics/gateway#update-voice-state */\nexport interface UpdateVoiceState {\n  /** id of the guild */\n  guildId: string\n  /** id of the voice channel client wants to join (null if disconnecting) */\n  channelId: string | null\n  /** Is the client muted */\n  selfMute: boolean\n  /** Is the client deafened */\n  selfDeaf: boolean\n}\n"],"names":["ShardState","TransportCompression","ShardSocketCloseCodes"],"mappings":"AAGA,OAAO,IAAA,AAAKA,oCAAAA;IACV,+EAA+E;IAE/E,2HAA2H;IAE3H,uEAAuE;IAEvE,+HAA+H;IAE/H,0EAA0E;IAE1E,0DAA0D;IAE1D,kHAAkH;WAbxGA;MAeX;AAED,OAAO,IAAA,AAAKC,8CAAAA;IACV;;;;;;;GAOC;IAED;;;;;;;GAOC;WAjBSA;MAmBX;AAiHD,OAAO,IAAA,AAAKC,+CAAAA;IACV,8BAA8B;IAE9B,qFAAqF;IAErF;;;GAGC;IAED,yFAAyF;IAEzF,kFAAkF;IAElF,6EAA6E;WAdnEA;MAgBX"}
45
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types.ts"],"sourcesContent":["import type { Camelize, DiscordGatewayPayload, GatewayOpcodes } from '@discordeno/types'\nimport type Shard from './Shard.js'\n\nexport enum ShardState {\n  /** Shard is fully connected to the gateway and receiving events from Discord. */\n  Connected = 0,\n  /** Shard started to connect to the gateway. This is only used if the shard is not currently trying to identify or resume. */\n  Connecting = 1,\n  /** Shard got disconnected and reconnection actions have been started. */\n  Disconnected = 2,\n  /** The shard is connected to the gateway but only heartbeating. At this state the shard has not been identified with discord. */\n  Unidentified = 3,\n  /** Shard is trying to identify with the gateway to create a new session. */\n  Identifying = 4,\n  /** Shard is trying to resume a session with the gateway. */\n  Resuming = 5,\n  /** Shard got shut down studied or due to a not (self) fixable error and may not attempt to reconnect on its own. */\n  Offline = 6,\n}\n\nexport enum TransportCompression {\n  /**\n   * ZLib-Stream Transport Compression.\n   *\n   * @remarks\n   * Uses `node:zlib` to decompress the payloads\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zlibstream\n   */\n  zlib = 'zlib-stream',\n  /**\n   * ZStd-Stream Transport Compression.\n   *\n   * @remarks\n   * This will use `node:zlib` zstd implementation if available (node v22.15+ or node v23.8+) or `fzstd` otherwise.\n   *\n   * `fzstd` is an optional dependency. You will need to install it to be able to use it.\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#zstdstream\n   */\n  zstd = 'zstd-stream',\n}\n\nexport interface ShardGatewayConfig {\n  /**\n   * Whatever to enable Payload compression.\n   *\n   * @remarks\n   * This is compatible with {@link transportCompression}\n   *\n   * @default false\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#payload-compression\n   */\n  compress: boolean\n  /**\n   * What Transport Compression should be use\n   *\n   * @default null\n   *\n   * @see https://discord.com/developers/docs/topics/gateway#transport-compression\n   */\n  transportCompression: TransportCompression | null\n  /** The calculated intent value of the events which the shard should receive.\n   *\n   * @default 0\n   */\n  intents: number\n  /** Identify properties to use */\n  properties: {\n    /** Operating system the shard runs on.\n     *\n     * @default \"darwin\" | \"linux\" | \"windows\"\n     */\n    os: string\n    /** The \"browser\" where this shard is running on.\n     *\n     * @default \"Discordeno\"\n     */\n    browser: string\n    /** The device on which the shard is running.\n     *\n     * @default \"Discordeno\"\n     */\n    device: string\n  }\n  /** Bot token which is used to connect to Discord */\n  token: string\n  /** The URL of the gateway which should be connected to.\n   *\n   * @default \"wss://gateway.discord.gg\"\n   */\n  url: string\n  /** The gateway version which should be used.\n   *\n   * @default 10\n   */\n  version: number\n  /**\n   * The total number of shards to connect to across the entire bot.\n   * @default 1\n   */\n  totalShards: number\n}\n\nexport interface ShardHeart {\n  /** Whether or not the heartbeat was acknowledged by Discord in time. */\n  acknowledged: boolean\n  /** Interval between heartbeats requested by Discord. */\n  interval: number\n  /** Id of the interval, which is used for sending the heartbeats. */\n  intervalId?: NodeJS.Timeout\n  /** Unix (in milliseconds) timestamp when the last heartbeat ACK was received from Discord. */\n  lastAck?: number\n  /** Unix timestamp (in milliseconds) when the last heartbeat was sent. */\n  lastBeat?: number\n  /** Round trip time (in milliseconds) from Shard to Discord and back.\n   * Calculated using the heartbeat system.\n   * Note: this value is undefined until the first heartbeat to Discord has happened.\n   */\n  rtt?: number\n  /** Id of the timeout which is used for sending the first heartbeat to Discord since it's \"special\". */\n  timeoutId?: NodeJS.Timeout\n}\n\nexport interface ShardEvents {\n  /** A heartbeat has been send. */\n  heartbeat?: (shard: Shard) => unknown\n  /** A heartbeat ACK was received. */\n  heartbeatAck?: (shard: Shard) => unknown\n  /** Shard has received a Hello payload. */\n  hello?: (shard: Shard) => unknown\n  /** The Shards session has been invalidated. */\n  invalidSession?: (shard: Shard, resumable: boolean) => unknown\n  /** The shard has started a resume action. */\n  resuming?: (shard: Shard) => unknown\n  /** The shard has successfully resumed an old session. */\n  resumed?: (shard: Shard) => unknown\n  /** Discord has requested the Shard to reconnect. */\n  requestedReconnect?: (shard: Shard) => unknown\n  /** The shard started to connect to Discord's gateway. */\n  connecting?: (shard: Shard) => unknown\n  /** The shard is connected with Discord's gateway. */\n  connected?: (shard: Shard) => unknown\n  /** The shard has been disconnected from Discord's gateway. */\n  disconnected?: (shard: Shard) => unknown\n  /** The shard has started to identify itself to Discord. */\n  identifying?: (shard: Shard) => unknown\n  /** The shard has successfully been identified itself with Discord. */\n  ready?: (shard: Shard) => unknown\n  /** The shard has received a message from Discord. */\n  message?: (shard: Shard, payload: Camelize<DiscordGatewayPayload>) => unknown\n}\n\nexport enum ShardSocketCloseCodes {\n  /** A regular Shard shutdown. */\n  Shutdown = 3000,\n  /** A resume has been requested and therefore the old connection needs to be closed. */\n  ResumeClosingOldConnection = 3024,\n  /**\n   * Did not receive a heartbeat ACK in time.\n   * Closing the shard and creating a new session.\n   */\n  ZombiedConnection = 3010,\n  /** Discordeno's gateway tests hae been finished, therefore the Shard can be turned off. */\n  TestingFinished = 3064,\n  /** Special close code reserved for Discordeno's zero-downtime resharding system. */\n  Resharded = 3065,\n  /** Shard is re-identifying therefore the old connection needs to be closed. */\n  ReIdentifying = 3066,\n}\n\nexport interface ShardSocketRequest {\n  /** The OP-Code for the payload to send. */\n  op: GatewayOpcodes\n  /** Payload data. */\n  d: unknown\n}\n\n/** https://discord.com/developers/docs/topics/gateway#update-voice-state */\nexport interface UpdateVoiceState {\n  /** id of the guild */\n  guildId: string\n  /** id of the voice channel client wants to join (null if disconnecting) */\n  channelId: string | null\n  /** Is the client muted */\n  selfMute: boolean\n  /** Is the client deafened */\n  selfDeaf: boolean\n}\n"],"names":["ShardState","TransportCompression","ShardSocketCloseCodes"],"mappings":"AAGA,OAAO,IAAA,AAAKA,oCAAAA;IACV,+EAA+E;IAE/E,2HAA2H;IAE3H,uEAAuE;IAEvE,+HAA+H;IAE/H,0EAA0E;IAE1E,0DAA0D;IAE1D,kHAAkH;WAbxGA;MAeX;AAED,OAAO,IAAA,AAAKC,8CAAAA;IACV;;;;;;;GAOC;IAED;;;;;;;;;GASC;WAnBSA;MAqBX;AAiHD,OAAO,IAAA,AAAKC,+CAAAA;IACV,8BAA8B;IAE9B,qFAAqF;IAErF;;;GAGC;IAED,yFAAyF;IAEzF,kFAAkF;IAElF,6EAA6E;WAdnEA;MAgBX"}
@@ -1,8 +1,8 @@
1
1
  import { Buffer } from 'node:buffer';
2
- import { type Inflate } from 'node:zlib';
2
+ import zlib from 'node:zlib';
3
3
  import type { DiscordGatewayPayload, DiscordUpdatePresence } from '@discordeno/types';
4
4
  import { LeakyBucket, logger } from '@discordeno/utils';
5
- import type { Decompress as ZstdDecompress } from 'fzstd';
5
+ import type { Decompress as FZstdDecompress } from 'fzstd';
6
6
  import { type ShardEvents, type ShardGatewayConfig, type ShardHeart, type ShardSocketRequest, ShardState } from './types.js';
7
7
  export declare class DiscordenoShard {
8
8
  /** The id of the shard. */
@@ -47,12 +47,12 @@ export declare class DiscordenoShard {
47
47
  goingOffline: boolean;
48
48
  /** Text decoder used for compressed payloads. */
49
49
  textDecoder: TextDecoder;
50
- /** ZLib Inflate instance for ZLib-stream transport payloads. */
51
- inflate?: Inflate;
50
+ /** zlib Inflate or zstd decompress (from node:zlib) instance for transport payloads. */
51
+ inflate?: zlib.Inflate | zlib.ZstdDecompress;
52
52
  /** ZLib inflate buffer. */
53
53
  inflateBuffer: Uint8Array | null;
54
54
  /** ZStd Decompress instance for ZStd-stream transport payloads. */
55
- zstdDecompress?: ZstdDecompress;
55
+ zstdDecompress?: FZstdDecompress;
56
56
  /** Queue for compressed payloads for Zstd Decompress */
57
57
  decompressionPromisesQueue: ((data: DiscordGatewayPayload) => void)[];
58
58
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"Shard.d.ts","sourceRoot":"","sources":["../../src/Shard.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Shard.d.ts","sourceRoot":"","sources":["../../src/Shard.ts"],"names":[],"mappings":"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"}
@@ -30,7 +30,9 @@ export declare enum TransportCompression {
30
30
  * ZStd-Stream Transport Compression.
31
31
  *
32
32
  * @remarks
33
- * Uses `fzstd` to decompress the payloads. `fzstd` is an optional dependency, it is required to be installed for this compression.
33
+ * This will use `node:zlib` zstd implementation if available (node v22.15+ or node v23.8+) or `fzstd` otherwise.
34
+ *
35
+ * `fzstd` is an optional dependency. You will need to install it to be able to use it.
34
36
  *
35
37
  * @see https://discord.com/developers/docs/topics/gateway#zstdstream
36
38
  */
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@discordeno/gateway",
3
- "version": "21.0.1-next.d50d47e",
3
+ "version": "21.0.1-next.d79e672",
4
4
  "main": "./dist/esm/index.js",
5
5
  "types": "./dist/types/index.d.ts",
6
6
  "exports": {
@@ -34,8 +34,8 @@
34
34
  "test:test-type": "tsc --project tests/tsconfig.json"
35
35
  },
36
36
  "dependencies": {
37
- "@discordeno/types": "21.0.1-next.d50d47e",
38
- "@discordeno/utils": "21.0.1-next.d50d47e",
37
+ "@discordeno/types": "21.0.1-next.d79e672",
38
+ "@discordeno/utils": "21.0.1-next.d79e672",
39
39
  "ws": "^8.18.1"
40
40
  },
41
41
  "optionalDependencies": {