@discordeno/rest 21.0.1-next.f4098d5 → 21.0.1-next.fca0b40
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.
- package/dist/cjs/index.cjs +2 -2
- package/dist/cjs/manager.cjs +84 -41
- package/dist/cjs/routes.cjs +12 -11
- package/dist/esm/index.js +2 -2
- package/dist/esm/manager.js +85 -42
- package/dist/esm/routes.js +12 -11
- package/dist/esm/types.js +1 -1
- package/dist/esm/typings/routes.js +1 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/manager.d.ts.map +1 -1
- package/dist/types/routes.d.ts.map +1 -1
- package/dist/types/types.d.ts +46 -20
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/typings/routes.d.ts +3 -3
- package/dist/types/typings/routes.d.ts.map +1 -1
- package/package.json +8 -8
package/dist/esm/manager.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Buffer } from 'node:buffer';
|
|
2
2
|
import { inspect } from 'node:util';
|
|
3
|
-
import {
|
|
3
|
+
import { calculateBits, camelize, camelToSnakeCase, DISCORDENO_VERSION, delay, getBotIdFromToken, hasProperty, logger, processReactionString, snowflakeToTimestamp, urlToBase64 } from '@discordeno/utils';
|
|
4
4
|
import { createInvalidRequestBucket } from './invalidBucket.js';
|
|
5
5
|
import { Queue } from './queue.js';
|
|
6
6
|
import { createRoutes } from './routes.js';
|
|
@@ -46,6 +46,12 @@ export function createRestManager(options) {
|
|
|
46
46
|
token: options.token,
|
|
47
47
|
version: options.version ?? DISCORD_API_VERSION,
|
|
48
48
|
logger: options.logger ?? logger,
|
|
49
|
+
events: {
|
|
50
|
+
request: ()=>{},
|
|
51
|
+
response: ()=>{},
|
|
52
|
+
requestError: ()=>{},
|
|
53
|
+
...options.events
|
|
54
|
+
},
|
|
49
55
|
routes: createRoutes(),
|
|
50
56
|
createBaseHeaders () {
|
|
51
57
|
return {
|
|
@@ -160,8 +166,6 @@ export function createRestManager(options) {
|
|
|
160
166
|
headers[AUDIT_LOG_REASON_HEADER] = encodeURIComponent(options?.reason);
|
|
161
167
|
}
|
|
162
168
|
let body;
|
|
163
|
-
// TODO: check if we need to add specific check for GET method
|
|
164
|
-
// Since GET does not allow bodies
|
|
165
169
|
// Have to check for attachments first, since body then has to be send in a different way.
|
|
166
170
|
if (options?.files !== undefined) {
|
|
167
171
|
const form = new FormData();
|
|
@@ -304,13 +308,20 @@ export function createRestManager(options) {
|
|
|
304
308
|
const authorizationScheme = payload.headers.authorization?.split(' ')[0];
|
|
305
309
|
loggingHeaders.authorization = `${authorizationScheme} tokenhere`;
|
|
306
310
|
}
|
|
311
|
+
const request = new Request(url, payload);
|
|
312
|
+
rest.events.request(request, {
|
|
313
|
+
body: options.requestBodyOptions?.body
|
|
314
|
+
});
|
|
307
315
|
rest.logger.debug(`sending request to ${url}`, 'with payload:', {
|
|
308
316
|
...payload,
|
|
309
317
|
headers: loggingHeaders
|
|
310
318
|
});
|
|
311
|
-
const response = await fetch(
|
|
319
|
+
const response = await fetch(request).catch(async (error)=>{
|
|
312
320
|
rest.logger.error(error);
|
|
313
|
-
|
|
321
|
+
rest.events.requestError(request, error, {
|
|
322
|
+
body: options.requestBodyOptions?.body
|
|
323
|
+
});
|
|
324
|
+
// Mark request as completed
|
|
314
325
|
rest.invalidBucket.handleCompletedRequest(999, false);
|
|
315
326
|
options.reject({
|
|
316
327
|
ok: false,
|
|
@@ -320,7 +331,13 @@ export function createRestManager(options) {
|
|
|
320
331
|
throw error;
|
|
321
332
|
});
|
|
322
333
|
rest.logger.debug(`request fetched from ${url} with status ${response.status} & ${response.statusText}`);
|
|
323
|
-
//
|
|
334
|
+
// Sometimes the Content-Type may be "application/json; charset=utf-8", for this reason, we need to check the start of the header
|
|
335
|
+
const body = await (response.headers.get('Content-Type')?.startsWith('application/json') ? response.json() : response.text()).catch(()=>null);
|
|
336
|
+
rest.events.response(request, response, {
|
|
337
|
+
requestBody: options.requestBodyOptions?.body,
|
|
338
|
+
responseBody: body
|
|
339
|
+
});
|
|
340
|
+
// Mark request as completed
|
|
324
341
|
rest.invalidBucket.handleCompletedRequest(response.status, response.headers.get(RATE_LIMIT_SCOPE_HEADER) === 'shared');
|
|
325
342
|
// Set the bucket id if it was available on the headers
|
|
326
343
|
const bucketId = rest.processHeaders(rest.simplifyUrl(options.route, options.method), response.headers, payload.headers.authorization);
|
|
@@ -328,7 +345,6 @@ export function createRestManager(options) {
|
|
|
328
345
|
if (response.status < 200 || response.status >= 400) {
|
|
329
346
|
rest.logger.debug(`Request to ${url} failed.`);
|
|
330
347
|
if (response.status !== 429) {
|
|
331
|
-
const body = response.headers.get('Content-Type') === 'application/json' ? await response.json() : await response.text();
|
|
332
348
|
options.reject({
|
|
333
349
|
ok: false,
|
|
334
350
|
status: response.status,
|
|
@@ -337,8 +353,6 @@ export function createRestManager(options) {
|
|
|
337
353
|
});
|
|
338
354
|
return;
|
|
339
355
|
}
|
|
340
|
-
// Consume the response body to avoid leaking memory
|
|
341
|
-
await response.arrayBuffer();
|
|
342
356
|
rest.logger.debug(`Request to ${url} was ratelimited.`);
|
|
343
357
|
// Too many attempts, get rid of request from queue.
|
|
344
358
|
if (options.retryCount >= rest.maxRetryCount) {
|
|
@@ -357,33 +371,57 @@ export function createRestManager(options) {
|
|
|
357
371
|
if (resetAfter) await delay(Number(resetAfter) * 1000);
|
|
358
372
|
return await options.retryRequest?.(options);
|
|
359
373
|
}
|
|
360
|
-
// Discord sometimes sends
|
|
374
|
+
// Discord sometimes sends a response with no content
|
|
361
375
|
options.resolve({
|
|
362
376
|
ok: true,
|
|
363
377
|
status: response.status,
|
|
364
|
-
body: response.status === 204 ? undefined :
|
|
378
|
+
body: response.status === 204 ? undefined : body
|
|
365
379
|
});
|
|
366
380
|
},
|
|
367
381
|
simplifyUrl (url, method) {
|
|
368
|
-
const
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
382
|
+
const routeInformationKey = [
|
|
383
|
+
method
|
|
384
|
+
];
|
|
385
|
+
const queryParamIndex = url.indexOf('?');
|
|
386
|
+
const route = queryParamIndex !== -1 ? url.slice(0, queryParamIndex) : url;
|
|
387
|
+
// Since the urls start with / the first part will always be empty
|
|
388
|
+
const splittedRoute = route.split('/');
|
|
389
|
+
// 1) Strip the minor params
|
|
390
|
+
// The only majors are channels, guilds, webhooks and webhooks with their token
|
|
391
|
+
const strippedRoute = splittedRoute.map((part, index, array)=>{
|
|
392
|
+
// While parseInt will truncate the snowflake id, it will still tell us if it is a number
|
|
393
|
+
const isNumber = Number.isFinite(parseInt(part, 10));
|
|
394
|
+
if (!isNumber) {
|
|
395
|
+
// Reactions emoji need to be stripped as it is a minor parameter
|
|
396
|
+
if (index >= 1 && array[index - 1] === 'reactions') return 'x';
|
|
397
|
+
// If we are on a webhook or if it is part of the route, keep it as it is a major parameter
|
|
398
|
+
return part;
|
|
399
|
+
}
|
|
400
|
+
// Check if we are on a channel id, a guild id or a webhook id
|
|
401
|
+
const isMajor = index >= 1 && (array[index - 1] === 'channels' || array[index - 1] === 'guilds' || array[index - 1] === 'webhooks');
|
|
402
|
+
if (isMajor) return part;
|
|
403
|
+
return 'x';
|
|
404
|
+
}).join('/');
|
|
405
|
+
routeInformationKey.push(strippedRoute);
|
|
406
|
+
// 2) Account for exceptions
|
|
407
|
+
// - https://github.com/discord/discord-api-docs/issues/1092
|
|
408
|
+
// - https://github.com/discord/discord-api-docs/issues/1295
|
|
409
|
+
// The 2 exceptions are for message delete, so we need to check if we are in that route
|
|
410
|
+
if (method === 'DELETE' && splittedRoute.length === 5 && splittedRoute[1] === 'channels' && strippedRoute.endsWith('/messages/x')) {
|
|
411
|
+
const messageId = splittedRoute[4];
|
|
412
|
+
const timestamp = snowflakeToTimestamp(messageId);
|
|
413
|
+
const now = Date.now();
|
|
414
|
+
// https://github.com/discord/discord-api-docs/issues/1092
|
|
415
|
+
if (now - timestamp < 10_000) {
|
|
416
|
+
routeInformationKey.push('message-delete-10s');
|
|
417
|
+
}
|
|
418
|
+
// https://github.com/discord/discord-api-docs/issues/1295
|
|
419
|
+
// 2 weeks = 2 * 7 * 24 * 60 * 60 * 1000 = 1209600000
|
|
420
|
+
if (now - timestamp > 1209600000) {
|
|
421
|
+
routeInformationKey.push('message-delete-2w');
|
|
422
|
+
}
|
|
385
423
|
}
|
|
386
|
-
return
|
|
424
|
+
return routeInformationKey.join(':');
|
|
387
425
|
},
|
|
388
426
|
async processRequest (request) {
|
|
389
427
|
const url = rest.simplifyUrl(request.route, request.method);
|
|
@@ -419,10 +457,18 @@ export function createRestManager(options) {
|
|
|
419
457
|
options.headers ??= {};
|
|
420
458
|
options.headers[rest.authorizationHeader] = rest.authorization;
|
|
421
459
|
}
|
|
422
|
-
const
|
|
460
|
+
const request = new Request(`${rest.baseUrl}/v${rest.version}${route}`, rest.createRequestBody(method, options));
|
|
461
|
+
rest.events.request(request, {
|
|
462
|
+
body: options?.body
|
|
463
|
+
});
|
|
464
|
+
const result = await fetch(request);
|
|
465
|
+
// Sometimes the Content-Type may be "application/json; charset=utf-8", for this reason, we need to check the start of the header
|
|
466
|
+
const body = await (result.headers.get('Content-Type')?.startsWith('application/json') ? result.json() : result.text()).catch(()=>null);
|
|
467
|
+
rest.events.response(request, result, {
|
|
468
|
+
requestBody: options?.body,
|
|
469
|
+
responseBody: body
|
|
470
|
+
});
|
|
423
471
|
if (!result.ok) {
|
|
424
|
-
// Sometime the Content-Type may be "application/json; charset=utf-8", for this reason we need to check the start of the header
|
|
425
|
-
const body = await (result.headers.get('Content-Type')?.startsWith('application/json') ? result.json() : result.text()).catch(()=>null);
|
|
426
472
|
error.cause = Object.assign(Object.create(baseErrorPrototype), {
|
|
427
473
|
ok: false,
|
|
428
474
|
status: result.status,
|
|
@@ -430,7 +476,7 @@ export function createRestManager(options) {
|
|
|
430
476
|
});
|
|
431
477
|
throw error;
|
|
432
478
|
}
|
|
433
|
-
return result.status !== 204 ?
|
|
479
|
+
return result.status !== 204 ? typeof body === 'string' ? JSON.parse(body) : body : undefined;
|
|
434
480
|
}
|
|
435
481
|
return await new Promise(async (resolve, reject)=>{
|
|
436
482
|
const payload = {
|
|
@@ -442,7 +488,7 @@ export function createRestManager(options) {
|
|
|
442
488
|
await rest.processRequest(payload);
|
|
443
489
|
},
|
|
444
490
|
resolve: (data)=>{
|
|
445
|
-
resolve(data.status !== 204 ? JSON.parse(data.body
|
|
491
|
+
resolve(data.status !== 204 ? typeof data.body === 'string' ? JSON.parse(data.body) : data.body : undefined);
|
|
446
492
|
},
|
|
447
493
|
reject: (reason)=>{
|
|
448
494
|
let errorText;
|
|
@@ -662,9 +708,6 @@ export function createRestManager(options) {
|
|
|
662
708
|
async deleteGlobalApplicationCommand (commandId) {
|
|
663
709
|
await rest.delete(rest.routes.interactions.commands.command(rest.applicationId, commandId));
|
|
664
710
|
},
|
|
665
|
-
async deleteGuild (guildId) {
|
|
666
|
-
await rest.delete(rest.routes.guilds.guild(guildId));
|
|
667
|
-
},
|
|
668
711
|
async deleteGuildApplicationCommand (commandId, guildId) {
|
|
669
712
|
await rest.delete(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId));
|
|
670
713
|
},
|
|
@@ -1064,8 +1107,8 @@ export function createRestManager(options) {
|
|
|
1064
1107
|
async getGlobalApplicationCommand (commandId) {
|
|
1065
1108
|
return await rest.get(rest.routes.interactions.commands.command(rest.applicationId, commandId));
|
|
1066
1109
|
},
|
|
1067
|
-
async getGlobalApplicationCommands () {
|
|
1068
|
-
return await rest.get(rest.routes.interactions.commands.commands(rest.applicationId));
|
|
1110
|
+
async getGlobalApplicationCommands (options) {
|
|
1111
|
+
return await rest.get(rest.routes.interactions.commands.commands(rest.applicationId, options?.withLocalizations));
|
|
1069
1112
|
},
|
|
1070
1113
|
async getGuild (guildId, options = {
|
|
1071
1114
|
counts: true
|
|
@@ -1084,8 +1127,8 @@ export function createRestManager(options) {
|
|
|
1084
1127
|
async getGuildApplicationCommand (commandId, guildId) {
|
|
1085
1128
|
return await rest.get(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId));
|
|
1086
1129
|
},
|
|
1087
|
-
async getGuildApplicationCommands (guildId) {
|
|
1088
|
-
return await rest.get(rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId));
|
|
1130
|
+
async getGuildApplicationCommands (guildId, options) {
|
|
1131
|
+
return await rest.get(rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId, options?.withLocalizations));
|
|
1089
1132
|
},
|
|
1090
1133
|
async getGuildPreview (guildId) {
|
|
1091
1134
|
return await rest.get(rest.routes.guilds.preview(guildId));
|
|
@@ -1577,4 +1620,4 @@ var HttpResponseCode = /*#__PURE__*/ function(HttpResponseCode) {
|
|
|
1577
1620
|
return HttpResponseCode;
|
|
1578
1621
|
}(HttpResponseCode || {});
|
|
1579
1622
|
|
|
1580
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/manager.ts"],"sourcesContent":["import { Buffer } from 'node:buffer'\nimport { type InspectOptions, inspect } from 'node:util'\nimport type {\n  BigString,\n  Camelize,\n  DiscordAccessTokenResponse,\n  DiscordActivityInstance,\n  DiscordApplication,\n  DiscordApplicationCommand,\n  DiscordApplicationRoleConnection,\n  DiscordApplicationRoleConnectionMetadata,\n  DiscordAuditLog,\n  DiscordAutoModerationRule,\n  DiscordBan,\n  DiscordBulkBan,\n  DiscordChannel,\n  DiscordConnection,\n  DiscordCurrentAuthorization,\n  DiscordEmoji,\n  DiscordEntitlement,\n  DiscordFollowedChannel,\n  DiscordGetAnswerVotesResponse,\n  DiscordGetGatewayBot,\n  DiscordGuild,\n  DiscordGuildApplicationCommandPermissions,\n  DiscordGuildOnboarding,\n  DiscordGuildPreview,\n  DiscordGuildWidget,\n  DiscordGuildWidgetSettings,\n  DiscordIncidentsData,\n  DiscordIntegration,\n  DiscordInteractionCallbackResponse,\n  DiscordInvite,\n  DiscordInviteMetadata,\n  DiscordListActiveThreads,\n  DiscordListArchivedThreads,\n  DiscordLobby,\n  DiscordLobbyMember,\n  DiscordMember,\n  DiscordMemberWithUser,\n  DiscordMessage,\n  DiscordPrunedCount,\n  DiscordRole,\n  DiscordScheduledEvent,\n  DiscordSku,\n  DiscordSoundboardSound,\n  DiscordStageInstance,\n  DiscordSticker,\n  DiscordStickerPack,\n  DiscordSubscription,\n  DiscordTemplate,\n  DiscordThreadMember,\n  DiscordUser,\n  DiscordVanityUrl,\n  DiscordVoiceRegion,\n  DiscordVoiceState,\n  DiscordWebhook,\n  DiscordWelcomeScreen,\n  ModifyGuildTemplate,\n} from '@discordeno/types'\nimport {\n  DISCORDENO_VERSION,\n  calculateBits,\n  camelToSnakeCase,\n  camelize,\n  delay,\n  getBotIdFromToken,\n  hasProperty,\n  logger,\n  processReactionString,\n  urlToBase64,\n} from '@discordeno/utils'\nimport { createInvalidRequestBucket } from './invalidBucket.js'\nimport { Queue } from './queue.js'\nimport { createRoutes } from './routes.js'\nimport type { CreateRequestBodyOptions, CreateRestManagerOptions, MakeRequestOptions, RestManager, SendRequestOptions } from './types.js'\n\nexport const DISCORD_API_VERSION = 10\nexport const DISCORD_API_URL = 'https://discord.com/api'\n\nexport const AUDIT_LOG_REASON_HEADER = 'x-audit-log-reason'\nexport const RATE_LIMIT_REMAINING_HEADER = 'x-ratelimit-remaining'\nexport const RATE_LIMIT_RESET_AFTER_HEADER = 'x-ratelimit-reset-after'\nexport const RATE_LIMIT_GLOBAL_HEADER = 'x-ratelimit-global'\nexport const RATE_LIMIT_BUCKET_HEADER = 'x-ratelimit-bucket'\nexport const RATE_LIMIT_LIMIT_HEADER = 'x-ratelimit-limit'\nexport const RATE_LIMIT_SCOPE_HEADER = 'x-ratelimit-scope'\n\nexport function createRestManager(options: CreateRestManagerOptions): RestManager {\n  const applicationId = options.applicationId ? BigInt(options.applicationId) : getBotIdFromToken(options.token)\n\n  const baseUrl = options.proxy?.baseUrl ?? DISCORD_API_URL\n  // Discord error can get nested a lot, so we use a custom inspect to change the depth to Infinity\n  const baseErrorPrototype = {\n    [inspect.custom](_depth: number, options: InspectOptions, _inspect: typeof inspect) {\n      return _inspect(this, {\n        ...options,\n        depth: Infinity,\n        // Since we call inspect on ourself, we need to disable the calls to the inspect.custom symbol or else it will cause an infinite loop.\n        customInspect: false,\n      })\n    },\n  }\n\n  const rest: RestManager = {\n    applicationId,\n    authorization: options.proxy?.authorization,\n    authorizationHeader: options.proxy?.authorizationHeader ?? 'authorization',\n    baseUrl,\n    deleteQueueDelay: 60000,\n    globallyRateLimited: false,\n    invalidBucket: createInvalidRequestBucket({ logger: options.logger }),\n    isProxied: !baseUrl.startsWith(DISCORD_API_URL),\n    updateBearerTokenEndpoint: options.proxy?.updateBearerTokenEndpoint,\n    maxRetryCount: Infinity,\n    processingRateLimitedPaths: false,\n    queues: new Map(),\n    rateLimitedPaths: new Map(),\n    token: options.token,\n    version: options.version ?? DISCORD_API_VERSION,\n    logger: options.logger ?? logger,\n\n    routes: createRoutes(),\n\n    createBaseHeaders() {\n      return {\n        'user-agent': `DiscordBot (https://github.com/discordeno/discordeno, v${DISCORDENO_VERSION})`,\n      }\n    },\n\n    checkRateLimits(url, identifier) {\n      const ratelimited = rest.rateLimitedPaths.get(`${identifier}${url}`)\n\n      const global = rest.rateLimitedPaths.get('global')\n      const now = Date.now()\n\n      if (ratelimited && now < ratelimited.resetTimestamp) {\n        return ratelimited.resetTimestamp - now\n      }\n\n      if (global && now < global.resetTimestamp) {\n        return global.resetTimestamp - now\n      }\n\n      return false\n    },\n\n    async updateTokenQueues(oldToken, newToken) {\n      if (rest.isProxied) {\n        if (!rest.updateBearerTokenEndpoint) {\n          throw new Error(\n            \"The 'proxy.updateBearerTokenEndpoint' option needs to be set when using a rest proxy and needed to call 'updateTokenQueues'\",\n          )\n        }\n\n        const headers = {\n          'content-type': 'application/json',\n        } as Record<string, string>\n\n        if (rest.authorization !== undefined) {\n          headers[rest.authorizationHeader] = rest.authorization\n        }\n\n        await fetch(`${rest.baseUrl}/${rest.updateBearerTokenEndpoint}`, {\n          method: 'POST',\n          body: JSON.stringify({\n            oldToken,\n            newToken,\n          }),\n          headers,\n        })\n\n        return\n      }\n\n      const newIdentifier = `Bearer ${newToken}`\n\n      // Update all the queues\n      for (const [key, queue] of rest.queues.entries()) {\n        if (!key.startsWith(`Bearer ${oldToken}`)) continue\n\n        rest.queues.delete(key)\n        queue.identifier = newIdentifier\n\n        const newKey = `${newIdentifier}${queue.url}`\n        const newQueue = rest.queues.get(newKey)\n\n        // Merge the queues\n        if (newQueue) {\n          newQueue.waiting.unshift(...queue.waiting)\n          newQueue.pending.unshift(...queue.pending)\n\n          queue.waiting = []\n          queue.pending = []\n\n          queue.cleanup()\n        } else {\n          rest.queues.set(newKey, queue)\n        }\n      }\n\n      for (const [key, ratelimitPath] of rest.rateLimitedPaths.entries()) {\n        if (!key.startsWith(`Bearer ${oldToken}`)) continue\n\n        rest.rateLimitedPaths.set(`${newIdentifier}${ratelimitPath.url}`, ratelimitPath)\n\n        if (ratelimitPath.bucketId) {\n          rest.rateLimitedPaths.set(`${newIdentifier}${ratelimitPath.bucketId}`, ratelimitPath)\n        }\n      }\n    },\n\n    changeToDiscordFormat(obj: any): any {\n      if (obj === null) return null\n\n      if (typeof obj === 'object') {\n        if (Array.isArray(obj)) {\n          return obj.map((item) => rest.changeToDiscordFormat(item))\n        }\n\n        const newObj: any = {}\n\n        for (const key of Object.keys(obj)) {\n          const value = obj[key]\n\n          // If the key is already in snake_case we can assume it is already in the discord format.\n          if (key.includes('_')) {\n            newObj[key] = value\n            continue\n          }\n\n          // Some falsy values should be allowed like null or 0\n          if (value !== undefined) {\n            switch (key) {\n              case 'permissions':\n              case 'allow':\n              case 'deny':\n                newObj[key] = typeof value === 'string' ? value : calculateBits(value)\n                continue\n              case 'defaultMemberPermissions':\n                newObj.default_member_permissions = typeof value === 'string' ? value : calculateBits(value)\n                continue\n              case 'nameLocalizations':\n                newObj.name_localizations = value\n                continue\n              case 'descriptionLocalizations':\n                newObj.description_localizations = value\n                continue\n            }\n          }\n\n          newObj[camelToSnakeCase(key)] = rest.changeToDiscordFormat(value)\n        }\n\n        return newObj\n      }\n\n      if (typeof obj === 'bigint') return obj.toString()\n\n      return obj\n    },\n\n    createRequestBody(method, options) {\n      const headers = this.createBaseHeaders()\n\n      if (options?.unauthorized !== true) headers.authorization = `Bot ${rest.token}`\n\n      // IF A REASON IS PROVIDED ENCODE IT IN HEADERS\n      if (options?.reason !== undefined) {\n        headers[AUDIT_LOG_REASON_HEADER] = encodeURIComponent(options?.reason)\n      }\n\n      let body: string | FormData | undefined\n\n      // TODO: check if we need to add specific check for GET method\n      // Since GET does not allow bodies\n\n      // Have to check for attachments first, since body then has to be send in a different way.\n      if (options?.files !== undefined) {\n        const form = new FormData()\n        for (let i = 0; i < options.files.length; ++i) {\n          form.append(`files[${i}]`, options.files[i].blob, options.files[i].name)\n        }\n\n        // Have to use changeToDiscordFormat or else JSON.stringify may throw an error for the presence of BigInt(s) in the json\n        form.append('payload_json', JSON.stringify(rest.changeToDiscordFormat({ ...options.body, files: undefined })))\n\n        // No need to set the `content-type` header since `fetch` does that automatically for us when we use a `FormData` object.\n        body = form\n      } else if (options?.body && options.headers && options.headers['content-type'] === 'application/x-www-form-urlencoded') {\n        // OAuth2 body handling\n        const formBody: string[] = []\n\n        const discordBody = rest.changeToDiscordFormat(options.body)\n\n        for (const prop in discordBody) {\n          formBody.push(`${encodeURIComponent(prop)}=${encodeURIComponent(discordBody[prop])}`)\n        }\n\n        body = formBody.join('&')\n      } else if (options?.body !== undefined) {\n        if (options.body instanceof FormData) {\n          body = options.body\n          // No need to set the `content-type` header since `fetch` does that automatically for us when we use a `FormData` object.\n        } else {\n          body = JSON.stringify(rest.changeToDiscordFormat(options.body))\n          headers['content-type'] = `application/json`\n        }\n      }\n\n      // SOMETIMES SPECIAL HEADERS (E.G. CUSTOM AUTHORIZATION) NEED TO BE USED\n      if (options?.headers) {\n        Object.assign(headers, options.headers)\n      }\n\n      return {\n        body,\n        headers,\n        method,\n      }\n    },\n\n    processRateLimitedPaths() {\n      const now = Date.now()\n\n      for (const [key, value] of rest.rateLimitedPaths.entries()) {\n        //   rest.debug(\n        // `[REST - processRateLimitedPaths] Running for of loop. ${\n        //   value.resetTimestamp - now\n        // }`\n        //   )\n        // If the time has not reached cancel\n        if (value.resetTimestamp > now) continue\n\n        // Rate limit is over, delete the rate limiter\n        rest.rateLimitedPaths.delete(key)\n        // If it was global, also mark the global value as false\n        if (key === 'global') rest.globallyRateLimited = false\n      }\n\n      // ALL PATHS ARE CLEARED CAN CANCEL OUT!\n      if (rest.rateLimitedPaths.size === 0) {\n        rest.processingRateLimitedPaths = false\n      } else {\n        rest.processingRateLimitedPaths = true\n        // RECHECK IN 1 SECOND\n        setTimeout(() => {\n          // rest.debug('[REST - processRateLimitedPaths] Running setTimeout.')\n          rest.processRateLimitedPaths()\n        }, 1000)\n      }\n    },\n\n    /** Processes the rate limit headers and determines if it needs to be rate limited and returns the bucket id if available */\n    processHeaders(url, headers, identifier) {\n      let rateLimited = false\n\n      // GET ALL NECESSARY HEADERS\n      const remaining = headers.get(RATE_LIMIT_REMAINING_HEADER)\n      const retryAfter = headers.get(RATE_LIMIT_RESET_AFTER_HEADER)\n      const reset = Date.now() + Number(retryAfter) * 1000\n      const global = headers.get(RATE_LIMIT_GLOBAL_HEADER)\n      // undefined override null needed for typings\n      const bucketId = headers.get(RATE_LIMIT_BUCKET_HEADER) ?? undefined\n      const limit = headers.get(RATE_LIMIT_LIMIT_HEADER)\n\n      // If we didn't received the identifier, fallback to the bot token\n      identifier ??= `Bot ${rest.token}`\n\n      rest.queues.get(`${identifier}${url}`)?.handleCompletedRequest({\n        remaining: remaining ? Number(remaining) : undefined,\n        interval: retryAfter ? Number(retryAfter) * 1000 : undefined,\n        max: limit ? Number(limit) : undefined,\n      })\n\n      // IF THERE IS NO REMAINING RATE LIMIT, MARK IT AS RATE LIMITED\n      if (remaining === '0') {\n        rateLimited = true\n\n        // SAVE THE URL AS LIMITED, IMPORTANT FOR NEW REQUESTS BY USER WITHOUT BUCKET\n        rest.rateLimitedPaths.set(`${identifier}${url}`, {\n          url,\n          resetTimestamp: reset,\n          bucketId,\n        })\n\n        // SAVE THE BUCKET AS LIMITED SINCE DIFFERENT URLS MAY SHARE A BUCKET\n        if (bucketId) {\n          rest.rateLimitedPaths.set(`${identifier}${bucketId}`, {\n            url,\n            resetTimestamp: reset,\n            bucketId,\n          })\n        }\n      }\n\n      // IF THERE IS NO REMAINING GLOBAL LIMIT, MARK IT RATE LIMITED GLOBALLY\n      if (global) {\n        const retryAfter = Number(headers.get('retry-after')) * 1000\n        const globalReset = Date.now() + retryAfter\n        //   rest.debug(\n        // `[REST = Globally Rate Limited] URL: ${url} | Global Rest: ${globalReset}`\n        //   )\n        rest.globallyRateLimited = true\n        rateLimited = true\n\n        setTimeout(() => {\n          rest.globallyRateLimited = false\n        }, retryAfter)\n\n        rest.rateLimitedPaths.set('global', {\n          url: 'global',\n          resetTimestamp: globalReset,\n          bucketId,\n        })\n\n        if (bucketId) {\n          rest.rateLimitedPaths.set(identifier, {\n            url: 'global',\n            resetTimestamp: globalReset,\n            bucketId,\n          })\n        }\n      }\n\n      if (rateLimited && !rest.processingRateLimitedPaths) {\n        rest.processRateLimitedPaths()\n      }\n      return rateLimited ? bucketId : undefined\n    },\n\n    async sendRequest(options) {\n      const url = `${rest.baseUrl}/v${rest.version}${options.route}`\n      const payload = rest.createRequestBody(options.method, options.requestBodyOptions)\n\n      const loggingHeaders = { ...payload.headers }\n\n      if (payload.headers.authorization) {\n        const authorizationScheme = payload.headers.authorization?.split(' ')[0]\n        loggingHeaders.authorization = `${authorizationScheme} tokenhere`\n      }\n\n      rest.logger.debug(`sending request to ${url}`, 'with payload:', { ...payload, headers: loggingHeaders })\n      const response = await fetch(url, payload).catch(async (error) => {\n        rest.logger.error(error)\n        // Mark request and completed\n        rest.invalidBucket.handleCompletedRequest(999, false)\n        options.reject({\n          ok: false,\n          status: 999,\n          error: 'Possible network or request shape issue occurred. If this is rare, its a network glitch. If it occurs a lot something is wrong.',\n        })\n        throw error\n      })\n      rest.logger.debug(`request fetched from ${url} with status ${response.status} & ${response.statusText}`)\n\n      // Mark request and completed\n      rest.invalidBucket.handleCompletedRequest(response.status, response.headers.get(RATE_LIMIT_SCOPE_HEADER) === 'shared')\n\n      // Set the bucket id if it was available on the headers\n      const bucketId = rest.processHeaders(rest.simplifyUrl(options.route, options.method), response.headers, payload.headers.authorization)\n\n      if (bucketId) options.bucketId = bucketId\n\n      if (response.status < HttpResponseCode.Success || response.status >= HttpResponseCode.Error) {\n        rest.logger.debug(`Request to ${url} failed.`)\n\n        if (response.status !== HttpResponseCode.TooManyRequests) {\n          const body = response.headers.get('Content-Type') === 'application/json' ? ((await response.json()) as object) : await response.text()\n\n          options.reject({ ok: false, status: response.status, statusText: response.statusText, body })\n          return\n        }\n\n        // Consume the response body to avoid leaking memory\n        await response.arrayBuffer()\n\n        rest.logger.debug(`Request to ${url} was ratelimited.`)\n        // Too many attempts, get rid of request from queue.\n        if (options.retryCount >= rest.maxRetryCount) {\n          rest.logger.debug(`Request to ${url} exceeded the maximum allowed retries.`, 'with payload:', payload)\n          // rest.debug(`[REST - RetriesMaxed] ${JSON.stringify(options)}`)\n          options.reject({\n            ok: false,\n            status: response.status,\n            statusText: response.statusText,\n            error: 'The request was rate limited and it maxed out the retries limit.',\n          })\n\n          return\n        }\n\n        options.retryCount += 1\n\n        const resetAfter = response.headers.get(RATE_LIMIT_RESET_AFTER_HEADER)\n        if (resetAfter) await delay(Number(resetAfter) * 1000)\n\n        return await options.retryRequest?.(options)\n      }\n\n      // Discord sometimes sends no response with no content.\n      options.resolve({ ok: true, status: response.status, body: response.status === HttpResponseCode.NoContent ? undefined : await response.text() })\n    },\n\n    simplifyUrl(url, method) {\n      const parts = url.split('/')\n      const secondLastPart = parts[parts.length - 2]\n\n      if (secondLastPart === 'channels' || secondLastPart === 'guilds') {\n        return url\n      }\n\n      if (secondLastPart === 'reactions' || parts[parts.length - 1] === '@me') {\n        parts.splice(-2)\n        parts.push('reactions')\n      } else {\n        parts.splice(-1)\n        parts.push('x')\n      }\n\n      if (parts[parts.length - 3] === 'reactions') {\n        parts.splice(-2)\n      }\n\n      if (method === 'DELETE' && secondLastPart === 'messages') {\n        return `D${parts.join('/')}`\n      }\n\n      return parts.join('/')\n    },\n\n    async processRequest(request: SendRequestOptions) {\n      const url = rest.simplifyUrl(request.route, request.method)\n\n      if (request.runThroughQueue === false) {\n        await rest.sendRequest(request)\n\n        return\n      }\n\n      // If we the request has a token, use it\n      // Else fallback to prefix with the bot token\n      const queueIdentifier = request.requestBodyOptions?.headers?.authorization ?? `Bot ${rest.token}`\n\n      const queue = rest.queues.get(`${queueIdentifier}${url}`)\n\n      if (queue !== undefined) {\n        queue.makeRequest(request)\n      } else {\n        // CREATES A NEW QUEUE\n        const bucketQueue = new Queue(rest, { url, deleteQueueDelay: rest.deleteQueueDelay, identifier: queueIdentifier })\n\n        // Save queue\n        rest.queues.set(`${queueIdentifier}${url}`, bucketQueue)\n\n        // Add request to queue\n        bucketQueue.makeRequest(request)\n      }\n    },\n\n    async makeRequest(method, route, options) {\n      // This error needs to be created here because of how stack traces get calculated\n      const error = new Error()\n\n      if (rest.isProxied) {\n        if (rest.authorization) {\n          options ??= {}\n          options.headers ??= {}\n          options.headers[rest.authorizationHeader] = rest.authorization\n        }\n\n        const result = await fetch(`${rest.baseUrl}/v${rest.version}${route}`, rest.createRequestBody(method, options))\n\n        if (!result.ok) {\n          // Sometime the Content-Type may be \"application/json; charset=utf-8\", for this reason we need to check the start of the header\n          const body = await (result.headers.get('Content-Type')?.startsWith('application/json') ? result.json() : result.text()).catch(() => null)\n\n          error.cause = Object.assign(Object.create(baseErrorPrototype), {\n            ok: false,\n            status: result.status,\n            body,\n          })\n\n          throw error\n        }\n\n        return result.status !== 204 ? await result.json() : undefined\n      }\n\n      return await new Promise(async (resolve, reject) => {\n        const payload: SendRequestOptions = {\n          route,\n          method,\n          requestBodyOptions: options,\n          retryCount: 0,\n          retryRequest: async (payload: SendRequestOptions) => {\n            await rest.processRequest(payload)\n          },\n          resolve: (data) => {\n            resolve(data.status !== 204 ? JSON.parse(data.body ?? '{}') : undefined)\n          },\n          reject: (reason) => {\n            let errorText: string\n\n            switch (reason.status) {\n              case 400:\n                errorText = \"The options was improperly formatted, or the server couldn't understand it.\"\n                break\n              case 401:\n                errorText = 'The Authorization header was missing or invalid.'\n                break\n              case 403:\n                errorText = 'The Authorization token you passed did not have permission to the resource.'\n                break\n              case 404:\n                errorText = \"The resource at the location specified doesn't exist.\"\n                break\n              case 405:\n                errorText = 'The HTTP method used is not valid for the location specified.'\n                break\n              case 429:\n                errorText = \"You're being ratelimited.\"\n                break\n              case 502:\n                errorText = 'There was not a gateway available to process your options. Wait a bit and retry.'\n                break\n              default:\n                errorText = reason.statusText ?? 'Unknown error'\n            }\n\n            error.message = `[${reason.status}] ${errorText}`\n\n            // If discord sent us JSON, it is probably going to be an error message from which we can get and add some information about the error to the error message, the full body will be in the error.cause\n            // https://discord.com/developers/docs/reference#error-messages\n            if (typeof reason.body === 'object' && hasProperty(reason.body, 'code') && hasProperty(reason.body, 'message')) {\n              error.message += `\\nDiscord error: [${reason.body.code}] ${reason.body.message}`\n            }\n\n            error.cause = Object.assign(Object.create(baseErrorPrototype), reason)\n            reject(error)\n          },\n          runThroughQueue: options?.runThroughQueue,\n        }\n\n        await rest.processRequest(payload)\n      })\n    },\n\n    async get<T = Record<string, unknown>>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('GET', url, options)) as Camelize<T>\n    },\n\n    async post<T = Record<string, unknown>>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('POST', url, options)) as Camelize<T>\n    },\n\n    async delete(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      camelize(await rest.makeRequest('DELETE', url, options))\n    },\n\n    async patch<T = Record<string, unknown>>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('PATCH', url, options)) as Camelize<T>\n    },\n\n    async put<T = void>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('PUT', url, options)) as Camelize<T>\n    },\n\n    async addReaction(channelId, messageId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.put(rest.routes.channels.reactions.bot(channelId, messageId, reaction))\n    },\n\n    async addReactions(channelId, messageId, reactions, ordered = false) {\n      if (!ordered) {\n        await Promise.all(\n          reactions.map(async (reaction) => {\n            await rest.addReaction(channelId, messageId, reaction)\n          }),\n        )\n        return\n      }\n\n      for (const reaction of reactions) {\n        await rest.addReaction(channelId, messageId, reaction)\n      }\n    },\n\n    async addRole(guildId, userId, roleId, reason) {\n      await rest.put(rest.routes.guilds.roles.member(guildId, userId, roleId), { reason })\n    },\n\n    async addThreadMember(channelId, userId) {\n      await rest.put(rest.routes.channels.threads.user(channelId, userId))\n    },\n\n    async addDmRecipient(channelId, userId, body) {\n      await rest.put(rest.routes.channels.dmRecipient(channelId, userId), { body })\n    },\n\n    async createAutomodRule(guildId, body, reason) {\n      return await rest.post<DiscordAutoModerationRule>(rest.routes.guilds.automod.rules(guildId), { body, reason })\n    },\n\n    async createChannel(guildId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.guilds.channels(guildId), { body, reason })\n    },\n\n    async createEmoji(guildId, body, reason) {\n      return await rest.post<DiscordEmoji>(rest.routes.guilds.emojis(guildId), { body, reason })\n    },\n\n    async createApplicationEmoji(body) {\n      return await rest.post<DiscordEmoji>(rest.routes.applicationEmojis(rest.applicationId), { body })\n    },\n\n    async createGlobalApplicationCommand(body, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.post<DiscordApplicationCommand>(rest.routes.interactions.commands.commands(rest.applicationId), restOptions)\n    },\n\n    async createGuildApplicationCommand(body, guildId, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.post<DiscordApplicationCommand>(rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId), restOptions)\n    },\n\n    async createGuildSticker(guildId, options, reason) {\n      const form = new FormData()\n      form.append('file', options.file.blob, options.file.name)\n      form.append('name', options.name)\n      form.append('description', options.description)\n      form.append('tags', options.tags)\n\n      return await rest.post<DiscordSticker>(rest.routes.guilds.stickers(guildId), { body: form, reason })\n    },\n\n    async createGuildTemplate(guildId, body) {\n      return await rest.post<DiscordTemplate>(rest.routes.guilds.templates.all(guildId), { body })\n    },\n\n    async createForumThread(channelId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.forum(channelId), { body, files: body.files, reason })\n    },\n\n    async createInvite(channelId, body = {}, reason) {\n      return await rest.post<DiscordInvite>(rest.routes.channels.invites(channelId), { body, reason })\n    },\n\n    async createRole(guildId, body, reason) {\n      return await rest.post<DiscordRole>(rest.routes.guilds.roles.all(guildId), { body, reason })\n    },\n\n    async createScheduledEvent(guildId, body, reason) {\n      return await rest.post<DiscordScheduledEvent>(rest.routes.guilds.events.events(guildId), { body, reason })\n    },\n\n    async createStageInstance(body, reason) {\n      return await rest.post<DiscordStageInstance>(rest.routes.channels.stages(), { body, reason })\n    },\n\n    async createWebhook(channelId, options, reason) {\n      return await rest.post<DiscordWebhook>(rest.routes.channels.webhooks(channelId), {\n        body: {\n          name: options.name,\n          avatar: options.avatar ? await urlToBase64(options.avatar) : undefined,\n        },\n        reason,\n      })\n    },\n\n    async deleteAutomodRule(guildId, ruleId, reason) {\n      await rest.delete(rest.routes.guilds.automod.rule(guildId, ruleId), { reason })\n    },\n\n    async deleteChannel(channelId, reason) {\n      await rest.delete(rest.routes.channels.channel(channelId), {\n        reason,\n      })\n    },\n\n    async deleteChannelPermissionOverride(channelId, overwriteId, reason) {\n      await rest.delete(rest.routes.channels.overwrite(channelId, overwriteId), { reason })\n    },\n\n    async deleteEmoji(guildId, id, reason) {\n      await rest.delete(rest.routes.guilds.emoji(guildId, id), { reason })\n    },\n\n    async deleteApplicationEmoji(id) {\n      await rest.delete(rest.routes.applicationEmoji(rest.applicationId, id))\n    },\n\n    async deleteFollowupMessage(token, messageId) {\n      await rest.delete(rest.routes.interactions.responses.message(rest.applicationId, token, messageId), { unauthorized: true })\n    },\n\n    async deleteGlobalApplicationCommand(commandId) {\n      await rest.delete(rest.routes.interactions.commands.command(rest.applicationId, commandId))\n    },\n\n    async deleteGuild(guildId) {\n      await rest.delete(rest.routes.guilds.guild(guildId))\n    },\n\n    async deleteGuildApplicationCommand(commandId, guildId) {\n      await rest.delete(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId))\n    },\n\n    async deleteGuildSticker(guildId, stickerId, reason) {\n      await rest.delete(rest.routes.guilds.sticker(guildId, stickerId), { reason })\n    },\n\n    async deleteGuildTemplate(guildId, templateCode) {\n      await rest.delete(rest.routes.guilds.templates.guild(guildId, templateCode))\n    },\n\n    async deleteIntegration(guildId, integrationId, reason) {\n      await rest.delete(rest.routes.guilds.integration(guildId, integrationId), { reason })\n    },\n\n    async deleteInvite(inviteCode, reason) {\n      await rest.delete(rest.routes.guilds.invite(inviteCode), { reason })\n    },\n\n    async deleteMessage(channelId, messageId, reason) {\n      await rest.delete(rest.routes.channels.message(channelId, messageId), { reason })\n    },\n\n    async deleteMessages(channelId, messageIds, reason) {\n      await rest.post(rest.routes.channels.bulk(channelId), {\n        body: {\n          messages: messageIds.slice(0, 100).map((id) => id.toString()),\n        },\n        reason,\n      })\n    },\n\n    async deleteOriginalInteractionResponse(token) {\n      await rest.delete(rest.routes.interactions.responses.original(rest.applicationId, token), { unauthorized: true })\n    },\n\n    async deleteOwnReaction(channelId, messageId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.delete(rest.routes.channels.reactions.bot(channelId, messageId, reaction))\n    },\n\n    async deleteReactionsAll(channelId, messageId) {\n      await rest.delete(rest.routes.channels.reactions.all(channelId, messageId))\n    },\n\n    async deleteReactionsEmoji(channelId, messageId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.delete(rest.routes.channels.reactions.emoji(channelId, messageId, reaction))\n    },\n\n    async deleteRole(guildId, roleId, reason) {\n      await rest.delete(rest.routes.guilds.roles.one(guildId, roleId), { reason })\n    },\n\n    async deleteScheduledEvent(guildId, eventId) {\n      await rest.delete(rest.routes.guilds.events.event(guildId, eventId))\n    },\n\n    async deleteStageInstance(channelId, reason) {\n      await rest.delete(rest.routes.channels.stage(channelId), { reason })\n    },\n\n    async deleteUserReaction(channelId, messageId, userId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.delete(rest.routes.channels.reactions.user(channelId, messageId, reaction, userId))\n    },\n\n    async deleteWebhook(webhookId, reason) {\n      await rest.delete(rest.routes.webhooks.id(webhookId), { reason })\n    },\n\n    async deleteWebhookMessage(webhookId, token, messageId, options) {\n      await rest.delete(rest.routes.webhooks.message(webhookId, token, messageId, options), { unauthorized: true })\n    },\n\n    async deleteWebhookWithToken(webhookId, token) {\n      await rest.delete(rest.routes.webhooks.webhook(webhookId, token), {\n        unauthorized: true,\n      })\n    },\n\n    async editApplicationCommandPermissions(guildId, commandId, bearerToken, permissions) {\n      return await rest.put<DiscordGuildApplicationCommandPermissions>(\n        rest.routes.interactions.commands.permission(rest.applicationId, guildId, commandId),\n        {\n          body: {\n            permissions,\n          },\n          headers: { authorization: `Bearer ${bearerToken}` },\n        },\n      )\n    },\n\n    async editAutomodRule(guildId, ruleId, body, reason) {\n      return await rest.patch<DiscordAutoModerationRule>(rest.routes.guilds.automod.rule(guildId, ruleId), { body, reason })\n    },\n\n    async editBotProfile(options) {\n      const avatar = options?.botAvatarURL ? await urlToBase64(options?.botAvatarURL) : options?.botAvatarURL\n      const banner = options?.botBannerURL ? await urlToBase64(options?.botBannerURL) : options?.botBannerURL\n\n      return await rest.patch<DiscordUser>(rest.routes.currentUser(), {\n        body: {\n          username: options.username?.trim(),\n          avatar,\n          banner,\n        },\n      })\n    },\n\n    async editChannel(channelId, body, reason) {\n      return await rest.patch<DiscordChannel>(rest.routes.channels.channel(channelId), { body, reason })\n    },\n\n    async editChannelPermissionOverrides(channelId, body, reason) {\n      await rest.put(rest.routes.channels.overwrite(channelId, body.id), { body, reason })\n    },\n\n    async editChannelPositions(guildId, body) {\n      await rest.patch(rest.routes.guilds.channels(guildId), { body })\n    },\n\n    async editEmoji(guildId, id, body, reason) {\n      return await rest.patch<DiscordEmoji>(rest.routes.guilds.emoji(guildId, id), { body, reason })\n    },\n\n    async editApplicationEmoji(id, body) {\n      return await rest.patch<DiscordEmoji>(rest.routes.applicationEmoji(rest.applicationId, id), { body })\n    },\n\n    async editFollowupMessage(token, messageId, body) {\n      return await rest.patch<DiscordMessage>(rest.routes.interactions.responses.message(rest.applicationId, token, messageId), {\n        body,\n        files: body.files,\n        unauthorized: true,\n      })\n    },\n\n    async editGlobalApplicationCommand(commandId, body) {\n      return await rest.patch<DiscordApplicationCommand>(rest.routes.interactions.commands.command(rest.applicationId, commandId), { body })\n    },\n\n    async editGuild(guildId, body, reason) {\n      return await rest.patch<DiscordGuild>(rest.routes.guilds.guild(guildId), { body, reason })\n    },\n\n    async editGuildApplicationCommand(commandId, guildId, body) {\n      return await rest.patch<DiscordApplicationCommand>(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId), {\n        body,\n      })\n    },\n\n    async editGuildSticker(guildId, stickerId, body, reason) {\n      return await rest.patch<DiscordSticker>(rest.routes.guilds.sticker(guildId, stickerId), { body, reason })\n    },\n\n    async editGuildTemplate(guildId, templateCode: string, body: ModifyGuildTemplate): Promise<Camelize<DiscordTemplate>> {\n      return await rest.patch<DiscordTemplate>(rest.routes.guilds.templates.guild(guildId, templateCode), { body })\n    },\n\n    async editMessage(channelId, messageId, body) {\n      return await rest.patch<DiscordMessage>(rest.routes.channels.message(channelId, messageId), { body, files: body.files })\n    },\n\n    async editOriginalInteractionResponse(token, body) {\n      return await rest.patch<DiscordMessage>(rest.routes.interactions.responses.original(rest.applicationId, token), {\n        body,\n        files: body.files,\n        unauthorized: true,\n      })\n    },\n\n    async editOwnVoiceState(guildId, options) {\n      await rest.patch(rest.routes.guilds.voice(guildId), {\n        body: {\n          ...options,\n          requestToSpeakTimestamp: options.requestToSpeakTimestamp\n            ? new Date(options.requestToSpeakTimestamp).toISOString()\n            : options.requestToSpeakTimestamp,\n        },\n      })\n    },\n\n    async editScheduledEvent(guildId, eventId, body, reason) {\n      return await rest.patch<DiscordScheduledEvent>(rest.routes.guilds.events.event(guildId, eventId), { body, reason })\n    },\n\n    async editRole(guildId, roleId, body, reason) {\n      return await rest.patch<DiscordRole>(rest.routes.guilds.roles.one(guildId, roleId), { body, reason })\n    },\n\n    async editRolePositions(guildId, body, reason) {\n      return await rest.patch<DiscordRole[]>(rest.routes.guilds.roles.all(guildId), { body, reason })\n    },\n\n    async editStageInstance(channelId, topic, reason?: string) {\n      return await rest.patch<DiscordStageInstance>(rest.routes.channels.stage(channelId), { body: { topic }, reason })\n    },\n\n    async editUserVoiceState(guildId, options) {\n      await rest.patch(rest.routes.guilds.voice(guildId, options.userId), { body: options })\n    },\n\n    async editWebhook(webhookId, body, reason) {\n      return await rest.patch<DiscordWebhook>(rest.routes.webhooks.id(webhookId), { body, reason })\n    },\n\n    async editWebhookMessage(webhookId, token, messageId, options) {\n      return await rest.patch<DiscordMessage>(rest.routes.webhooks.message(webhookId, token, messageId, options), {\n        body: options,\n        files: options.files,\n        unauthorized: true,\n      })\n    },\n\n    async editWebhookWithToken(webhookId, token, body) {\n      return await rest.patch<DiscordWebhook>(rest.routes.webhooks.webhook(webhookId, token), {\n        body,\n        unauthorized: true,\n      })\n    },\n\n    async editWelcomeScreen(guildId, body, reason) {\n      return await rest.patch<DiscordWelcomeScreen>(rest.routes.guilds.welcome(guildId), { body, reason })\n    },\n\n    async editWidgetSettings(guildId, body, reason) {\n      return await rest.patch<DiscordGuildWidgetSettings>(rest.routes.guilds.widget(guildId), { body, reason })\n    },\n\n    async executeWebhook(webhookId, token, options) {\n      return await rest.post<DiscordMessage>(rest.routes.webhooks.webhook(webhookId, token, options), {\n        body: options,\n        unauthorized: true,\n      })\n    },\n\n    async followAnnouncement(sourceChannelId, targetChannelId, reason) {\n      return await rest.post<DiscordFollowedChannel>(rest.routes.channels.follow(sourceChannelId), {\n        body: {\n          webhookChannelId: targetChannelId,\n        },\n        reason,\n      })\n    },\n\n    async getActiveThreads(guildId) {\n      return await rest.get<DiscordListActiveThreads>(rest.routes.channels.threads.active(guildId))\n    },\n\n    async getApplicationCommandPermission(guildId, commandId, options) {\n      const restOptions: Omit<MakeRequestOptions, 'body'> = {}\n\n      if (options?.accessToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.accessToken}`,\n        }\n      }\n\n      return await rest.get<DiscordGuildApplicationCommandPermissions>(\n        rest.routes.interactions.commands.permission(options?.applicationId ?? rest.applicationId, guildId, commandId),\n        restOptions,\n      )\n    },\n\n    async getApplicationCommandPermissions(guildId, options) {\n      const restOptions: Omit<MakeRequestOptions, 'body'> = {}\n\n      if (options?.accessToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.accessToken}`,\n        }\n      }\n\n      return await rest.get<DiscordGuildApplicationCommandPermissions[]>(\n        rest.routes.interactions.commands.permissions(options?.applicationId ?? rest.applicationId, guildId),\n        restOptions,\n      )\n    },\n\n    async getApplicationInfo() {\n      return await rest.get<DiscordApplication>(rest.routes.oauth2.application())\n    },\n\n    async editApplicationInfo(body) {\n      return await rest.patch<DiscordApplication>(rest.routes.application(), {\n        body,\n      })\n    },\n\n    async getCurrentAuthenticationInfo(token) {\n      return await rest.get<DiscordCurrentAuthorization>(rest.routes.oauth2.currentAuthorization(), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async exchangeToken(clientId, clientSecret, body) {\n      const basicCredentials = Buffer.from(`${clientId}:${clientSecret}`)\n\n      const restOptions: MakeRequestOptions = {\n        body,\n        headers: {\n          'content-type': 'application/x-www-form-urlencoded',\n          authorization: `Basic ${basicCredentials.toString('base64')}`,\n        },\n        runThroughQueue: false,\n        unauthorized: true,\n      }\n\n      if (body.grantType === 'client_credentials') {\n        restOptions.body.scope = body.scope.join(' ')\n      }\n\n      return await rest.post<DiscordAccessTokenResponse>(rest.routes.oauth2.tokenExchange(), restOptions)\n    },\n\n    async revokeToken(clientId, clientSecret, body) {\n      const basicCredentials = Buffer.from(`${clientId}:${clientSecret}`)\n\n      await rest.post(rest.routes.oauth2.tokenRevoke(), {\n        body,\n        headers: {\n          'content-type': 'application/x-www-form-urlencoded',\n          authorization: `Basic ${basicCredentials.toString('base64')}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getAuditLog(guildId, options) {\n      return await rest.get<DiscordAuditLog>(rest.routes.guilds.auditlogs(guildId, options))\n    },\n\n    async getAutomodRule(guildId, ruleId) {\n      return await rest.get<DiscordAutoModerationRule>(rest.routes.guilds.automod.rule(guildId, ruleId))\n    },\n\n    async getAutomodRules(guildId) {\n      return await rest.get<DiscordAutoModerationRule[]>(rest.routes.guilds.automod.rules(guildId))\n    },\n\n    async getAvailableVoiceRegions() {\n      return await rest.get<DiscordVoiceRegion[]>(rest.routes.regions())\n    },\n\n    async getBan(guildId, userId) {\n      return await rest.get<DiscordBan>(rest.routes.guilds.members.ban(guildId, userId))\n    },\n\n    async getBans(guildId, options) {\n      return await rest.get<DiscordBan[]>(rest.routes.guilds.members.bans(guildId, options))\n    },\n\n    async getChannel(id) {\n      return await rest.get<DiscordChannel>(rest.routes.channels.channel(id))\n    },\n\n    async getChannelInvites(channelId) {\n      return await rest.get<DiscordInviteMetadata[]>(rest.routes.channels.invites(channelId))\n    },\n\n    async getChannels(guildId) {\n      return await rest.get<DiscordChannel[]>(rest.routes.guilds.channels(guildId))\n    },\n\n    async getChannelWebhooks(channelId) {\n      return await rest.get<DiscordWebhook[]>(rest.routes.channels.webhooks(channelId))\n    },\n\n    async getDmChannel(userId) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.dm(), {\n        body: { recipientId: userId },\n      })\n    },\n\n    async getGroupDmChannel(body) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.dm(), {\n        body,\n      })\n    },\n\n    async getEmoji(guildId, emojiId) {\n      return await rest.get<DiscordEmoji>(rest.routes.guilds.emoji(guildId, emojiId))\n    },\n\n    async getApplicationEmoji(emojiId) {\n      return await rest.get<DiscordEmoji>(rest.routes.applicationEmoji(rest.applicationId, emojiId))\n    },\n\n    async getEmojis(guildId) {\n      return await rest.get<DiscordEmoji[]>(rest.routes.guilds.emojis(guildId))\n    },\n\n    async getApplicationEmojis() {\n      return await rest.get<{ items: DiscordEmoji[] }>(rest.routes.applicationEmojis(rest.applicationId))\n    },\n\n    async getFollowupMessage(token, messageId) {\n      return await rest.get<DiscordMessage>(rest.routes.interactions.responses.message(rest.applicationId, token, messageId), { unauthorized: true })\n    },\n\n    async getGatewayBot() {\n      return await rest.get<DiscordGetGatewayBot>(rest.routes.gatewayBot())\n    },\n\n    async getGlobalApplicationCommand(commandId) {\n      return await rest.get<DiscordApplicationCommand>(rest.routes.interactions.commands.command(rest.applicationId, commandId))\n    },\n\n    async getGlobalApplicationCommands() {\n      return await rest.get<DiscordApplicationCommand[]>(rest.routes.interactions.commands.commands(rest.applicationId))\n    },\n\n    async getGuild(guildId, options = { counts: true }) {\n      return await rest.get<DiscordGuild>(rest.routes.guilds.guild(guildId, options.counts))\n    },\n\n    async getGuilds(token, options) {\n      const makeRequestOptions: MakeRequestOptions | undefined = token\n        ? {\n            headers: {\n              authorization: `Bearer ${token}`,\n            },\n            unauthorized: true,\n          }\n        : undefined\n\n      return await rest.get<Partial<DiscordGuild>[]>(rest.routes.guilds.userGuilds(options), makeRequestOptions)\n    },\n\n    async getGuildApplicationCommand(commandId, guildId) {\n      return await rest.get<DiscordApplicationCommand>(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId))\n    },\n\n    async getGuildApplicationCommands(guildId) {\n      return await rest.get<DiscordApplicationCommand[]>(rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId))\n    },\n\n    async getGuildPreview(guildId) {\n      return await rest.get<DiscordGuildPreview>(rest.routes.guilds.preview(guildId))\n    },\n\n    async getGuildTemplate(templateCode) {\n      return await rest.get<DiscordTemplate>(rest.routes.guilds.templates.code(templateCode))\n    },\n\n    async getGuildTemplates(guildId) {\n      return await rest.get<DiscordTemplate[]>(rest.routes.guilds.templates.all(guildId))\n    },\n\n    async getGuildWebhooks(guildId) {\n      return await rest.get<DiscordWebhook[]>(rest.routes.guilds.webhooks(guildId))\n    },\n\n    async getIntegrations(guildId) {\n      return await rest.get<DiscordIntegration[]>(rest.routes.guilds.integrations(guildId))\n    },\n\n    async getInvite(inviteCode, options) {\n      return await rest.get<DiscordInviteMetadata>(rest.routes.guilds.invite(inviteCode, options))\n    },\n\n    async getInvites(guildId) {\n      return await rest.get<DiscordInviteMetadata[]>(rest.routes.guilds.invites(guildId))\n    },\n\n    async getMessage(channelId, messageId) {\n      return await rest.get<DiscordMessage>(rest.routes.channels.message(channelId, messageId))\n    },\n\n    async getMessages(channelId, options) {\n      return await rest.get<DiscordMessage[]>(rest.routes.channels.messages(channelId, options))\n    },\n\n    async getStickerPack(stickerPackId) {\n      return await rest.get<DiscordStickerPack>(rest.routes.stickerPack(stickerPackId))\n    },\n\n    async getStickerPacks() {\n      return await rest.get<DiscordStickerPack[]>(rest.routes.stickerPacks())\n    },\n\n    async getOriginalInteractionResponse(token) {\n      return await rest.get<DiscordMessage>(rest.routes.interactions.responses.original(rest.applicationId, token), { unauthorized: true })\n    },\n\n    async getChannelPins(channelId, options) {\n      return await rest.get(rest.routes.channels.messagePins(channelId, options))\n    },\n\n    async getPinnedMessages(channelId) {\n      return await rest.get<DiscordMessage[]>(rest.routes.channels.pins(channelId))\n    },\n\n    async getPrivateArchivedThreads(channelId, options) {\n      return await rest.get<DiscordListArchivedThreads>(rest.routes.channels.threads.private(channelId, options))\n    },\n\n    async getPrivateJoinedArchivedThreads(channelId, options) {\n      return await rest.get<DiscordListArchivedThreads>(rest.routes.channels.threads.joined(channelId, options))\n    },\n\n    async getPruneCount(guildId, options) {\n      return await rest.get<DiscordPrunedCount>(rest.routes.guilds.prune(guildId, options))\n    },\n\n    async getPublicArchivedThreads(channelId, options) {\n      return await rest.get<DiscordListArchivedThreads>(rest.routes.channels.threads.public(channelId, options))\n    },\n\n    async getRoles(guildId) {\n      return await rest.get<DiscordRole[]>(rest.routes.guilds.roles.all(guildId))\n    },\n\n    async getRole(guildId, roleId) {\n      return await rest.get<DiscordRole>(rest.routes.guilds.roles.one(guildId, roleId))\n    },\n\n    async getScheduledEvent(guildId, eventId, options) {\n      return await rest.get<DiscordScheduledEvent>(rest.routes.guilds.events.event(guildId, eventId, options?.withUserCount))\n    },\n\n    async getScheduledEvents(guildId, options) {\n      return await rest.get<DiscordScheduledEvent[]>(rest.routes.guilds.events.events(guildId, options?.withUserCount))\n    },\n\n    async getScheduledEventUsers(guildId, eventId, options) {\n      return await rest.get<Array<{ user: DiscordUser; member?: DiscordMember }>>(rest.routes.guilds.events.users(guildId, eventId, options))\n    },\n\n    async getSessionInfo() {\n      return await rest.getGatewayBot()\n    },\n\n    async getStageInstance(channelId) {\n      return await rest.get<DiscordStageInstance>(rest.routes.channels.stage(channelId))\n    },\n\n    async getOwnVoiceState(guildId) {\n      return await rest.get<DiscordVoiceState>(rest.routes.guilds.voice(guildId))\n    },\n\n    async getUserVoiceState(guildId, userId) {\n      return await rest.get<DiscordVoiceState>(rest.routes.guilds.voice(guildId, userId))\n    },\n\n    async getSticker(stickerId: BigString) {\n      return await rest.get<DiscordSticker>(rest.routes.sticker(stickerId))\n    },\n\n    async getGuildSticker(guildId, stickerId) {\n      return await rest.get<DiscordSticker>(rest.routes.guilds.sticker(guildId, stickerId))\n    },\n\n    async getGuildStickers(guildId) {\n      return await rest.get<DiscordSticker[]>(rest.routes.guilds.stickers(guildId))\n    },\n\n    async getThreadMember(channelId, userId, options) {\n      return await rest.get<DiscordThreadMember>(rest.routes.channels.threads.getUser(channelId, userId, options))\n    },\n\n    async getThreadMembers(channelId, options) {\n      return await rest.get<DiscordThreadMember[]>(rest.routes.channels.threads.members(channelId, options))\n    },\n\n    async getReactions(channelId, messageId, reaction, options) {\n      return await rest.get<DiscordUser[]>(rest.routes.channels.reactions.message(channelId, messageId, reaction, options))\n    },\n\n    async getUser(id) {\n      return await rest.get<DiscordUser>(rest.routes.user(id))\n    },\n\n    async getCurrentUser(token) {\n      return await rest.get<DiscordUser>(rest.routes.currentUser(), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getUserConnections(token) {\n      return await rest.get<DiscordConnection[]>(rest.routes.oauth2.connections(), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getUserApplicationRoleConnection(token, applicationId) {\n      return await rest.get<DiscordApplicationRoleConnection>(rest.routes.oauth2.roleConnections(applicationId), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getVanityUrl(guildId) {\n      return await rest.get<DiscordVanityUrl>(rest.routes.guilds.vanity(guildId))\n    },\n\n    async getVoiceRegions(guildId) {\n      return await rest.get<DiscordVoiceRegion[]>(rest.routes.guilds.regions(guildId))\n    },\n\n    async getWebhook(webhookId) {\n      return await rest.get<DiscordWebhook>(rest.routes.webhooks.id(webhookId))\n    },\n\n    async getWebhookMessage(webhookId, token, messageId, options) {\n      return await rest.get<DiscordMessage>(rest.routes.webhooks.message(webhookId, token, messageId, options), {\n        unauthorized: true,\n      })\n    },\n\n    async getWebhookWithToken(webhookId, token) {\n      return await rest.get<DiscordWebhook>(rest.routes.webhooks.webhook(webhookId, token), {\n        unauthorized: true,\n      })\n    },\n\n    async getWelcomeScreen(guildId) {\n      return await rest.get<DiscordWelcomeScreen>(rest.routes.guilds.welcome(guildId))\n    },\n\n    async getWidget(guildId) {\n      return await rest.get<DiscordGuildWidget>(rest.routes.guilds.widgetJson(guildId))\n    },\n\n    async getWidgetSettings(guildId) {\n      return await rest.get<DiscordGuildWidgetSettings>(rest.routes.guilds.widget(guildId))\n    },\n\n    async joinThread(channelId) {\n      await rest.put(rest.routes.channels.threads.me(channelId))\n    },\n\n    async leaveGuild(guildId) {\n      await rest.delete(rest.routes.guilds.leave(guildId))\n    },\n\n    async leaveThread(channelId) {\n      await rest.delete(rest.routes.channels.threads.me(channelId))\n    },\n\n    async publishMessage(channelId, messageId) {\n      return await rest.post<DiscordMessage>(rest.routes.channels.crosspost(channelId, messageId))\n    },\n\n    async removeRole(guildId, userId, roleId, reason) {\n      await rest.delete(rest.routes.guilds.roles.member(guildId, userId, roleId), { reason })\n    },\n\n    async removeThreadMember(channelId, userId) {\n      await rest.delete(rest.routes.channels.threads.user(channelId, userId))\n    },\n\n    async removeDmRecipient(channelId, userId) {\n      await rest.delete(rest.routes.channels.dmRecipient(channelId, userId))\n    },\n\n    async sendFollowupMessage(token, options) {\n      return await rest.post(rest.routes.webhooks.webhook(rest.applicationId, token), {\n        body: options,\n        files: options.files,\n        unauthorized: true,\n      })\n    },\n\n    async sendInteractionResponse(interactionId, token, options, params) {\n      return await rest.post<void | DiscordInteractionCallbackResponse>(rest.routes.interactions.responses.callback(interactionId, token, params), {\n        body: options,\n        files: options.data?.files,\n        runThroughQueue: false,\n        unauthorized: true,\n      })\n    },\n\n    async sendMessage(channelId, body) {\n      return await rest.post<DiscordMessage>(rest.routes.channels.messages(channelId), { body, files: body.files })\n    },\n\n    async startThreadWithMessage(channelId, messageId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.threads.message(channelId, messageId), { body, reason })\n    },\n\n    async startThreadWithoutMessage(channelId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.threads.all(channelId), { body, reason })\n    },\n\n    async getPollAnswerVoters(channelId, messageId, answerId, options) {\n      return await rest.get<DiscordGetAnswerVotesResponse>(rest.routes.channels.polls.votes(channelId, messageId, answerId, options))\n    },\n\n    async endPoll(channelId, messageId) {\n      return await rest.post<DiscordMessage>(rest.routes.channels.polls.expire(channelId, messageId))\n    },\n\n    async syncGuildTemplate(guildId) {\n      return await rest.put<DiscordTemplate>(rest.routes.guilds.templates.all(guildId))\n    },\n\n    async banMember(guildId, userId, body, reason) {\n      await rest.put<void>(rest.routes.guilds.members.ban(guildId, userId), { body, reason })\n    },\n\n    async bulkBanMembers(guildId, options, reason) {\n      return await rest.post<DiscordBulkBan>(rest.routes.guilds.members.bulkBan(guildId), { body: options, reason })\n    },\n\n    async editBotMember(guildId, body, reason) {\n      return await rest.patch<DiscordMember>(rest.routes.guilds.members.bot(guildId), { body, reason })\n    },\n\n    async editMember(guildId, userId, body, reason) {\n      return await rest.patch<DiscordMemberWithUser>(rest.routes.guilds.members.member(guildId, userId), { body, reason })\n    },\n\n    async getMember(guildId, userId) {\n      return await rest.get<DiscordMemberWithUser>(rest.routes.guilds.members.member(guildId, userId))\n    },\n\n    async getCurrentMember(guildId, token) {\n      return await rest.get<DiscordMemberWithUser>(rest.routes.guilds.members.currentMember(guildId), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getMembers(guildId, options) {\n      return await rest.get<DiscordMemberWithUser[]>(rest.routes.guilds.members.members(guildId, options))\n    },\n\n    async getApplicationActivityInstance(applicationId, instanceId) {\n      return await rest.get<DiscordActivityInstance>(rest.routes.applicationActivityInstance(applicationId, instanceId))\n    },\n\n    async kickMember(guildId, userId, reason) {\n      await rest.delete(rest.routes.guilds.members.member(guildId, userId), {\n        reason,\n      })\n    },\n\n    async pinMessage(channelId, messageId, reason) {\n      await rest.put(rest.routes.channels.messagePin(channelId, messageId), { reason })\n    },\n\n    async pruneMembers(guildId, body, reason) {\n      return await rest.post<{ pruned: number | null }>(rest.routes.guilds.members.prune(guildId), { body, reason })\n    },\n\n    async searchMembers(guildId, query, options) {\n      return await rest.get<DiscordMemberWithUser[]>(rest.routes.guilds.members.search(guildId, query, options))\n    },\n\n    async getGuildOnboarding(guildId) {\n      return await rest.get<DiscordGuildOnboarding>(rest.routes.guilds.onboarding(guildId))\n    },\n\n    async editGuildOnboarding(guildId, options, reason) {\n      return await rest.put<DiscordGuildOnboarding>(rest.routes.guilds.onboarding(guildId), {\n        body: options,\n        reason,\n      })\n    },\n\n    async modifyGuildIncidentActions(guildId, options) {\n      return await rest.put<DiscordIncidentsData>(rest.routes.guilds.incidentActions(guildId), { body: options })\n    },\n\n    async unbanMember(guildId, userId, reason) {\n      await rest.delete(rest.routes.guilds.members.ban(guildId, userId), { reason })\n    },\n\n    async unpinMessage(channelId, messageId, reason) {\n      await rest.delete(rest.routes.channels.messagePin(channelId, messageId), { reason })\n    },\n\n    async triggerTypingIndicator(channelId) {\n      await rest.post(rest.routes.channels.typing(channelId))\n    },\n\n    async upsertGlobalApplicationCommands(body, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.put<DiscordApplicationCommand[]>(rest.routes.interactions.commands.commands(rest.applicationId), restOptions)\n    },\n\n    async upsertGuildApplicationCommands(guildId, body, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.put<DiscordApplicationCommand[]>(rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId), restOptions)\n    },\n\n    async editUserApplicationRoleConnection(token, applicationId, body) {\n      return await rest.put<DiscordApplicationRoleConnection>(rest.routes.oauth2.roleConnections(applicationId), {\n        body,\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async addGuildMember(guildId, userId, body) {\n      return await rest.put(rest.routes.guilds.members.member(guildId, userId), {\n        body,\n      })\n    },\n\n    async createTestEntitlement(applicationId, body) {\n      return await rest.post<DiscordEntitlement>(rest.routes.monetization.entitlements(applicationId), {\n        body,\n      })\n    },\n\n    async listEntitlements(applicationId, options) {\n      return await rest.get<DiscordEntitlement[]>(rest.routes.monetization.entitlements(applicationId, options))\n    },\n\n    async getEntitlement(applicationId, entitlementId) {\n      return await rest.get<DiscordEntitlement>(rest.routes.monetization.entitlement(applicationId, entitlementId))\n    },\n\n    async deleteTestEntitlement(applicationId, entitlementId) {\n      await rest.delete(rest.routes.monetization.entitlement(applicationId, entitlementId))\n    },\n\n    async consumeEntitlement(applicationId, entitlementId) {\n      await rest.post(rest.routes.monetization.consumeEntitlement(applicationId, entitlementId))\n    },\n\n    async listSkus(applicationId) {\n      return await rest.get<DiscordSku[]>(rest.routes.monetization.skus(applicationId))\n    },\n\n    async listSubscriptions(skuId, options) {\n      return await rest.get<DiscordSubscription[]>(rest.routes.monetization.subscriptions(skuId, options))\n    },\n\n    async getSubscription(skuId, subscriptionId) {\n      return await rest.get<DiscordSubscription>(rest.routes.monetization.subscription(skuId, subscriptionId))\n    },\n\n    async sendSoundboardSound(channelId, options) {\n      await rest.post(rest.routes.soundboard.sendSound(channelId), {\n        body: options,\n      })\n    },\n\n    async listDefaultSoundboardSounds() {\n      return await rest.get<DiscordSoundboardSound[]>(rest.routes.soundboard.listDefault())\n    },\n\n    async listGuildSoundboardSounds(guildId) {\n      return await rest.get<{ items: DiscordSoundboardSound[] }>(rest.routes.soundboard.guildSounds(guildId))\n    },\n\n    async getGuildSoundboardSound(guildId, soundId) {\n      return await rest.get<DiscordSoundboardSound>(rest.routes.soundboard.guildSound(guildId, soundId))\n    },\n\n    async createGuildSoundboardSound(guildId, options, reason) {\n      return await rest.post<DiscordSoundboardSound>(rest.routes.soundboard.guildSounds(guildId), {\n        body: options,\n        reason,\n      })\n    },\n\n    async modifyGuildSoundboardSound(guildId, soundId, options, reason) {\n      return await rest.post<DiscordSoundboardSound>(rest.routes.soundboard.guildSound(guildId, soundId), {\n        body: options,\n        reason,\n      })\n    },\n\n    async deleteGuildSoundboardSound(guildId, soundId, reason) {\n      return await rest.delete(rest.routes.soundboard.guildSound(guildId, soundId), {\n        reason,\n      })\n    },\n\n    async listApplicationRoleConnectionsMetadataRecords(applicationId) {\n      return await rest.get<DiscordApplicationRoleConnectionMetadata[]>(rest.routes.applicationRoleConnectionMetadata(applicationId))\n    },\n\n    async updateApplicationRoleConnectionsMetadataRecords(applicationId, options) {\n      return await rest.put<DiscordApplicationRoleConnectionMetadata[]>(rest.routes.applicationRoleConnectionMetadata(applicationId), {\n        body: options,\n      })\n    },\n\n    async createLobby(options) {\n      return await rest.post<DiscordLobby>(rest.routes.lobby.create(), {\n        body: options,\n      })\n    },\n\n    async getLobby(lobbyId) {\n      return await rest.get<DiscordLobby>(rest.routes.lobby.lobby(lobbyId))\n    },\n\n    async modifyLobby(lobbyId, options) {\n      return await rest.patch<DiscordLobby>(rest.routes.lobby.lobby(lobbyId), {\n        body: options,\n      })\n    },\n\n    async deleteLobby(lobbyId) {\n      return await rest.delete(rest.routes.lobby.lobby(lobbyId))\n    },\n\n    async addMemberToLobby(lobbyId, userId, options) {\n      return await rest.put<DiscordLobbyMember>(rest.routes.lobby.member(lobbyId, userId), {\n        body: options,\n      })\n    },\n\n    async removeMemberFromLobby(lobbyId, userId) {\n      return await rest.delete(rest.routes.lobby.member(lobbyId, userId))\n    },\n\n    async leaveLobby(lobbyId, bearerToken) {\n      return await rest.delete(rest.routes.lobby.leave(lobbyId), {\n        headers: {\n          authorization: `Bearer ${bearerToken}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async linkChannelToLobby(lobbyId, bearerToken, options) {\n      return await rest.patch<DiscordLobby>(rest.routes.lobby.link(lobbyId), {\n        body: options,\n        headers: {\n          authorization: `Bearer ${bearerToken}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async unlinkChannelToLobby(lobbyId, bearerToken) {\n      return await rest.patch<DiscordLobby>(rest.routes.lobby.link(lobbyId), {\n        headers: {\n          authorization: `Bearer ${bearerToken}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    preferSnakeCase(enabled: boolean) {\n      const camelizer = enabled ? (x: any) => x : camelize\n\n      rest.get = async (url, options) => {\n        return camelizer(await rest.makeRequest('GET', url, options))\n      }\n\n      rest.post = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        return camelizer(await rest.makeRequest('POST', url, options))\n      }\n\n      rest.delete = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        camelizer(await rest.makeRequest('DELETE', url, options))\n      }\n\n      rest.patch = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        return camelizer(await rest.makeRequest('PATCH', url, options))\n      }\n\n      rest.put = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        return camelizer(await rest.makeRequest('PUT', url, options))\n      }\n\n      return rest\n    },\n  }\n\n  return rest\n}\n\nenum HttpResponseCode {\n  /** Minimum value of a code in oder to consider that it was successful. */\n  Success = 200,\n  /** Request completed successfully, but Discord returned an empty body. */\n  NoContent = 204,\n  /** Minimum value of a code in order to consider that something went wrong. */\n  Error = 400,\n  /** This request got rate limited. */\n  TooManyRequests = 429,\n}\n"],"names":["Buffer","inspect","DISCORDENO_VERSION","calculateBits","camelToSnakeCase","camelize","delay","getBotIdFromToken","hasProperty","logger","processReactionString","urlToBase64","createInvalidRequestBucket","Queue","createRoutes","DISCORD_API_VERSION","DISCORD_API_URL","AUDIT_LOG_REASON_HEADER","RATE_LIMIT_REMAINING_HEADER","RATE_LIMIT_RESET_AFTER_HEADER","RATE_LIMIT_GLOBAL_HEADER","RATE_LIMIT_BUCKET_HEADER","RATE_LIMIT_LIMIT_HEADER","RATE_LIMIT_SCOPE_HEADER","createRestManager","options","applicationId","BigInt","token","baseUrl","proxy","baseErrorPrototype","custom","_depth","_inspect","depth","Infinity","customInspect","rest","authorization","authorizationHeader","deleteQueueDelay","globallyRateLimited","invalidBucket","isProxied","startsWith","updateBearerTokenEndpoint","maxRetryCount","processingRateLimitedPaths","queues","Map","rateLimitedPaths","version","routes","createBaseHeaders","checkRateLimits","url","identifier","ratelimited","get","global","now","Date","resetTimestamp","updateTokenQueues","oldToken","newToken","Error","headers","undefined","fetch","method","body","JSON","stringify","newIdentifier","key","queue","entries","delete","newKey","newQueue","waiting","unshift","pending","cleanup","set","ratelimitPath","bucketId","changeToDiscordFormat","obj","Array","isArray","map","item","newObj","Object","keys","value","includes","default_member_permissions","name_localizations","description_localizations","toString","createRequestBody","unauthorized","reason","encodeURIComponent","files","form","FormData","i","length","append","blob","name","formBody","discordBody","prop","push","join","assign","processRateLimitedPaths","size","setTimeout","processHeaders","rateLimited","remaining","retryAfter","reset","Number","limit","handleCompletedRequest","interval","max","globalReset","sendRequest","route","payload","requestBodyOptions","loggingHeaders","authorizationScheme","split","debug","response","catch","error","reject","ok","status","statusText","simplifyUrl","json","text","arrayBuffer","retryCount","resetAfter","retryRequest","resolve","parts","secondLastPart","splice","processRequest","request","runThroughQueue","queueIdentifier","makeRequest","bucketQueue","result","cause","create","Promise","data","parse","errorText","message","code","post","patch","put","addReaction","channelId","messageId","reaction","channels","reactions","bot","addReactions","ordered","all","addRole","guildId","userId","roleId","guilds","roles","member","addThreadMember","threads","user","addDmRecipient","dmRecipient","createAutomodRule","automod","rules","createChannel","createEmoji","emojis","createApplicationEmoji","applicationEmojis","createGlobalApplicationCommand","restOptions","bearerToken","interactions","commands","createGuildApplicationCommand","createGuildSticker","file","description","tags","stickers","createGuildTemplate","templates","createForumThread","forum","createInvite","invites","createRole","createScheduledEvent","events","createStageInstance","stages","createWebhook","webhooks","avatar","deleteAutomodRule","ruleId","rule","deleteChannel","channel","deleteChannelPermissionOverride","overwriteId","overwrite","deleteEmoji","id","emoji","deleteApplicationEmoji","applicationEmoji","deleteFollowupMessage","responses","deleteGlobalApplicationCommand","commandId","command","deleteGuild","guild","deleteGuildApplicationCommand","one","deleteGuildSticker","stickerId","sticker","deleteGuildTemplate","templateCode","deleteIntegration","integrationId","integration","deleteInvite","inviteCode","invite","deleteMessage","deleteMessages","messageIds","bulk","messages","slice","deleteOriginalInteractionResponse","original","deleteOwnReaction","deleteReactionsAll","deleteReactionsEmoji","deleteRole","deleteScheduledEvent","eventId","event","deleteStageInstance","stage","deleteUserReaction","deleteWebhook","webhookId","deleteWebhookMessage","deleteWebhookWithToken","webhook","editApplicationCommandPermissions","permissions","permission","editAutomodRule","editBotProfile","botAvatarURL","banner","botBannerURL","currentUser","username","trim","editChannel","editChannelPermissionOverrides","editChannelPositions","editEmoji","editApplicationEmoji","editFollowupMessage","editGlobalApplicationCommand","editGuild","editGuildApplicationCommand","editGuildSticker","editGuildTemplate","editMessage","editOriginalInteractionResponse","editOwnVoiceState","voice","requestToSpeakTimestamp","toISOString","editScheduledEvent","editRole","editRolePositions","editStageInstance","topic","editUserVoiceState","editWebhook","editWebhookMessage","editWebhookWithToken","editWelcomeScreen","welcome","editWidgetSettings","widget","executeWebhook","followAnnouncement","sourceChannelId","targetChannelId","follow","webhookChannelId","getActiveThreads","active","getApplicationCommandPermission","accessToken","getApplicationCommandPermissions","getApplicationInfo","oauth2","application","editApplicationInfo","getCurrentAuthenticationInfo","currentAuthorization","exchangeToken","clientId","clientSecret","basicCredentials","from","grantType","scope","tokenExchange","revokeToken","tokenRevoke","getAuditLog","auditlogs","getAutomodRule","getAutomodRules","getAvailableVoiceRegions","regions","getBan","members","ban","getBans","bans","getChannel","getChannelInvites","getChannels","getChannelWebhooks","getDmChannel","dm","recipientId","getGroupDmChannel","getEmoji","emojiId","getApplicationEmoji","getEmojis","getApplicationEmojis","getFollowupMessage","getGatewayBot","gatewayBot","getGlobalApplicationCommand","getGlobalApplicationCommands","getGuild","counts","getGuilds","makeRequestOptions","userGuilds","getGuildApplicationCommand","getGuildApplicationCommands","getGuildPreview","preview","getGuildTemplate","getGuildTemplates","getGuildWebhooks","getIntegrations","integrations","getInvite","getInvites","getMessage","getMessages","getStickerPack","stickerPackId","stickerPack","getStickerPacks","stickerPacks","getOriginalInteractionResponse","getChannelPins","messagePins","getPinnedMessages","pins","getPrivateArchivedThreads","private","getPrivateJoinedArchivedThreads","joined","getPruneCount","prune","getPublicArchivedThreads","public","getRoles","getRole","getScheduledEvent","withUserCount","getScheduledEvents","getScheduledEventUsers","users","getSessionInfo","getStageInstance","getOwnVoiceState","getUserVoiceState","getSticker","getGuildSticker","getGuildStickers","getThreadMember","getUser","getThreadMembers","getReactions","getCurrentUser","getUserConnections","connections","getUserApplicationRoleConnection","roleConnections","getVanityUrl","vanity","getVoiceRegions","getWebhook","getWebhookMessage","getWebhookWithToken","getWelcomeScreen","getWidget","widgetJson","getWidgetSettings","joinThread","me","leaveGuild","leave","leaveThread","publishMessage","crosspost","removeRole","removeThreadMember","removeDmRecipient","sendFollowupMessage","sendInteractionResponse","interactionId","params","callback","sendMessage","startThreadWithMessage","startThreadWithoutMessage","getPollAnswerVoters","answerId","polls","votes","endPoll","expire","syncGuildTemplate","banMember","bulkBanMembers","bulkBan","editBotMember","editMember","getMember","getCurrentMember","currentMember","getMembers","getApplicationActivityInstance","instanceId","applicationActivityInstance","kickMember","pinMessage","messagePin","pruneMembers","searchMembers","query","search","getGuildOnboarding","onboarding","editGuildOnboarding","modifyGuildIncidentActions","incidentActions","unbanMember","unpinMessage","triggerTypingIndicator","typing","upsertGlobalApplicationCommands","upsertGuildApplicationCommands","editUserApplicationRoleConnection","addGuildMember","createTestEntitlement","monetization","entitlements","listEntitlements","getEntitlement","entitlementId","entitlement","deleteTestEntitlement","consumeEntitlement","listSkus","skus","listSubscriptions","skuId","subscriptions","getSubscription","subscriptionId","subscription","sendSoundboardSound","soundboard","sendSound","listDefaultSoundboardSounds","listDefault","listGuildSoundboardSounds","guildSounds","getGuildSoundboardSound","soundId","guildSound","createGuildSoundboardSound","modifyGuildSoundboardSound","deleteGuildSoundboardSound","listApplicationRoleConnectionsMetadataRecords","applicationRoleConnectionMetadata","updateApplicationRoleConnectionsMetadataRecords","createLobby","lobby","getLobby","lobbyId","modifyLobby","deleteLobby","addMemberToLobby","removeMemberFromLobby","leaveLobby","linkChannelToLobby","link","unlinkChannelToLobby","preferSnakeCase","enabled","camelizer","x","HttpResponseCode"],"mappings":"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"}
|
|
1623
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/manager.ts"],"sourcesContent":["import { Buffer } from 'node:buffer'\nimport { type InspectOptions, inspect } from 'node:util'\nimport type {\n  BigString,\n  Camelize,\n  DiscordAccessTokenResponse,\n  DiscordActivityInstance,\n  DiscordApplication,\n  DiscordApplicationCommand,\n  DiscordApplicationRoleConnection,\n  DiscordApplicationRoleConnectionMetadata,\n  DiscordAuditLog,\n  DiscordAutoModerationRule,\n  DiscordBan,\n  DiscordBulkBan,\n  DiscordChannel,\n  DiscordConnection,\n  DiscordCurrentAuthorization,\n  DiscordEmoji,\n  DiscordEntitlement,\n  DiscordFollowedChannel,\n  DiscordGetAnswerVotesResponse,\n  DiscordGetGatewayBot,\n  DiscordGuild,\n  DiscordGuildApplicationCommandPermissions,\n  DiscordGuildOnboarding,\n  DiscordGuildPreview,\n  DiscordGuildWidget,\n  DiscordGuildWidgetSettings,\n  DiscordIncidentsData,\n  DiscordIntegration,\n  DiscordInteractionCallbackResponse,\n  DiscordInvite,\n  DiscordInviteMetadata,\n  DiscordListActiveThreads,\n  DiscordListArchivedThreads,\n  DiscordLobby,\n  DiscordLobbyMember,\n  DiscordMember,\n  DiscordMemberWithUser,\n  DiscordMessage,\n  DiscordPrunedCount,\n  DiscordRole,\n  DiscordScheduledEvent,\n  DiscordSku,\n  DiscordSoundboardSound,\n  DiscordStageInstance,\n  DiscordSticker,\n  DiscordStickerPack,\n  DiscordSubscription,\n  DiscordTemplate,\n  DiscordThreadMember,\n  DiscordUser,\n  DiscordVanityUrl,\n  DiscordVoiceRegion,\n  DiscordVoiceState,\n  DiscordWebhook,\n  DiscordWelcomeScreen,\n  ModifyGuildTemplate,\n} from '@discordeno/types'\nimport {\n  calculateBits,\n  camelize,\n  camelToSnakeCase,\n  DISCORDENO_VERSION,\n  delay,\n  getBotIdFromToken,\n  hasProperty,\n  logger,\n  processReactionString,\n  snowflakeToTimestamp,\n  urlToBase64,\n} from '@discordeno/utils'\nimport { createInvalidRequestBucket } from './invalidBucket.js'\nimport { Queue } from './queue.js'\nimport { createRoutes } from './routes.js'\nimport type { CreateRequestBodyOptions, CreateRestManagerOptions, MakeRequestOptions, RestManager, SendRequestOptions } from './types.js'\n\nexport const DISCORD_API_VERSION = 10\nexport const DISCORD_API_URL = 'https://discord.com/api'\n\nexport const AUDIT_LOG_REASON_HEADER = 'x-audit-log-reason'\nexport const RATE_LIMIT_REMAINING_HEADER = 'x-ratelimit-remaining'\nexport const RATE_LIMIT_RESET_AFTER_HEADER = 'x-ratelimit-reset-after'\nexport const RATE_LIMIT_GLOBAL_HEADER = 'x-ratelimit-global'\nexport const RATE_LIMIT_BUCKET_HEADER = 'x-ratelimit-bucket'\nexport const RATE_LIMIT_LIMIT_HEADER = 'x-ratelimit-limit'\nexport const RATE_LIMIT_SCOPE_HEADER = 'x-ratelimit-scope'\n\nexport function createRestManager(options: CreateRestManagerOptions): RestManager {\n  const applicationId = options.applicationId ? BigInt(options.applicationId) : getBotIdFromToken(options.token)\n\n  const baseUrl = options.proxy?.baseUrl ?? DISCORD_API_URL\n  // Discord error can get nested a lot, so we use a custom inspect to change the depth to Infinity\n  const baseErrorPrototype = {\n    [inspect.custom](_depth: number, options: InspectOptions, _inspect: typeof inspect) {\n      return _inspect(this, {\n        ...options,\n        depth: Infinity,\n        // Since we call inspect on ourself, we need to disable the calls to the inspect.custom symbol or else it will cause an infinite loop.\n        customInspect: false,\n      })\n    },\n  }\n\n  const rest: RestManager = {\n    applicationId,\n    authorization: options.proxy?.authorization,\n    authorizationHeader: options.proxy?.authorizationHeader ?? 'authorization',\n    baseUrl,\n    deleteQueueDelay: 60000,\n    globallyRateLimited: false,\n    invalidBucket: createInvalidRequestBucket({ logger: options.logger }),\n    isProxied: !baseUrl.startsWith(DISCORD_API_URL),\n    updateBearerTokenEndpoint: options.proxy?.updateBearerTokenEndpoint,\n    maxRetryCount: Infinity,\n    processingRateLimitedPaths: false,\n    queues: new Map(),\n    rateLimitedPaths: new Map(),\n    token: options.token,\n    version: options.version ?? DISCORD_API_VERSION,\n    logger: options.logger ?? logger,\n    events: {\n      request: () => {},\n      response: () => {},\n      requestError: () => {},\n      ...options.events,\n    },\n\n    routes: createRoutes(),\n\n    createBaseHeaders() {\n      return {\n        'user-agent': `DiscordBot (https://github.com/discordeno/discordeno, v${DISCORDENO_VERSION})`,\n      }\n    },\n\n    checkRateLimits(url, identifier) {\n      const ratelimited = rest.rateLimitedPaths.get(`${identifier}${url}`)\n\n      const global = rest.rateLimitedPaths.get('global')\n      const now = Date.now()\n\n      if (ratelimited && now < ratelimited.resetTimestamp) {\n        return ratelimited.resetTimestamp - now\n      }\n\n      if (global && now < global.resetTimestamp) {\n        return global.resetTimestamp - now\n      }\n\n      return false\n    },\n\n    async updateTokenQueues(oldToken, newToken) {\n      if (rest.isProxied) {\n        if (!rest.updateBearerTokenEndpoint) {\n          throw new Error(\n            \"The 'proxy.updateBearerTokenEndpoint' option needs to be set when using a rest proxy and needed to call 'updateTokenQueues'\",\n          )\n        }\n\n        const headers = {\n          'content-type': 'application/json',\n        } as Record<string, string>\n\n        if (rest.authorization !== undefined) {\n          headers[rest.authorizationHeader] = rest.authorization\n        }\n\n        await fetch(`${rest.baseUrl}/${rest.updateBearerTokenEndpoint}`, {\n          method: 'POST',\n          body: JSON.stringify({\n            oldToken,\n            newToken,\n          }),\n          headers,\n        })\n\n        return\n      }\n\n      const newIdentifier = `Bearer ${newToken}`\n\n      // Update all the queues\n      for (const [key, queue] of rest.queues.entries()) {\n        if (!key.startsWith(`Bearer ${oldToken}`)) continue\n\n        rest.queues.delete(key)\n        queue.identifier = newIdentifier\n\n        const newKey = `${newIdentifier}${queue.url}`\n        const newQueue = rest.queues.get(newKey)\n\n        // Merge the queues\n        if (newQueue) {\n          newQueue.waiting.unshift(...queue.waiting)\n          newQueue.pending.unshift(...queue.pending)\n\n          queue.waiting = []\n          queue.pending = []\n\n          queue.cleanup()\n        } else {\n          rest.queues.set(newKey, queue)\n        }\n      }\n\n      for (const [key, ratelimitPath] of rest.rateLimitedPaths.entries()) {\n        if (!key.startsWith(`Bearer ${oldToken}`)) continue\n\n        rest.rateLimitedPaths.set(`${newIdentifier}${ratelimitPath.url}`, ratelimitPath)\n\n        if (ratelimitPath.bucketId) {\n          rest.rateLimitedPaths.set(`${newIdentifier}${ratelimitPath.bucketId}`, ratelimitPath)\n        }\n      }\n    },\n\n    changeToDiscordFormat(obj: any): any {\n      if (obj === null) return null\n\n      if (typeof obj === 'object') {\n        if (Array.isArray(obj)) {\n          return obj.map((item) => rest.changeToDiscordFormat(item))\n        }\n\n        const newObj: any = {}\n\n        for (const key of Object.keys(obj)) {\n          const value = obj[key]\n\n          // If the key is already in snake_case we can assume it is already in the discord format.\n          if (key.includes('_')) {\n            newObj[key] = value\n            continue\n          }\n\n          // Some falsy values should be allowed like null or 0\n          if (value !== undefined) {\n            switch (key) {\n              case 'permissions':\n              case 'allow':\n              case 'deny':\n                newObj[key] = typeof value === 'string' ? value : calculateBits(value)\n                continue\n              case 'defaultMemberPermissions':\n                newObj.default_member_permissions = typeof value === 'string' ? value : calculateBits(value)\n                continue\n              case 'nameLocalizations':\n                newObj.name_localizations = value\n                continue\n              case 'descriptionLocalizations':\n                newObj.description_localizations = value\n                continue\n            }\n          }\n\n          newObj[camelToSnakeCase(key)] = rest.changeToDiscordFormat(value)\n        }\n\n        return newObj\n      }\n\n      if (typeof obj === 'bigint') return obj.toString()\n\n      return obj\n    },\n\n    createRequestBody(method, options) {\n      const headers = this.createBaseHeaders()\n\n      if (options?.unauthorized !== true) headers.authorization = `Bot ${rest.token}`\n\n      // IF A REASON IS PROVIDED ENCODE IT IN HEADERS\n      if (options?.reason !== undefined) {\n        headers[AUDIT_LOG_REASON_HEADER] = encodeURIComponent(options?.reason)\n      }\n\n      let body: string | FormData | undefined\n\n      // Have to check for attachments first, since body then has to be send in a different way.\n      if (options?.files !== undefined) {\n        const form = new FormData()\n        for (let i = 0; i < options.files.length; ++i) {\n          form.append(`files[${i}]`, options.files[i].blob, options.files[i].name)\n        }\n\n        // Have to use changeToDiscordFormat or else JSON.stringify may throw an error for the presence of BigInt(s) in the json\n        form.append('payload_json', JSON.stringify(rest.changeToDiscordFormat({ ...options.body, files: undefined })))\n\n        // No need to set the `content-type` header since `fetch` does that automatically for us when we use a `FormData` object.\n        body = form\n      } else if (options?.body && options.headers && options.headers['content-type'] === 'application/x-www-form-urlencoded') {\n        // OAuth2 body handling\n        const formBody: string[] = []\n\n        const discordBody = rest.changeToDiscordFormat(options.body)\n\n        for (const prop in discordBody) {\n          formBody.push(`${encodeURIComponent(prop)}=${encodeURIComponent(discordBody[prop])}`)\n        }\n\n        body = formBody.join('&')\n      } else if (options?.body !== undefined) {\n        if (options.body instanceof FormData) {\n          body = options.body\n          // No need to set the `content-type` header since `fetch` does that automatically for us when we use a `FormData` object.\n        } else {\n          body = JSON.stringify(rest.changeToDiscordFormat(options.body))\n          headers['content-type'] = `application/json`\n        }\n      }\n\n      // SOMETIMES SPECIAL HEADERS (E.G. CUSTOM AUTHORIZATION) NEED TO BE USED\n      if (options?.headers) {\n        Object.assign(headers, options.headers)\n      }\n\n      return {\n        body,\n        headers,\n        method,\n      }\n    },\n\n    processRateLimitedPaths() {\n      const now = Date.now()\n\n      for (const [key, value] of rest.rateLimitedPaths.entries()) {\n        //   rest.debug(\n        // `[REST - processRateLimitedPaths] Running for of loop. ${\n        //   value.resetTimestamp - now\n        // }`\n        //   )\n        // If the time has not reached cancel\n        if (value.resetTimestamp > now) continue\n\n        // Rate limit is over, delete the rate limiter\n        rest.rateLimitedPaths.delete(key)\n        // If it was global, also mark the global value as false\n        if (key === 'global') rest.globallyRateLimited = false\n      }\n\n      // ALL PATHS ARE CLEARED CAN CANCEL OUT!\n      if (rest.rateLimitedPaths.size === 0) {\n        rest.processingRateLimitedPaths = false\n      } else {\n        rest.processingRateLimitedPaths = true\n        // RECHECK IN 1 SECOND\n        setTimeout(() => {\n          // rest.debug('[REST - processRateLimitedPaths] Running setTimeout.')\n          rest.processRateLimitedPaths()\n        }, 1000)\n      }\n    },\n\n    /** Processes the rate limit headers and determines if it needs to be rate limited and returns the bucket id if available */\n    processHeaders(url, headers, identifier) {\n      let rateLimited = false\n\n      // GET ALL NECESSARY HEADERS\n      const remaining = headers.get(RATE_LIMIT_REMAINING_HEADER)\n      const retryAfter = headers.get(RATE_LIMIT_RESET_AFTER_HEADER)\n      const reset = Date.now() + Number(retryAfter) * 1000\n      const global = headers.get(RATE_LIMIT_GLOBAL_HEADER)\n      // undefined override null needed for typings\n      const bucketId = headers.get(RATE_LIMIT_BUCKET_HEADER) ?? undefined\n      const limit = headers.get(RATE_LIMIT_LIMIT_HEADER)\n\n      // If we didn't received the identifier, fallback to the bot token\n      identifier ??= `Bot ${rest.token}`\n\n      rest.queues.get(`${identifier}${url}`)?.handleCompletedRequest({\n        remaining: remaining ? Number(remaining) : undefined,\n        interval: retryAfter ? Number(retryAfter) * 1000 : undefined,\n        max: limit ? Number(limit) : undefined,\n      })\n\n      // IF THERE IS NO REMAINING RATE LIMIT, MARK IT AS RATE LIMITED\n      if (remaining === '0') {\n        rateLimited = true\n\n        // SAVE THE URL AS LIMITED, IMPORTANT FOR NEW REQUESTS BY USER WITHOUT BUCKET\n        rest.rateLimitedPaths.set(`${identifier}${url}`, {\n          url,\n          resetTimestamp: reset,\n          bucketId,\n        })\n\n        // SAVE THE BUCKET AS LIMITED SINCE DIFFERENT URLS MAY SHARE A BUCKET\n        if (bucketId) {\n          rest.rateLimitedPaths.set(`${identifier}${bucketId}`, {\n            url,\n            resetTimestamp: reset,\n            bucketId,\n          })\n        }\n      }\n\n      // IF THERE IS NO REMAINING GLOBAL LIMIT, MARK IT RATE LIMITED GLOBALLY\n      if (global) {\n        const retryAfter = Number(headers.get('retry-after')) * 1000\n        const globalReset = Date.now() + retryAfter\n        //   rest.debug(\n        // `[REST = Globally Rate Limited] URL: ${url} | Global Rest: ${globalReset}`\n        //   )\n        rest.globallyRateLimited = true\n        rateLimited = true\n\n        setTimeout(() => {\n          rest.globallyRateLimited = false\n        }, retryAfter)\n\n        rest.rateLimitedPaths.set('global', {\n          url: 'global',\n          resetTimestamp: globalReset,\n          bucketId,\n        })\n\n        if (bucketId) {\n          rest.rateLimitedPaths.set(identifier, {\n            url: 'global',\n            resetTimestamp: globalReset,\n            bucketId,\n          })\n        }\n      }\n\n      if (rateLimited && !rest.processingRateLimitedPaths) {\n        rest.processRateLimitedPaths()\n      }\n      return rateLimited ? bucketId : undefined\n    },\n\n    async sendRequest(options) {\n      const url = `${rest.baseUrl}/v${rest.version}${options.route}`\n      const payload = rest.createRequestBody(options.method, options.requestBodyOptions)\n\n      const loggingHeaders = { ...payload.headers }\n\n      if (payload.headers.authorization) {\n        const authorizationScheme = payload.headers.authorization?.split(' ')[0]\n        loggingHeaders.authorization = `${authorizationScheme} tokenhere`\n      }\n\n      const request = new Request(url, payload)\n      rest.events.request(request, {\n        body: options.requestBodyOptions?.body,\n      })\n\n      rest.logger.debug(`sending request to ${url}`, 'with payload:', { ...payload, headers: loggingHeaders })\n      const response = await fetch(request).catch(async (error) => {\n        rest.logger.error(error)\n        rest.events.requestError(request, error, { body: options.requestBodyOptions?.body })\n        // Mark request as completed\n        rest.invalidBucket.handleCompletedRequest(999, false)\n        options.reject({\n          ok: false,\n          status: 999,\n          error: 'Possible network or request shape issue occurred. If this is rare, its a network glitch. If it occurs a lot something is wrong.',\n        })\n        throw error\n      })\n      rest.logger.debug(`request fetched from ${url} with status ${response.status} & ${response.statusText}`)\n\n      // Sometimes the Content-Type may be \"application/json; charset=utf-8\", for this reason, we need to check the start of the header\n      const body = await (response.headers.get('Content-Type')?.startsWith('application/json') ? response.json() : response.text()).catch(() => null)\n\n      rest.events.response(request, response, {\n        requestBody: options.requestBodyOptions?.body,\n        responseBody: body,\n      })\n\n      // Mark request as completed\n      rest.invalidBucket.handleCompletedRequest(response.status, response.headers.get(RATE_LIMIT_SCOPE_HEADER) === 'shared')\n\n      // Set the bucket id if it was available on the headers\n      const bucketId = rest.processHeaders(rest.simplifyUrl(options.route, options.method), response.headers, payload.headers.authorization)\n\n      if (bucketId) options.bucketId = bucketId\n\n      if (response.status < HttpResponseCode.Success || response.status >= HttpResponseCode.Error) {\n        rest.logger.debug(`Request to ${url} failed.`)\n\n        if (response.status !== HttpResponseCode.TooManyRequests) {\n          options.reject({ ok: false, status: response.status, statusText: response.statusText, body })\n          return\n        }\n\n        rest.logger.debug(`Request to ${url} was ratelimited.`)\n        // Too many attempts, get rid of request from queue.\n        if (options.retryCount >= rest.maxRetryCount) {\n          rest.logger.debug(`Request to ${url} exceeded the maximum allowed retries.`, 'with payload:', payload)\n          // rest.debug(`[REST - RetriesMaxed] ${JSON.stringify(options)}`)\n          options.reject({\n            ok: false,\n            status: response.status,\n            statusText: response.statusText,\n            error: 'The request was rate limited and it maxed out the retries limit.',\n          })\n\n          return\n        }\n\n        options.retryCount += 1\n\n        const resetAfter = response.headers.get(RATE_LIMIT_RESET_AFTER_HEADER)\n        if (resetAfter) await delay(Number(resetAfter) * 1000)\n\n        return await options.retryRequest?.(options)\n      }\n\n      // Discord sometimes sends a response with no content\n      options.resolve({ ok: true, status: response.status, body: response.status === HttpResponseCode.NoContent ? undefined : body })\n    },\n\n    simplifyUrl(url, method) {\n      const routeInformationKey: string[] = [method]\n\n      const queryParamIndex = url.indexOf('?')\n      const route = queryParamIndex !== -1 ? url.slice(0, queryParamIndex) : url\n\n      // Since the urls start with / the first part will always be empty\n      const splittedRoute = route.split('/')\n\n      // 1) Strip the minor params\n      //    The only majors are channels, guilds, webhooks and webhooks with their token\n\n      const strippedRoute = splittedRoute\n        .map((part, index, array) => {\n          // While parseInt will truncate the snowflake id, it will still tell us if it is a number\n          const isNumber = Number.isFinite(parseInt(part, 10))\n\n          if (!isNumber) {\n            // Reactions emoji need to be stripped as it is a minor parameter\n            if (index >= 1 && array[index - 1] === 'reactions') return 'x'\n            // If we are on a webhook or if it is part of the route, keep it as it is a major parameter\n            return part\n          }\n\n          // Check if we are on a channel id, a guild id or a webhook id\n          const isMajor = index >= 1 && (array[index - 1] === 'channels' || array[index - 1] === 'guilds' || array[index - 1] === 'webhooks')\n\n          if (isMajor) return part\n\n          return 'x'\n        })\n        .join('/')\n\n      routeInformationKey.push(strippedRoute)\n\n      // 2) Account for exceptions\n      //    - https://github.com/discord/discord-api-docs/issues/1092\n      //    - https://github.com/discord/discord-api-docs/issues/1295\n\n      // The 2 exceptions are for message delete, so we need to check if we are in that route\n      if (method === 'DELETE' && splittedRoute.length === 5 && splittedRoute[1] === 'channels' && strippedRoute.endsWith('/messages/x')) {\n        const messageId = splittedRoute[4]\n        const timestamp = snowflakeToTimestamp(messageId)\n        const now = Date.now()\n\n        // https://github.com/discord/discord-api-docs/issues/1092\n        if (now - timestamp < 10_000) {\n          routeInformationKey.push('message-delete-10s')\n        }\n\n        // https://github.com/discord/discord-api-docs/issues/1295\n        // 2 weeks = 2 * 7 * 24 * 60 * 60 * 1000 = 1209600000\n        if (now - timestamp > 1209600000) {\n          routeInformationKey.push('message-delete-2w')\n        }\n      }\n\n      return routeInformationKey.join(':')\n    },\n\n    async processRequest(request: SendRequestOptions) {\n      const url = rest.simplifyUrl(request.route, request.method)\n\n      if (request.runThroughQueue === false) {\n        await rest.sendRequest(request)\n\n        return\n      }\n\n      // If we the request has a token, use it\n      // Else fallback to prefix with the bot token\n      const queueIdentifier = request.requestBodyOptions?.headers?.authorization ?? `Bot ${rest.token}`\n\n      const queue = rest.queues.get(`${queueIdentifier}${url}`)\n\n      if (queue !== undefined) {\n        queue.makeRequest(request)\n      } else {\n        // CREATES A NEW QUEUE\n        const bucketQueue = new Queue(rest, { url, deleteQueueDelay: rest.deleteQueueDelay, identifier: queueIdentifier })\n\n        // Save queue\n        rest.queues.set(`${queueIdentifier}${url}`, bucketQueue)\n\n        // Add request to queue\n        bucketQueue.makeRequest(request)\n      }\n    },\n\n    async makeRequest(method, route, options) {\n      // This error needs to be created here because of how stack traces get calculated\n      const error = new Error()\n\n      if (rest.isProxied) {\n        if (rest.authorization) {\n          options ??= {}\n          options.headers ??= {}\n          options.headers[rest.authorizationHeader] = rest.authorization\n        }\n\n        const request = new Request(`${rest.baseUrl}/v${rest.version}${route}`, rest.createRequestBody(method, options))\n        rest.events.request(request, {\n          body: options?.body,\n        })\n\n        const result = await fetch(request)\n\n        // Sometimes the Content-Type may be \"application/json; charset=utf-8\", for this reason, we need to check the start of the header\n        const body = await (result.headers.get('Content-Type')?.startsWith('application/json') ? result.json() : result.text()).catch(() => null)\n\n        rest.events.response(request, result, {\n          requestBody: options?.body,\n          responseBody: body,\n        })\n\n        if (!result.ok) {\n          error.cause = Object.assign(Object.create(baseErrorPrototype), {\n            ok: false,\n            status: result.status,\n            body,\n          })\n\n          throw error\n        }\n\n        return result.status !== 204 ? (typeof body === 'string' ? JSON.parse(body) : body) : undefined\n      }\n\n      return await new Promise(async (resolve, reject) => {\n        const payload: SendRequestOptions = {\n          route,\n          method,\n          requestBodyOptions: options,\n          retryCount: 0,\n          retryRequest: async (payload: SendRequestOptions) => {\n            await rest.processRequest(payload)\n          },\n          resolve: (data) => {\n            resolve(data.status !== 204 ? (typeof data.body === 'string' ? JSON.parse(data.body) : data.body) : undefined)\n          },\n          reject: (reason) => {\n            let errorText: string\n\n            switch (reason.status) {\n              case 400:\n                errorText = \"The options was improperly formatted, or the server couldn't understand it.\"\n                break\n              case 401:\n                errorText = 'The Authorization header was missing or invalid.'\n                break\n              case 403:\n                errorText = 'The Authorization token you passed did not have permission to the resource.'\n                break\n              case 404:\n                errorText = \"The resource at the location specified doesn't exist.\"\n                break\n              case 405:\n                errorText = 'The HTTP method used is not valid for the location specified.'\n                break\n              case 429:\n                errorText = \"You're being ratelimited.\"\n                break\n              case 502:\n                errorText = 'There was not a gateway available to process your options. Wait a bit and retry.'\n                break\n              default:\n                errorText = reason.statusText ?? 'Unknown error'\n            }\n\n            error.message = `[${reason.status}] ${errorText}`\n\n            // If discord sent us JSON, it is probably going to be an error message from which we can get and add some information about the error to the error message, the full body will be in the error.cause\n            // https://discord.com/developers/docs/reference#error-messages\n            if (typeof reason.body === 'object' && hasProperty(reason.body, 'code') && hasProperty(reason.body, 'message')) {\n              error.message += `\\nDiscord error: [${reason.body.code}] ${reason.body.message}`\n            }\n\n            error.cause = Object.assign(Object.create(baseErrorPrototype), reason)\n            reject(error)\n          },\n          runThroughQueue: options?.runThroughQueue,\n        }\n\n        await rest.processRequest(payload)\n      })\n    },\n\n    async get<T = Record<string, unknown>>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('GET', url, options)) as Camelize<T>\n    },\n\n    async post<T = Record<string, unknown>>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('POST', url, options)) as Camelize<T>\n    },\n\n    async delete(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      camelize(await rest.makeRequest('DELETE', url, options))\n    },\n\n    async patch<T = Record<string, unknown>>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('PATCH', url, options)) as Camelize<T>\n    },\n\n    async put<T = void>(url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) {\n      return camelize(await rest.makeRequest('PUT', url, options)) as Camelize<T>\n    },\n\n    async addReaction(channelId, messageId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.put(rest.routes.channels.reactions.bot(channelId, messageId, reaction))\n    },\n\n    async addReactions(channelId, messageId, reactions, ordered = false) {\n      if (!ordered) {\n        await Promise.all(\n          reactions.map(async (reaction) => {\n            await rest.addReaction(channelId, messageId, reaction)\n          }),\n        )\n        return\n      }\n\n      for (const reaction of reactions) {\n        await rest.addReaction(channelId, messageId, reaction)\n      }\n    },\n\n    async addRole(guildId, userId, roleId, reason) {\n      await rest.put(rest.routes.guilds.roles.member(guildId, userId, roleId), { reason })\n    },\n\n    async addThreadMember(channelId, userId) {\n      await rest.put(rest.routes.channels.threads.user(channelId, userId))\n    },\n\n    async addDmRecipient(channelId, userId, body) {\n      await rest.put(rest.routes.channels.dmRecipient(channelId, userId), { body })\n    },\n\n    async createAutomodRule(guildId, body, reason) {\n      return await rest.post<DiscordAutoModerationRule>(rest.routes.guilds.automod.rules(guildId), { body, reason })\n    },\n\n    async createChannel(guildId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.guilds.channels(guildId), { body, reason })\n    },\n\n    async createEmoji(guildId, body, reason) {\n      return await rest.post<DiscordEmoji>(rest.routes.guilds.emojis(guildId), { body, reason })\n    },\n\n    async createApplicationEmoji(body) {\n      return await rest.post<DiscordEmoji>(rest.routes.applicationEmojis(rest.applicationId), { body })\n    },\n\n    async createGlobalApplicationCommand(body, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.post<DiscordApplicationCommand>(rest.routes.interactions.commands.commands(rest.applicationId), restOptions)\n    },\n\n    async createGuildApplicationCommand(body, guildId, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.post<DiscordApplicationCommand>(rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId), restOptions)\n    },\n\n    async createGuildSticker(guildId, options, reason) {\n      const form = new FormData()\n      form.append('file', options.file.blob, options.file.name)\n      form.append('name', options.name)\n      form.append('description', options.description)\n      form.append('tags', options.tags)\n\n      return await rest.post<DiscordSticker>(rest.routes.guilds.stickers(guildId), { body: form, reason })\n    },\n\n    async createGuildTemplate(guildId, body) {\n      return await rest.post<DiscordTemplate>(rest.routes.guilds.templates.all(guildId), { body })\n    },\n\n    async createForumThread(channelId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.forum(channelId), { body, files: body.files, reason })\n    },\n\n    async createInvite(channelId, body = {}, reason) {\n      return await rest.post<DiscordInvite>(rest.routes.channels.invites(channelId), { body, reason })\n    },\n\n    async createRole(guildId, body, reason) {\n      return await rest.post<DiscordRole>(rest.routes.guilds.roles.all(guildId), { body, reason })\n    },\n\n    async createScheduledEvent(guildId, body, reason) {\n      return await rest.post<DiscordScheduledEvent>(rest.routes.guilds.events.events(guildId), { body, reason })\n    },\n\n    async createStageInstance(body, reason) {\n      return await rest.post<DiscordStageInstance>(rest.routes.channels.stages(), { body, reason })\n    },\n\n    async createWebhook(channelId, options, reason) {\n      return await rest.post<DiscordWebhook>(rest.routes.channels.webhooks(channelId), {\n        body: {\n          name: options.name,\n          avatar: options.avatar ? await urlToBase64(options.avatar) : undefined,\n        },\n        reason,\n      })\n    },\n\n    async deleteAutomodRule(guildId, ruleId, reason) {\n      await rest.delete(rest.routes.guilds.automod.rule(guildId, ruleId), { reason })\n    },\n\n    async deleteChannel(channelId, reason) {\n      await rest.delete(rest.routes.channels.channel(channelId), {\n        reason,\n      })\n    },\n\n    async deleteChannelPermissionOverride(channelId, overwriteId, reason) {\n      await rest.delete(rest.routes.channels.overwrite(channelId, overwriteId), { reason })\n    },\n\n    async deleteEmoji(guildId, id, reason) {\n      await rest.delete(rest.routes.guilds.emoji(guildId, id), { reason })\n    },\n\n    async deleteApplicationEmoji(id) {\n      await rest.delete(rest.routes.applicationEmoji(rest.applicationId, id))\n    },\n\n    async deleteFollowupMessage(token, messageId) {\n      await rest.delete(rest.routes.interactions.responses.message(rest.applicationId, token, messageId), { unauthorized: true })\n    },\n\n    async deleteGlobalApplicationCommand(commandId) {\n      await rest.delete(rest.routes.interactions.commands.command(rest.applicationId, commandId))\n    },\n\n    async deleteGuildApplicationCommand(commandId, guildId) {\n      await rest.delete(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId))\n    },\n\n    async deleteGuildSticker(guildId, stickerId, reason) {\n      await rest.delete(rest.routes.guilds.sticker(guildId, stickerId), { reason })\n    },\n\n    async deleteGuildTemplate(guildId, templateCode) {\n      await rest.delete(rest.routes.guilds.templates.guild(guildId, templateCode))\n    },\n\n    async deleteIntegration(guildId, integrationId, reason) {\n      await rest.delete(rest.routes.guilds.integration(guildId, integrationId), { reason })\n    },\n\n    async deleteInvite(inviteCode, reason) {\n      await rest.delete(rest.routes.guilds.invite(inviteCode), { reason })\n    },\n\n    async deleteMessage(channelId, messageId, reason) {\n      await rest.delete(rest.routes.channels.message(channelId, messageId), { reason })\n    },\n\n    async deleteMessages(channelId, messageIds, reason) {\n      await rest.post(rest.routes.channels.bulk(channelId), {\n        body: {\n          messages: messageIds.slice(0, 100).map((id) => id.toString()),\n        },\n        reason,\n      })\n    },\n\n    async deleteOriginalInteractionResponse(token) {\n      await rest.delete(rest.routes.interactions.responses.original(rest.applicationId, token), { unauthorized: true })\n    },\n\n    async deleteOwnReaction(channelId, messageId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.delete(rest.routes.channels.reactions.bot(channelId, messageId, reaction))\n    },\n\n    async deleteReactionsAll(channelId, messageId) {\n      await rest.delete(rest.routes.channels.reactions.all(channelId, messageId))\n    },\n\n    async deleteReactionsEmoji(channelId, messageId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.delete(rest.routes.channels.reactions.emoji(channelId, messageId, reaction))\n    },\n\n    async deleteRole(guildId, roleId, reason) {\n      await rest.delete(rest.routes.guilds.roles.one(guildId, roleId), { reason })\n    },\n\n    async deleteScheduledEvent(guildId, eventId) {\n      await rest.delete(rest.routes.guilds.events.event(guildId, eventId))\n    },\n\n    async deleteStageInstance(channelId, reason) {\n      await rest.delete(rest.routes.channels.stage(channelId), { reason })\n    },\n\n    async deleteUserReaction(channelId, messageId, userId, reaction) {\n      reaction = processReactionString(reaction)\n\n      await rest.delete(rest.routes.channels.reactions.user(channelId, messageId, reaction, userId))\n    },\n\n    async deleteWebhook(webhookId, reason) {\n      await rest.delete(rest.routes.webhooks.id(webhookId), { reason })\n    },\n\n    async deleteWebhookMessage(webhookId, token, messageId, options) {\n      await rest.delete(rest.routes.webhooks.message(webhookId, token, messageId, options), { unauthorized: true })\n    },\n\n    async deleteWebhookWithToken(webhookId, token) {\n      await rest.delete(rest.routes.webhooks.webhook(webhookId, token), {\n        unauthorized: true,\n      })\n    },\n\n    async editApplicationCommandPermissions(guildId, commandId, bearerToken, permissions) {\n      return await rest.put<DiscordGuildApplicationCommandPermissions>(\n        rest.routes.interactions.commands.permission(rest.applicationId, guildId, commandId),\n        {\n          body: {\n            permissions,\n          },\n          headers: { authorization: `Bearer ${bearerToken}` },\n        },\n      )\n    },\n\n    async editAutomodRule(guildId, ruleId, body, reason) {\n      return await rest.patch<DiscordAutoModerationRule>(rest.routes.guilds.automod.rule(guildId, ruleId), { body, reason })\n    },\n\n    async editBotProfile(options) {\n      const avatar = options?.botAvatarURL ? await urlToBase64(options?.botAvatarURL) : options?.botAvatarURL\n      const banner = options?.botBannerURL ? await urlToBase64(options?.botBannerURL) : options?.botBannerURL\n\n      return await rest.patch<DiscordUser>(rest.routes.currentUser(), {\n        body: {\n          username: options.username?.trim(),\n          avatar,\n          banner,\n        },\n      })\n    },\n\n    async editChannel(channelId, body, reason) {\n      return await rest.patch<DiscordChannel>(rest.routes.channels.channel(channelId), { body, reason })\n    },\n\n    async editChannelPermissionOverrides(channelId, body, reason) {\n      await rest.put(rest.routes.channels.overwrite(channelId, body.id), { body, reason })\n    },\n\n    async editChannelPositions(guildId, body) {\n      await rest.patch(rest.routes.guilds.channels(guildId), { body })\n    },\n\n    async editEmoji(guildId, id, body, reason) {\n      return await rest.patch<DiscordEmoji>(rest.routes.guilds.emoji(guildId, id), { body, reason })\n    },\n\n    async editApplicationEmoji(id, body) {\n      return await rest.patch<DiscordEmoji>(rest.routes.applicationEmoji(rest.applicationId, id), { body })\n    },\n\n    async editFollowupMessage(token, messageId, body) {\n      return await rest.patch<DiscordMessage>(rest.routes.interactions.responses.message(rest.applicationId, token, messageId), {\n        body,\n        files: body.files,\n        unauthorized: true,\n      })\n    },\n\n    async editGlobalApplicationCommand(commandId, body) {\n      return await rest.patch<DiscordApplicationCommand>(rest.routes.interactions.commands.command(rest.applicationId, commandId), { body })\n    },\n\n    async editGuild(guildId, body, reason) {\n      return await rest.patch<DiscordGuild>(rest.routes.guilds.guild(guildId), { body, reason })\n    },\n\n    async editGuildApplicationCommand(commandId, guildId, body) {\n      return await rest.patch<DiscordApplicationCommand>(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId), {\n        body,\n      })\n    },\n\n    async editGuildSticker(guildId, stickerId, body, reason) {\n      return await rest.patch<DiscordSticker>(rest.routes.guilds.sticker(guildId, stickerId), { body, reason })\n    },\n\n    async editGuildTemplate(guildId, templateCode: string, body: ModifyGuildTemplate): Promise<Camelize<DiscordTemplate>> {\n      return await rest.patch<DiscordTemplate>(rest.routes.guilds.templates.guild(guildId, templateCode), { body })\n    },\n\n    async editMessage(channelId, messageId, body) {\n      return await rest.patch<DiscordMessage>(rest.routes.channels.message(channelId, messageId), { body, files: body.files })\n    },\n\n    async editOriginalInteractionResponse(token, body) {\n      return await rest.patch<DiscordMessage>(rest.routes.interactions.responses.original(rest.applicationId, token), {\n        body,\n        files: body.files,\n        unauthorized: true,\n      })\n    },\n\n    async editOwnVoiceState(guildId, options) {\n      await rest.patch(rest.routes.guilds.voice(guildId), {\n        body: {\n          ...options,\n          requestToSpeakTimestamp: options.requestToSpeakTimestamp\n            ? new Date(options.requestToSpeakTimestamp).toISOString()\n            : options.requestToSpeakTimestamp,\n        },\n      })\n    },\n\n    async editScheduledEvent(guildId, eventId, body, reason) {\n      return await rest.patch<DiscordScheduledEvent>(rest.routes.guilds.events.event(guildId, eventId), { body, reason })\n    },\n\n    async editRole(guildId, roleId, body, reason) {\n      return await rest.patch<DiscordRole>(rest.routes.guilds.roles.one(guildId, roleId), { body, reason })\n    },\n\n    async editRolePositions(guildId, body, reason) {\n      return await rest.patch<DiscordRole[]>(rest.routes.guilds.roles.all(guildId), { body, reason })\n    },\n\n    async editStageInstance(channelId, topic, reason?: string) {\n      return await rest.patch<DiscordStageInstance>(rest.routes.channels.stage(channelId), { body: { topic }, reason })\n    },\n\n    async editUserVoiceState(guildId, options) {\n      await rest.patch(rest.routes.guilds.voice(guildId, options.userId), { body: options })\n    },\n\n    async editWebhook(webhookId, body, reason) {\n      return await rest.patch<DiscordWebhook>(rest.routes.webhooks.id(webhookId), { body, reason })\n    },\n\n    async editWebhookMessage(webhookId, token, messageId, options) {\n      return await rest.patch<DiscordMessage>(rest.routes.webhooks.message(webhookId, token, messageId, options), {\n        body: options,\n        files: options.files,\n        unauthorized: true,\n      })\n    },\n\n    async editWebhookWithToken(webhookId, token, body) {\n      return await rest.patch<DiscordWebhook>(rest.routes.webhooks.webhook(webhookId, token), {\n        body,\n        unauthorized: true,\n      })\n    },\n\n    async editWelcomeScreen(guildId, body, reason) {\n      return await rest.patch<DiscordWelcomeScreen>(rest.routes.guilds.welcome(guildId), { body, reason })\n    },\n\n    async editWidgetSettings(guildId, body, reason) {\n      return await rest.patch<DiscordGuildWidgetSettings>(rest.routes.guilds.widget(guildId), { body, reason })\n    },\n\n    async executeWebhook(webhookId, token, options) {\n      return await rest.post<DiscordMessage>(rest.routes.webhooks.webhook(webhookId, token, options), {\n        body: options,\n        unauthorized: true,\n      })\n    },\n\n    async followAnnouncement(sourceChannelId, targetChannelId, reason) {\n      return await rest.post<DiscordFollowedChannel>(rest.routes.channels.follow(sourceChannelId), {\n        body: {\n          webhookChannelId: targetChannelId,\n        },\n        reason,\n      })\n    },\n\n    async getActiveThreads(guildId) {\n      return await rest.get<DiscordListActiveThreads>(rest.routes.channels.threads.active(guildId))\n    },\n\n    async getApplicationCommandPermission(guildId, commandId, options) {\n      const restOptions: Omit<MakeRequestOptions, 'body'> = {}\n\n      if (options?.accessToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.accessToken}`,\n        }\n      }\n\n      return await rest.get<DiscordGuildApplicationCommandPermissions>(\n        rest.routes.interactions.commands.permission(options?.applicationId ?? rest.applicationId, guildId, commandId),\n        restOptions,\n      )\n    },\n\n    async getApplicationCommandPermissions(guildId, options) {\n      const restOptions: Omit<MakeRequestOptions, 'body'> = {}\n\n      if (options?.accessToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.accessToken}`,\n        }\n      }\n\n      return await rest.get<DiscordGuildApplicationCommandPermissions[]>(\n        rest.routes.interactions.commands.permissions(options?.applicationId ?? rest.applicationId, guildId),\n        restOptions,\n      )\n    },\n\n    async getApplicationInfo() {\n      return await rest.get<DiscordApplication>(rest.routes.oauth2.application())\n    },\n\n    async editApplicationInfo(body) {\n      return await rest.patch<DiscordApplication>(rest.routes.application(), {\n        body,\n      })\n    },\n\n    async getCurrentAuthenticationInfo(token) {\n      return await rest.get<DiscordCurrentAuthorization>(rest.routes.oauth2.currentAuthorization(), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async exchangeToken(clientId, clientSecret, body) {\n      const basicCredentials = Buffer.from(`${clientId}:${clientSecret}`)\n\n      const restOptions: MakeRequestOptions = {\n        body,\n        headers: {\n          'content-type': 'application/x-www-form-urlencoded',\n          authorization: `Basic ${basicCredentials.toString('base64')}`,\n        },\n        runThroughQueue: false,\n        unauthorized: true,\n      }\n\n      if (body.grantType === 'client_credentials') {\n        restOptions.body.scope = body.scope.join(' ')\n      }\n\n      return await rest.post<DiscordAccessTokenResponse>(rest.routes.oauth2.tokenExchange(), restOptions)\n    },\n\n    async revokeToken(clientId, clientSecret, body) {\n      const basicCredentials = Buffer.from(`${clientId}:${clientSecret}`)\n\n      await rest.post(rest.routes.oauth2.tokenRevoke(), {\n        body,\n        headers: {\n          'content-type': 'application/x-www-form-urlencoded',\n          authorization: `Basic ${basicCredentials.toString('base64')}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getAuditLog(guildId, options) {\n      return await rest.get<DiscordAuditLog>(rest.routes.guilds.auditlogs(guildId, options))\n    },\n\n    async getAutomodRule(guildId, ruleId) {\n      return await rest.get<DiscordAutoModerationRule>(rest.routes.guilds.automod.rule(guildId, ruleId))\n    },\n\n    async getAutomodRules(guildId) {\n      return await rest.get<DiscordAutoModerationRule[]>(rest.routes.guilds.automod.rules(guildId))\n    },\n\n    async getAvailableVoiceRegions() {\n      return await rest.get<DiscordVoiceRegion[]>(rest.routes.regions())\n    },\n\n    async getBan(guildId, userId) {\n      return await rest.get<DiscordBan>(rest.routes.guilds.members.ban(guildId, userId))\n    },\n\n    async getBans(guildId, options) {\n      return await rest.get<DiscordBan[]>(rest.routes.guilds.members.bans(guildId, options))\n    },\n\n    async getChannel(id) {\n      return await rest.get<DiscordChannel>(rest.routes.channels.channel(id))\n    },\n\n    async getChannelInvites(channelId) {\n      return await rest.get<DiscordInviteMetadata[]>(rest.routes.channels.invites(channelId))\n    },\n\n    async getChannels(guildId) {\n      return await rest.get<DiscordChannel[]>(rest.routes.guilds.channels(guildId))\n    },\n\n    async getChannelWebhooks(channelId) {\n      return await rest.get<DiscordWebhook[]>(rest.routes.channels.webhooks(channelId))\n    },\n\n    async getDmChannel(userId) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.dm(), {\n        body: { recipientId: userId },\n      })\n    },\n\n    async getGroupDmChannel(body) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.dm(), {\n        body,\n      })\n    },\n\n    async getEmoji(guildId, emojiId) {\n      return await rest.get<DiscordEmoji>(rest.routes.guilds.emoji(guildId, emojiId))\n    },\n\n    async getApplicationEmoji(emojiId) {\n      return await rest.get<DiscordEmoji>(rest.routes.applicationEmoji(rest.applicationId, emojiId))\n    },\n\n    async getEmojis(guildId) {\n      return await rest.get<DiscordEmoji[]>(rest.routes.guilds.emojis(guildId))\n    },\n\n    async getApplicationEmojis() {\n      return await rest.get<{ items: DiscordEmoji[] }>(rest.routes.applicationEmojis(rest.applicationId))\n    },\n\n    async getFollowupMessage(token, messageId) {\n      return await rest.get<DiscordMessage>(rest.routes.interactions.responses.message(rest.applicationId, token, messageId), { unauthorized: true })\n    },\n\n    async getGatewayBot() {\n      return await rest.get<DiscordGetGatewayBot>(rest.routes.gatewayBot())\n    },\n\n    async getGlobalApplicationCommand(commandId) {\n      return await rest.get<DiscordApplicationCommand>(rest.routes.interactions.commands.command(rest.applicationId, commandId))\n    },\n\n    async getGlobalApplicationCommands(options) {\n      return await rest.get<DiscordApplicationCommand[]>(rest.routes.interactions.commands.commands(rest.applicationId, options?.withLocalizations))\n    },\n\n    async getGuild(guildId, options = { counts: true }) {\n      return await rest.get<DiscordGuild>(rest.routes.guilds.guild(guildId, options.counts))\n    },\n\n    async getGuilds(token, options) {\n      const makeRequestOptions: MakeRequestOptions | undefined = token\n        ? {\n            headers: {\n              authorization: `Bearer ${token}`,\n            },\n            unauthorized: true,\n          }\n        : undefined\n\n      return await rest.get<Partial<DiscordGuild>[]>(rest.routes.guilds.userGuilds(options), makeRequestOptions)\n    },\n\n    async getGuildApplicationCommand(commandId, guildId) {\n      return await rest.get<DiscordApplicationCommand>(rest.routes.interactions.commands.guilds.one(rest.applicationId, guildId, commandId))\n    },\n\n    async getGuildApplicationCommands(guildId, options) {\n      return await rest.get<DiscordApplicationCommand[]>(\n        rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId, options?.withLocalizations),\n      )\n    },\n\n    async getGuildPreview(guildId) {\n      return await rest.get<DiscordGuildPreview>(rest.routes.guilds.preview(guildId))\n    },\n\n    async getGuildTemplate(templateCode) {\n      return await rest.get<DiscordTemplate>(rest.routes.guilds.templates.code(templateCode))\n    },\n\n    async getGuildTemplates(guildId) {\n      return await rest.get<DiscordTemplate[]>(rest.routes.guilds.templates.all(guildId))\n    },\n\n    async getGuildWebhooks(guildId) {\n      return await rest.get<DiscordWebhook[]>(rest.routes.guilds.webhooks(guildId))\n    },\n\n    async getIntegrations(guildId) {\n      return await rest.get<DiscordIntegration[]>(rest.routes.guilds.integrations(guildId))\n    },\n\n    async getInvite(inviteCode, options) {\n      return await rest.get<DiscordInviteMetadata>(rest.routes.guilds.invite(inviteCode, options))\n    },\n\n    async getInvites(guildId) {\n      return await rest.get<DiscordInviteMetadata[]>(rest.routes.guilds.invites(guildId))\n    },\n\n    async getMessage(channelId, messageId) {\n      return await rest.get<DiscordMessage>(rest.routes.channels.message(channelId, messageId))\n    },\n\n    async getMessages(channelId, options) {\n      return await rest.get<DiscordMessage[]>(rest.routes.channels.messages(channelId, options))\n    },\n\n    async getStickerPack(stickerPackId) {\n      return await rest.get<DiscordStickerPack>(rest.routes.stickerPack(stickerPackId))\n    },\n\n    async getStickerPacks() {\n      return await rest.get<DiscordStickerPack[]>(rest.routes.stickerPacks())\n    },\n\n    async getOriginalInteractionResponse(token) {\n      return await rest.get<DiscordMessage>(rest.routes.interactions.responses.original(rest.applicationId, token), { unauthorized: true })\n    },\n\n    async getChannelPins(channelId, options) {\n      return await rest.get(rest.routes.channels.messagePins(channelId, options))\n    },\n\n    async getPinnedMessages(channelId) {\n      return await rest.get<DiscordMessage[]>(rest.routes.channels.pins(channelId))\n    },\n\n    async getPrivateArchivedThreads(channelId, options) {\n      return await rest.get<DiscordListArchivedThreads>(rest.routes.channels.threads.private(channelId, options))\n    },\n\n    async getPrivateJoinedArchivedThreads(channelId, options) {\n      return await rest.get<DiscordListArchivedThreads>(rest.routes.channels.threads.joined(channelId, options))\n    },\n\n    async getPruneCount(guildId, options) {\n      return await rest.get<DiscordPrunedCount>(rest.routes.guilds.prune(guildId, options))\n    },\n\n    async getPublicArchivedThreads(channelId, options) {\n      return await rest.get<DiscordListArchivedThreads>(rest.routes.channels.threads.public(channelId, options))\n    },\n\n    async getRoles(guildId) {\n      return await rest.get<DiscordRole[]>(rest.routes.guilds.roles.all(guildId))\n    },\n\n    async getRole(guildId, roleId) {\n      return await rest.get<DiscordRole>(rest.routes.guilds.roles.one(guildId, roleId))\n    },\n\n    async getScheduledEvent(guildId, eventId, options) {\n      return await rest.get<DiscordScheduledEvent>(rest.routes.guilds.events.event(guildId, eventId, options?.withUserCount))\n    },\n\n    async getScheduledEvents(guildId, options) {\n      return await rest.get<DiscordScheduledEvent[]>(rest.routes.guilds.events.events(guildId, options?.withUserCount))\n    },\n\n    async getScheduledEventUsers(guildId, eventId, options) {\n      return await rest.get<Array<{ user: DiscordUser; member?: DiscordMember }>>(rest.routes.guilds.events.users(guildId, eventId, options))\n    },\n\n    async getSessionInfo() {\n      return await rest.getGatewayBot()\n    },\n\n    async getStageInstance(channelId) {\n      return await rest.get<DiscordStageInstance>(rest.routes.channels.stage(channelId))\n    },\n\n    async getOwnVoiceState(guildId) {\n      return await rest.get<DiscordVoiceState>(rest.routes.guilds.voice(guildId))\n    },\n\n    async getUserVoiceState(guildId, userId) {\n      return await rest.get<DiscordVoiceState>(rest.routes.guilds.voice(guildId, userId))\n    },\n\n    async getSticker(stickerId: BigString) {\n      return await rest.get<DiscordSticker>(rest.routes.sticker(stickerId))\n    },\n\n    async getGuildSticker(guildId, stickerId) {\n      return await rest.get<DiscordSticker>(rest.routes.guilds.sticker(guildId, stickerId))\n    },\n\n    async getGuildStickers(guildId) {\n      return await rest.get<DiscordSticker[]>(rest.routes.guilds.stickers(guildId))\n    },\n\n    async getThreadMember(channelId, userId, options) {\n      return await rest.get<DiscordThreadMember>(rest.routes.channels.threads.getUser(channelId, userId, options))\n    },\n\n    async getThreadMembers(channelId, options) {\n      return await rest.get<DiscordThreadMember[]>(rest.routes.channels.threads.members(channelId, options))\n    },\n\n    async getReactions(channelId, messageId, reaction, options) {\n      return await rest.get<DiscordUser[]>(rest.routes.channels.reactions.message(channelId, messageId, reaction, options))\n    },\n\n    async getUser(id) {\n      return await rest.get<DiscordUser>(rest.routes.user(id))\n    },\n\n    async getCurrentUser(token) {\n      return await rest.get<DiscordUser>(rest.routes.currentUser(), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getUserConnections(token) {\n      return await rest.get<DiscordConnection[]>(rest.routes.oauth2.connections(), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getUserApplicationRoleConnection(token, applicationId) {\n      return await rest.get<DiscordApplicationRoleConnection>(rest.routes.oauth2.roleConnections(applicationId), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getVanityUrl(guildId) {\n      return await rest.get<DiscordVanityUrl>(rest.routes.guilds.vanity(guildId))\n    },\n\n    async getVoiceRegions(guildId) {\n      return await rest.get<DiscordVoiceRegion[]>(rest.routes.guilds.regions(guildId))\n    },\n\n    async getWebhook(webhookId) {\n      return await rest.get<DiscordWebhook>(rest.routes.webhooks.id(webhookId))\n    },\n\n    async getWebhookMessage(webhookId, token, messageId, options) {\n      return await rest.get<DiscordMessage>(rest.routes.webhooks.message(webhookId, token, messageId, options), {\n        unauthorized: true,\n      })\n    },\n\n    async getWebhookWithToken(webhookId, token) {\n      return await rest.get<DiscordWebhook>(rest.routes.webhooks.webhook(webhookId, token), {\n        unauthorized: true,\n      })\n    },\n\n    async getWelcomeScreen(guildId) {\n      return await rest.get<DiscordWelcomeScreen>(rest.routes.guilds.welcome(guildId))\n    },\n\n    async getWidget(guildId) {\n      return await rest.get<DiscordGuildWidget>(rest.routes.guilds.widgetJson(guildId))\n    },\n\n    async getWidgetSettings(guildId) {\n      return await rest.get<DiscordGuildWidgetSettings>(rest.routes.guilds.widget(guildId))\n    },\n\n    async joinThread(channelId) {\n      await rest.put(rest.routes.channels.threads.me(channelId))\n    },\n\n    async leaveGuild(guildId) {\n      await rest.delete(rest.routes.guilds.leave(guildId))\n    },\n\n    async leaveThread(channelId) {\n      await rest.delete(rest.routes.channels.threads.me(channelId))\n    },\n\n    async publishMessage(channelId, messageId) {\n      return await rest.post<DiscordMessage>(rest.routes.channels.crosspost(channelId, messageId))\n    },\n\n    async removeRole(guildId, userId, roleId, reason) {\n      await rest.delete(rest.routes.guilds.roles.member(guildId, userId, roleId), { reason })\n    },\n\n    async removeThreadMember(channelId, userId) {\n      await rest.delete(rest.routes.channels.threads.user(channelId, userId))\n    },\n\n    async removeDmRecipient(channelId, userId) {\n      await rest.delete(rest.routes.channels.dmRecipient(channelId, userId))\n    },\n\n    async sendFollowupMessage(token, options) {\n      return await rest.post(rest.routes.webhooks.webhook(rest.applicationId, token), {\n        body: options,\n        files: options.files,\n        unauthorized: true,\n      })\n    },\n\n    async sendInteractionResponse(interactionId, token, options, params) {\n      return await rest.post<void | DiscordInteractionCallbackResponse>(rest.routes.interactions.responses.callback(interactionId, token, params), {\n        body: options,\n        files: options.data?.files,\n        runThroughQueue: false,\n        unauthorized: true,\n      })\n    },\n\n    async sendMessage(channelId, body) {\n      return await rest.post<DiscordMessage>(rest.routes.channels.messages(channelId), { body, files: body.files })\n    },\n\n    async startThreadWithMessage(channelId, messageId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.threads.message(channelId, messageId), { body, reason })\n    },\n\n    async startThreadWithoutMessage(channelId, body, reason) {\n      return await rest.post<DiscordChannel>(rest.routes.channels.threads.all(channelId), { body, reason })\n    },\n\n    async getPollAnswerVoters(channelId, messageId, answerId, options) {\n      return await rest.get<DiscordGetAnswerVotesResponse>(rest.routes.channels.polls.votes(channelId, messageId, answerId, options))\n    },\n\n    async endPoll(channelId, messageId) {\n      return await rest.post<DiscordMessage>(rest.routes.channels.polls.expire(channelId, messageId))\n    },\n\n    async syncGuildTemplate(guildId) {\n      return await rest.put<DiscordTemplate>(rest.routes.guilds.templates.all(guildId))\n    },\n\n    async banMember(guildId, userId, body, reason) {\n      await rest.put<void>(rest.routes.guilds.members.ban(guildId, userId), { body, reason })\n    },\n\n    async bulkBanMembers(guildId, options, reason) {\n      return await rest.post<DiscordBulkBan>(rest.routes.guilds.members.bulkBan(guildId), { body: options, reason })\n    },\n\n    async editBotMember(guildId, body, reason) {\n      return await rest.patch<DiscordMember>(rest.routes.guilds.members.bot(guildId), { body, reason })\n    },\n\n    async editMember(guildId, userId, body, reason) {\n      return await rest.patch<DiscordMemberWithUser>(rest.routes.guilds.members.member(guildId, userId), { body, reason })\n    },\n\n    async getMember(guildId, userId) {\n      return await rest.get<DiscordMemberWithUser>(rest.routes.guilds.members.member(guildId, userId))\n    },\n\n    async getCurrentMember(guildId, token) {\n      return await rest.get<DiscordMemberWithUser>(rest.routes.guilds.members.currentMember(guildId), {\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async getMembers(guildId, options) {\n      return await rest.get<DiscordMemberWithUser[]>(rest.routes.guilds.members.members(guildId, options))\n    },\n\n    async getApplicationActivityInstance(applicationId, instanceId) {\n      return await rest.get<DiscordActivityInstance>(rest.routes.applicationActivityInstance(applicationId, instanceId))\n    },\n\n    async kickMember(guildId, userId, reason) {\n      await rest.delete(rest.routes.guilds.members.member(guildId, userId), {\n        reason,\n      })\n    },\n\n    async pinMessage(channelId, messageId, reason) {\n      await rest.put(rest.routes.channels.messagePin(channelId, messageId), { reason })\n    },\n\n    async pruneMembers(guildId, body, reason) {\n      return await rest.post<{ pruned: number | null }>(rest.routes.guilds.members.prune(guildId), { body, reason })\n    },\n\n    async searchMembers(guildId, query, options) {\n      return await rest.get<DiscordMemberWithUser[]>(rest.routes.guilds.members.search(guildId, query, options))\n    },\n\n    async getGuildOnboarding(guildId) {\n      return await rest.get<DiscordGuildOnboarding>(rest.routes.guilds.onboarding(guildId))\n    },\n\n    async editGuildOnboarding(guildId, options, reason) {\n      return await rest.put<DiscordGuildOnboarding>(rest.routes.guilds.onboarding(guildId), {\n        body: options,\n        reason,\n      })\n    },\n\n    async modifyGuildIncidentActions(guildId, options) {\n      return await rest.put<DiscordIncidentsData>(rest.routes.guilds.incidentActions(guildId), { body: options })\n    },\n\n    async unbanMember(guildId, userId, reason) {\n      await rest.delete(rest.routes.guilds.members.ban(guildId, userId), { reason })\n    },\n\n    async unpinMessage(channelId, messageId, reason) {\n      await rest.delete(rest.routes.channels.messagePin(channelId, messageId), { reason })\n    },\n\n    async triggerTypingIndicator(channelId) {\n      await rest.post(rest.routes.channels.typing(channelId))\n    },\n\n    async upsertGlobalApplicationCommands(body, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.put<DiscordApplicationCommand[]>(rest.routes.interactions.commands.commands(rest.applicationId), restOptions)\n    },\n\n    async upsertGuildApplicationCommands(guildId, body, options) {\n      const restOptions: MakeRequestOptions = { body }\n\n      if (options?.bearerToken) {\n        restOptions.unauthorized = true\n        restOptions.headers = {\n          authorization: `Bearer ${options.bearerToken}`,\n        }\n      }\n\n      return await rest.put<DiscordApplicationCommand[]>(rest.routes.interactions.commands.guilds.all(rest.applicationId, guildId), restOptions)\n    },\n\n    async editUserApplicationRoleConnection(token, applicationId, body) {\n      return await rest.put<DiscordApplicationRoleConnection>(rest.routes.oauth2.roleConnections(applicationId), {\n        body,\n        headers: {\n          authorization: `Bearer ${token}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async addGuildMember(guildId, userId, body) {\n      return await rest.put(rest.routes.guilds.members.member(guildId, userId), {\n        body,\n      })\n    },\n\n    async createTestEntitlement(applicationId, body) {\n      return await rest.post<DiscordEntitlement>(rest.routes.monetization.entitlements(applicationId), {\n        body,\n      })\n    },\n\n    async listEntitlements(applicationId, options) {\n      return await rest.get<DiscordEntitlement[]>(rest.routes.monetization.entitlements(applicationId, options))\n    },\n\n    async getEntitlement(applicationId, entitlementId) {\n      return await rest.get<DiscordEntitlement>(rest.routes.monetization.entitlement(applicationId, entitlementId))\n    },\n\n    async deleteTestEntitlement(applicationId, entitlementId) {\n      await rest.delete(rest.routes.monetization.entitlement(applicationId, entitlementId))\n    },\n\n    async consumeEntitlement(applicationId, entitlementId) {\n      await rest.post(rest.routes.monetization.consumeEntitlement(applicationId, entitlementId))\n    },\n\n    async listSkus(applicationId) {\n      return await rest.get<DiscordSku[]>(rest.routes.monetization.skus(applicationId))\n    },\n\n    async listSubscriptions(skuId, options) {\n      return await rest.get<DiscordSubscription[]>(rest.routes.monetization.subscriptions(skuId, options))\n    },\n\n    async getSubscription(skuId, subscriptionId) {\n      return await rest.get<DiscordSubscription>(rest.routes.monetization.subscription(skuId, subscriptionId))\n    },\n\n    async sendSoundboardSound(channelId, options) {\n      await rest.post(rest.routes.soundboard.sendSound(channelId), {\n        body: options,\n      })\n    },\n\n    async listDefaultSoundboardSounds() {\n      return await rest.get<DiscordSoundboardSound[]>(rest.routes.soundboard.listDefault())\n    },\n\n    async listGuildSoundboardSounds(guildId) {\n      return await rest.get<{ items: DiscordSoundboardSound[] }>(rest.routes.soundboard.guildSounds(guildId))\n    },\n\n    async getGuildSoundboardSound(guildId, soundId) {\n      return await rest.get<DiscordSoundboardSound>(rest.routes.soundboard.guildSound(guildId, soundId))\n    },\n\n    async createGuildSoundboardSound(guildId, options, reason) {\n      return await rest.post<DiscordSoundboardSound>(rest.routes.soundboard.guildSounds(guildId), {\n        body: options,\n        reason,\n      })\n    },\n\n    async modifyGuildSoundboardSound(guildId, soundId, options, reason) {\n      return await rest.post<DiscordSoundboardSound>(rest.routes.soundboard.guildSound(guildId, soundId), {\n        body: options,\n        reason,\n      })\n    },\n\n    async deleteGuildSoundboardSound(guildId, soundId, reason) {\n      return await rest.delete(rest.routes.soundboard.guildSound(guildId, soundId), {\n        reason,\n      })\n    },\n\n    async listApplicationRoleConnectionsMetadataRecords(applicationId) {\n      return await rest.get<DiscordApplicationRoleConnectionMetadata[]>(rest.routes.applicationRoleConnectionMetadata(applicationId))\n    },\n\n    async updateApplicationRoleConnectionsMetadataRecords(applicationId, options) {\n      return await rest.put<DiscordApplicationRoleConnectionMetadata[]>(rest.routes.applicationRoleConnectionMetadata(applicationId), {\n        body: options,\n      })\n    },\n\n    async createLobby(options) {\n      return await rest.post<DiscordLobby>(rest.routes.lobby.create(), {\n        body: options,\n      })\n    },\n\n    async getLobby(lobbyId) {\n      return await rest.get<DiscordLobby>(rest.routes.lobby.lobby(lobbyId))\n    },\n\n    async modifyLobby(lobbyId, options) {\n      return await rest.patch<DiscordLobby>(rest.routes.lobby.lobby(lobbyId), {\n        body: options,\n      })\n    },\n\n    async deleteLobby(lobbyId) {\n      return await rest.delete(rest.routes.lobby.lobby(lobbyId))\n    },\n\n    async addMemberToLobby(lobbyId, userId, options) {\n      return await rest.put<DiscordLobbyMember>(rest.routes.lobby.member(lobbyId, userId), {\n        body: options,\n      })\n    },\n\n    async removeMemberFromLobby(lobbyId, userId) {\n      return await rest.delete(rest.routes.lobby.member(lobbyId, userId))\n    },\n\n    async leaveLobby(lobbyId, bearerToken) {\n      return await rest.delete(rest.routes.lobby.leave(lobbyId), {\n        headers: {\n          authorization: `Bearer ${bearerToken}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async linkChannelToLobby(lobbyId, bearerToken, options) {\n      return await rest.patch<DiscordLobby>(rest.routes.lobby.link(lobbyId), {\n        body: options,\n        headers: {\n          authorization: `Bearer ${bearerToken}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    async unlinkChannelToLobby(lobbyId, bearerToken) {\n      return await rest.patch<DiscordLobby>(rest.routes.lobby.link(lobbyId), {\n        headers: {\n          authorization: `Bearer ${bearerToken}`,\n        },\n        unauthorized: true,\n      })\n    },\n\n    preferSnakeCase(enabled: boolean) {\n      const camelizer = enabled ? (x: any) => x : camelize\n\n      rest.get = async (url, options) => {\n        return camelizer(await rest.makeRequest('GET', url, options))\n      }\n\n      rest.post = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        return camelizer(await rest.makeRequest('POST', url, options))\n      }\n\n      rest.delete = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        camelizer(await rest.makeRequest('DELETE', url, options))\n      }\n\n      rest.patch = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        return camelizer(await rest.makeRequest('PATCH', url, options))\n      }\n\n      rest.put = async (url: string, options?: Omit<CreateRequestBodyOptions, 'body' | 'method'>) => {\n        return camelizer(await rest.makeRequest('PUT', url, options))\n      }\n\n      return rest\n    },\n  }\n\n  return rest\n}\n\nenum HttpResponseCode {\n  /** Minimum value of a code in oder to consider that it was successful. */\n  Success = 200,\n  /** Request completed successfully, but Discord returned an empty body. */\n  NoContent = 204,\n  /** Minimum value of a code in order to consider that something went wrong. */\n  Error = 400,\n  /** This request got rate limited. */\n  TooManyRequests = 429,\n}\n"],"names":["Buffer","inspect","calculateBits","camelize","camelToSnakeCase","DISCORDENO_VERSION","delay","getBotIdFromToken","hasProperty","logger","processReactionString","snowflakeToTimestamp","urlToBase64","createInvalidRequestBucket","Queue","createRoutes","DISCORD_API_VERSION","DISCORD_API_URL","AUDIT_LOG_REASON_HEADER","RATE_LIMIT_REMAINING_HEADER","RATE_LIMIT_RESET_AFTER_HEADER","RATE_LIMIT_GLOBAL_HEADER","RATE_LIMIT_BUCKET_HEADER","RATE_LIMIT_LIMIT_HEADER","RATE_LIMIT_SCOPE_HEADER","createRestManager","options","applicationId","BigInt","token","baseUrl","proxy","baseErrorPrototype","custom","_depth","_inspect","depth","Infinity","customInspect","rest","authorization","authorizationHeader","deleteQueueDelay","globallyRateLimited","invalidBucket","isProxied","startsWith","updateBearerTokenEndpoint","maxRetryCount","processingRateLimitedPaths","queues","Map","rateLimitedPaths","version","events","request","response","requestError","routes","createBaseHeaders","checkRateLimits","url","identifier","ratelimited","get","global","now","Date","resetTimestamp","updateTokenQueues","oldToken","newToken","Error","headers","undefined","fetch","method","body","JSON","stringify","newIdentifier","key","queue","entries","delete","newKey","newQueue","waiting","unshift","pending","cleanup","set","ratelimitPath","bucketId","changeToDiscordFormat","obj","Array","isArray","map","item","newObj","Object","keys","value","includes","default_member_permissions","name_localizations","description_localizations","toString","createRequestBody","unauthorized","reason","encodeURIComponent","files","form","FormData","i","length","append","blob","name","formBody","discordBody","prop","push","join","assign","processRateLimitedPaths","size","setTimeout","processHeaders","rateLimited","remaining","retryAfter","reset","Number","limit","handleCompletedRequest","interval","max","globalReset","sendRequest","route","payload","requestBodyOptions","loggingHeaders","authorizationScheme","split","Request","debug","catch","error","reject","ok","status","statusText","json","text","requestBody","responseBody","simplifyUrl","retryCount","resetAfter","retryRequest","resolve","routeInformationKey","queryParamIndex","indexOf","slice","splittedRoute","strippedRoute","part","index","array","isNumber","isFinite","parseInt","isMajor","endsWith","messageId","timestamp","processRequest","runThroughQueue","queueIdentifier","makeRequest","bucketQueue","result","cause","create","parse","Promise","data","errorText","message","code","post","patch","put","addReaction","channelId","reaction","channels","reactions","bot","addReactions","ordered","all","addRole","guildId","userId","roleId","guilds","roles","member","addThreadMember","threads","user","addDmRecipient","dmRecipient","createAutomodRule","automod","rules","createChannel","createEmoji","emojis","createApplicationEmoji","applicationEmojis","createGlobalApplicationCommand","restOptions","bearerToken","interactions","commands","createGuildApplicationCommand","createGuildSticker","file","description","tags","stickers","createGuildTemplate","templates","createForumThread","forum","createInvite","invites","createRole","createScheduledEvent","createStageInstance","stages","createWebhook","webhooks","avatar","deleteAutomodRule","ruleId","rule","deleteChannel","channel","deleteChannelPermissionOverride","overwriteId","overwrite","deleteEmoji","id","emoji","deleteApplicationEmoji","applicationEmoji","deleteFollowupMessage","responses","deleteGlobalApplicationCommand","commandId","command","deleteGuildApplicationCommand","one","deleteGuildSticker","stickerId","sticker","deleteGuildTemplate","templateCode","guild","deleteIntegration","integrationId","integration","deleteInvite","inviteCode","invite","deleteMessage","deleteMessages","messageIds","bulk","messages","deleteOriginalInteractionResponse","original","deleteOwnReaction","deleteReactionsAll","deleteReactionsEmoji","deleteRole","deleteScheduledEvent","eventId","event","deleteStageInstance","stage","deleteUserReaction","deleteWebhook","webhookId","deleteWebhookMessage","deleteWebhookWithToken","webhook","editApplicationCommandPermissions","permissions","permission","editAutomodRule","editBotProfile","botAvatarURL","banner","botBannerURL","currentUser","username","trim","editChannel","editChannelPermissionOverrides","editChannelPositions","editEmoji","editApplicationEmoji","editFollowupMessage","editGlobalApplicationCommand","editGuild","editGuildApplicationCommand","editGuildSticker","editGuildTemplate","editMessage","editOriginalInteractionResponse","editOwnVoiceState","voice","requestToSpeakTimestamp","toISOString","editScheduledEvent","editRole","editRolePositions","editStageInstance","topic","editUserVoiceState","editWebhook","editWebhookMessage","editWebhookWithToken","editWelcomeScreen","welcome","editWidgetSettings","widget","executeWebhook","followAnnouncement","sourceChannelId","targetChannelId","follow","webhookChannelId","getActiveThreads","active","getApplicationCommandPermission","accessToken","getApplicationCommandPermissions","getApplicationInfo","oauth2","application","editApplicationInfo","getCurrentAuthenticationInfo","currentAuthorization","exchangeToken","clientId","clientSecret","basicCredentials","from","grantType","scope","tokenExchange","revokeToken","tokenRevoke","getAuditLog","auditlogs","getAutomodRule","getAutomodRules","getAvailableVoiceRegions","regions","getBan","members","ban","getBans","bans","getChannel","getChannelInvites","getChannels","getChannelWebhooks","getDmChannel","dm","recipientId","getGroupDmChannel","getEmoji","emojiId","getApplicationEmoji","getEmojis","getApplicationEmojis","getFollowupMessage","getGatewayBot","gatewayBot","getGlobalApplicationCommand","getGlobalApplicationCommands","withLocalizations","getGuild","counts","getGuilds","makeRequestOptions","userGuilds","getGuildApplicationCommand","getGuildApplicationCommands","getGuildPreview","preview","getGuildTemplate","getGuildTemplates","getGuildWebhooks","getIntegrations","integrations","getInvite","getInvites","getMessage","getMessages","getStickerPack","stickerPackId","stickerPack","getStickerPacks","stickerPacks","getOriginalInteractionResponse","getChannelPins","messagePins","getPinnedMessages","pins","getPrivateArchivedThreads","private","getPrivateJoinedArchivedThreads","joined","getPruneCount","prune","getPublicArchivedThreads","public","getRoles","getRole","getScheduledEvent","withUserCount","getScheduledEvents","getScheduledEventUsers","users","getSessionInfo","getStageInstance","getOwnVoiceState","getUserVoiceState","getSticker","getGuildSticker","getGuildStickers","getThreadMember","getUser","getThreadMembers","getReactions","getCurrentUser","getUserConnections","connections","getUserApplicationRoleConnection","roleConnections","getVanityUrl","vanity","getVoiceRegions","getWebhook","getWebhookMessage","getWebhookWithToken","getWelcomeScreen","getWidget","widgetJson","getWidgetSettings","joinThread","me","leaveGuild","leave","leaveThread","publishMessage","crosspost","removeRole","removeThreadMember","removeDmRecipient","sendFollowupMessage","sendInteractionResponse","interactionId","params","callback","sendMessage","startThreadWithMessage","startThreadWithoutMessage","getPollAnswerVoters","answerId","polls","votes","endPoll","expire","syncGuildTemplate","banMember","bulkBanMembers","bulkBan","editBotMember","editMember","getMember","getCurrentMember","currentMember","getMembers","getApplicationActivityInstance","instanceId","applicationActivityInstance","kickMember","pinMessage","messagePin","pruneMembers","searchMembers","query","search","getGuildOnboarding","onboarding","editGuildOnboarding","modifyGuildIncidentActions","incidentActions","unbanMember","unpinMessage","triggerTypingIndicator","typing","upsertGlobalApplicationCommands","upsertGuildApplicationCommands","editUserApplicationRoleConnection","addGuildMember","createTestEntitlement","monetization","entitlements","listEntitlements","getEntitlement","entitlementId","entitlement","deleteTestEntitlement","consumeEntitlement","listSkus","skus","listSubscriptions","skuId","subscriptions","getSubscription","subscriptionId","subscription","sendSoundboardSound","soundboard","sendSound","listDefaultSoundboardSounds","listDefault","listGuildSoundboardSounds","guildSounds","getGuildSoundboardSound","soundId","guildSound","createGuildSoundboardSound","modifyGuildSoundboardSound","deleteGuildSoundboardSound","listApplicationRoleConnectionsMetadataRecords","applicationRoleConnectionMetadata","updateApplicationRoleConnectionsMetadataRecords","createLobby","lobby","getLobby","lobbyId","modifyLobby","deleteLobby","addMemberToLobby","removeMemberFromLobby","leaveLobby","linkChannelToLobby","link","unlinkChannelToLobby","preferSnakeCase","enabled","camelizer","x","HttpResponseCode"],"mappings":"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"}
|