@discordeno/types 19.0.0-next.af6ffc3 → 19.0.0-next.afb1fa5
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/discord.cjs +125 -1
- package/dist/cjs/discordeno.cjs +1 -1
- package/dist/cjs/shared.cjs +85 -11
- package/dist/esm/camel.js +1 -1
- package/dist/esm/discord.js +92 -1
- package/dist/esm/discordeno.js +1 -1
- package/dist/esm/shared.js +82 -11
- package/dist/types/camel.d.ts +11 -3
- package/dist/types/camel.d.ts.map +1 -1
- package/dist/types/discord.d.ts +538 -134
- package/dist/types/discord.d.ts.map +1 -1
- package/dist/types/discordeno.d.ts +298 -69
- package/dist/types/discordeno.d.ts.map +1 -1
- package/dist/types/shared.d.ts +108 -18
- package/dist/types/shared.d.ts.map +1 -1
- package/package.json +11 -12
package/dist/cjs/discord.cjs
CHANGED
|
@@ -18,6 +18,12 @@ _export(exports, {
|
|
|
18
18
|
AutoModerationTriggerTypes: function() {
|
|
19
19
|
return AutoModerationTriggerTypes;
|
|
20
20
|
},
|
|
21
|
+
DiscordActivityLocationKind: function() {
|
|
22
|
+
return DiscordActivityLocationKind;
|
|
23
|
+
},
|
|
24
|
+
DiscordApplicationEventWebhookStatus: function() {
|
|
25
|
+
return DiscordApplicationEventWebhookStatus;
|
|
26
|
+
},
|
|
21
27
|
DiscordApplicationIntegrationType: function() {
|
|
22
28
|
return DiscordApplicationIntegrationType;
|
|
23
29
|
},
|
|
@@ -33,6 +39,9 @@ _export(exports, {
|
|
|
33
39
|
DiscordEntitlementType: function() {
|
|
34
40
|
return DiscordEntitlementType;
|
|
35
41
|
},
|
|
42
|
+
DiscordEventWebhookType: function() {
|
|
43
|
+
return DiscordEventWebhookType;
|
|
44
|
+
},
|
|
36
45
|
DiscordGuildOnboardingMode: function() {
|
|
37
46
|
return DiscordGuildOnboardingMode;
|
|
38
47
|
},
|
|
@@ -42,21 +51,45 @@ _export(exports, {
|
|
|
42
51
|
DiscordInteractionContextType: function() {
|
|
43
52
|
return DiscordInteractionContextType;
|
|
44
53
|
},
|
|
54
|
+
DiscordInteractionEntryPointCommandHandlerType: function() {
|
|
55
|
+
return DiscordInteractionEntryPointCommandHandlerType;
|
|
56
|
+
},
|
|
45
57
|
DiscordInviteType: function() {
|
|
46
58
|
return DiscordInviteType;
|
|
47
59
|
},
|
|
60
|
+
DiscordMessageReferenceType: function() {
|
|
61
|
+
return DiscordMessageReferenceType;
|
|
62
|
+
},
|
|
48
63
|
DiscordPollLayoutType: function() {
|
|
49
64
|
return DiscordPollLayoutType;
|
|
50
65
|
},
|
|
51
66
|
DiscordReactionType: function() {
|
|
52
67
|
return DiscordReactionType;
|
|
53
68
|
},
|
|
69
|
+
DiscordScheduledEventRecurrenceRuleFrequency: function() {
|
|
70
|
+
return DiscordScheduledEventRecurrenceRuleFrequency;
|
|
71
|
+
},
|
|
72
|
+
DiscordScheduledEventRecurrenceRuleMonth: function() {
|
|
73
|
+
return DiscordScheduledEventRecurrenceRuleMonth;
|
|
74
|
+
},
|
|
75
|
+
DiscordScheduledEventRecurrenceRuleWeekday: function() {
|
|
76
|
+
return DiscordScheduledEventRecurrenceRuleWeekday;
|
|
77
|
+
},
|
|
54
78
|
DiscordSkuType: function() {
|
|
55
79
|
return DiscordSkuType;
|
|
56
80
|
},
|
|
81
|
+
DiscordSubscriptionStatus: function() {
|
|
82
|
+
return DiscordSubscriptionStatus;
|
|
83
|
+
},
|
|
57
84
|
DiscordTeamMemberRole: function() {
|
|
58
85
|
return DiscordTeamMemberRole;
|
|
59
86
|
},
|
|
87
|
+
DiscordVoiceChannelEffectAnimationType: function() {
|
|
88
|
+
return DiscordVoiceChannelEffectAnimationType;
|
|
89
|
+
},
|
|
90
|
+
DiscordWebhookEventType: function() {
|
|
91
|
+
return DiscordWebhookEventType;
|
|
92
|
+
},
|
|
60
93
|
OAuth2Scope: function() {
|
|
61
94
|
return OAuth2Scope;
|
|
62
95
|
}
|
|
@@ -166,8 +199,15 @@ var DiscordApplicationIntegrationType;
|
|
|
166
199
|
/** App is installable to servers */ DiscordApplicationIntegrationType[DiscordApplicationIntegrationType["GuildInstall"] = 0] = "GuildInstall";
|
|
167
200
|
/** App is installable to users */ DiscordApplicationIntegrationType[DiscordApplicationIntegrationType["UserInstall"] = 1] = "UserInstall";
|
|
168
201
|
})(DiscordApplicationIntegrationType || (DiscordApplicationIntegrationType = {}));
|
|
202
|
+
var DiscordApplicationEventWebhookStatus;
|
|
203
|
+
(function(DiscordApplicationEventWebhookStatus) {
|
|
204
|
+
/** Webhook events are disabled by developer */ DiscordApplicationEventWebhookStatus[DiscordApplicationEventWebhookStatus["Disabled"] = 1] = "Disabled";
|
|
205
|
+
/** Webhook events are enabled by developer */ DiscordApplicationEventWebhookStatus[DiscordApplicationEventWebhookStatus["Enabled"] = 2] = "Enabled";
|
|
206
|
+
/** Webhook events are disabled by Discord, usually due to inactivity */ DiscordApplicationEventWebhookStatus[DiscordApplicationEventWebhookStatus["DisabledByDiscord"] = 3] = "DisabledByDiscord";
|
|
207
|
+
})(DiscordApplicationEventWebhookStatus || (DiscordApplicationEventWebhookStatus = {}));
|
|
169
208
|
var DiscordConnectionServiceType;
|
|
170
209
|
(function(DiscordConnectionServiceType) {
|
|
210
|
+
DiscordConnectionServiceType["AmazonMusic"] = "amazon-music";
|
|
171
211
|
DiscordConnectionServiceType["BattleNet"] = "battlenet";
|
|
172
212
|
DiscordConnectionServiceType["Bungie"] = "Bungie.net";
|
|
173
213
|
DiscordConnectionServiceType["Domain"] = "domain";
|
|
@@ -181,6 +221,7 @@ var DiscordConnectionServiceType;
|
|
|
181
221
|
DiscordConnectionServiceType["PlayStationNetwork"] = "playstation";
|
|
182
222
|
DiscordConnectionServiceType["Reddit"] = "reddit";
|
|
183
223
|
DiscordConnectionServiceType["RiotGames"] = "riotgames";
|
|
224
|
+
DiscordConnectionServiceType["Roblox"] = "roblox";
|
|
184
225
|
DiscordConnectionServiceType["Spotify"] = "spotify";
|
|
185
226
|
DiscordConnectionServiceType["Skype"] = "skype";
|
|
186
227
|
DiscordConnectionServiceType["Steam"] = "steam";
|
|
@@ -195,11 +236,35 @@ var DiscordConnectionVisibility;
|
|
|
195
236
|
/** invisible to everyone except the user themselves */ DiscordConnectionVisibility[DiscordConnectionVisibility["None"] = 0] = "None";
|
|
196
237
|
/** visible to everyone */ DiscordConnectionVisibility[DiscordConnectionVisibility["Everyone"] = 1] = "Everyone";
|
|
197
238
|
})(DiscordConnectionVisibility || (DiscordConnectionVisibility = {}));
|
|
239
|
+
var DiscordActivityLocationKind;
|
|
240
|
+
(function(DiscordActivityLocationKind) {
|
|
241
|
+
/** The Location is a Guild Channel */ DiscordActivityLocationKind["GuildChannel"] = "gc";
|
|
242
|
+
/** The Location is a Private Channel, such as a DM or GDM */ DiscordActivityLocationKind["PrivateChannel"] = "pc";
|
|
243
|
+
})(DiscordActivityLocationKind || (DiscordActivityLocationKind = {}));
|
|
198
244
|
var DiscordReactionType;
|
|
199
245
|
(function(DiscordReactionType) {
|
|
200
246
|
DiscordReactionType[DiscordReactionType["Normal"] = 0] = "Normal";
|
|
201
247
|
DiscordReactionType[DiscordReactionType["Burst"] = 1] = "Burst";
|
|
202
248
|
})(DiscordReactionType || (DiscordReactionType = {}));
|
|
249
|
+
var DiscordMessageReferenceType;
|
|
250
|
+
(function(DiscordMessageReferenceType) {
|
|
251
|
+
/**
|
|
252
|
+
* A standard reference used by replies.
|
|
253
|
+
*
|
|
254
|
+
* @remarks
|
|
255
|
+
* When the type is set to this value, the field referenced_message on the message will be present
|
|
256
|
+
*/ DiscordMessageReferenceType[DiscordMessageReferenceType["Default"] = 0] = "Default";
|
|
257
|
+
/**
|
|
258
|
+
* Reference used to point to a message at a point in time.
|
|
259
|
+
*
|
|
260
|
+
* @remarks
|
|
261
|
+
* When the type is set to this value, the field message_snapshot on the message will be present
|
|
262
|
+
*
|
|
263
|
+
* This value can only be used for basic messages;
|
|
264
|
+
* i.e. messages which do not have strong bindings to a non global entity.
|
|
265
|
+
* Thus we support only messages with `DEFAULT` or `REPLY` types, but disallowed if there are any polls, calls, or components.
|
|
266
|
+
*/ DiscordMessageReferenceType[DiscordMessageReferenceType["Forward"] = 1] = "Forward";
|
|
267
|
+
})(DiscordMessageReferenceType || (DiscordMessageReferenceType = {}));
|
|
203
268
|
var DiscordPollLayoutType;
|
|
204
269
|
(function(DiscordPollLayoutType) {
|
|
205
270
|
/** The default layout */ DiscordPollLayoutType[DiscordPollLayoutType["Default"] = 1] = "Default";
|
|
@@ -237,12 +302,54 @@ var AutoModerationActionType;
|
|
|
237
302
|
*/ AutoModerationActionType[AutoModerationActionType["Timeout"] = 3] = "Timeout";
|
|
238
303
|
/** prevents a member from using text, voice, or other interactions */ AutoModerationActionType[AutoModerationActionType["BlockMemberInteraction"] = 4] = "BlockMemberInteraction";
|
|
239
304
|
})(AutoModerationActionType || (AutoModerationActionType = {}));
|
|
305
|
+
var DiscordScheduledEventRecurrenceRuleFrequency;
|
|
306
|
+
(function(DiscordScheduledEventRecurrenceRuleFrequency) {
|
|
307
|
+
DiscordScheduledEventRecurrenceRuleFrequency[DiscordScheduledEventRecurrenceRuleFrequency["Yearly"] = 0] = "Yearly";
|
|
308
|
+
DiscordScheduledEventRecurrenceRuleFrequency[DiscordScheduledEventRecurrenceRuleFrequency["Monthly"] = 1] = "Monthly";
|
|
309
|
+
DiscordScheduledEventRecurrenceRuleFrequency[DiscordScheduledEventRecurrenceRuleFrequency["Weekly"] = 2] = "Weekly";
|
|
310
|
+
DiscordScheduledEventRecurrenceRuleFrequency[DiscordScheduledEventRecurrenceRuleFrequency["Daily"] = 3] = "Daily";
|
|
311
|
+
})(DiscordScheduledEventRecurrenceRuleFrequency || (DiscordScheduledEventRecurrenceRuleFrequency = {}));
|
|
312
|
+
var DiscordScheduledEventRecurrenceRuleWeekday;
|
|
313
|
+
(function(DiscordScheduledEventRecurrenceRuleWeekday) {
|
|
314
|
+
DiscordScheduledEventRecurrenceRuleWeekday[DiscordScheduledEventRecurrenceRuleWeekday["Monday"] = 0] = "Monday";
|
|
315
|
+
DiscordScheduledEventRecurrenceRuleWeekday[DiscordScheduledEventRecurrenceRuleWeekday["Tuesday"] = 1] = "Tuesday";
|
|
316
|
+
DiscordScheduledEventRecurrenceRuleWeekday[DiscordScheduledEventRecurrenceRuleWeekday["Wednesday"] = 2] = "Wednesday";
|
|
317
|
+
DiscordScheduledEventRecurrenceRuleWeekday[DiscordScheduledEventRecurrenceRuleWeekday["Thursday"] = 3] = "Thursday";
|
|
318
|
+
DiscordScheduledEventRecurrenceRuleWeekday[DiscordScheduledEventRecurrenceRuleWeekday["Friday"] = 4] = "Friday";
|
|
319
|
+
DiscordScheduledEventRecurrenceRuleWeekday[DiscordScheduledEventRecurrenceRuleWeekday["Saturday"] = 5] = "Saturday";
|
|
320
|
+
DiscordScheduledEventRecurrenceRuleWeekday[DiscordScheduledEventRecurrenceRuleWeekday["Sunday"] = 6] = "Sunday";
|
|
321
|
+
})(DiscordScheduledEventRecurrenceRuleWeekday || (DiscordScheduledEventRecurrenceRuleWeekday = {}));
|
|
322
|
+
var DiscordScheduledEventRecurrenceRuleMonth;
|
|
323
|
+
(function(DiscordScheduledEventRecurrenceRuleMonth) {
|
|
324
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["January"] = 1] = "January";
|
|
325
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["February"] = 2] = "February";
|
|
326
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["March"] = 3] = "March";
|
|
327
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["April"] = 4] = "April";
|
|
328
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["May"] = 5] = "May";
|
|
329
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["June"] = 6] = "June";
|
|
330
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["July"] = 7] = "July";
|
|
331
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["August"] = 8] = "August";
|
|
332
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["September"] = 9] = "September";
|
|
333
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["October"] = 10] = "October";
|
|
334
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["November"] = 11] = "November";
|
|
335
|
+
DiscordScheduledEventRecurrenceRuleMonth[DiscordScheduledEventRecurrenceRuleMonth["December"] = 12] = "December";
|
|
336
|
+
})(DiscordScheduledEventRecurrenceRuleMonth || (DiscordScheduledEventRecurrenceRuleMonth = {}));
|
|
240
337
|
var DiscordInviteType;
|
|
241
338
|
(function(DiscordInviteType) {
|
|
242
339
|
DiscordInviteType[DiscordInviteType["Guild"] = 0] = "Guild";
|
|
243
340
|
DiscordInviteType[DiscordInviteType["GroupDm"] = 1] = "GroupDm";
|
|
244
341
|
DiscordInviteType[DiscordInviteType["Friend"] = 2] = "Friend";
|
|
245
342
|
})(DiscordInviteType || (DiscordInviteType = {}));
|
|
343
|
+
var DiscordInteractionEntryPointCommandHandlerType;
|
|
344
|
+
(function(DiscordInteractionEntryPointCommandHandlerType) {
|
|
345
|
+
/** The app handles the interaction using an interaction token */ DiscordInteractionEntryPointCommandHandlerType[DiscordInteractionEntryPointCommandHandlerType["AppHandler"] = 1] = "AppHandler";
|
|
346
|
+
/** Discord handles the interaction by launching an Activity and sending a follow-up message without coordinating with the app */ DiscordInteractionEntryPointCommandHandlerType[DiscordInteractionEntryPointCommandHandlerType["DiscordLaunchActivity"] = 2] = "DiscordLaunchActivity";
|
|
347
|
+
})(DiscordInteractionEntryPointCommandHandlerType || (DiscordInteractionEntryPointCommandHandlerType = {}));
|
|
348
|
+
var DiscordVoiceChannelEffectAnimationType;
|
|
349
|
+
(function(DiscordVoiceChannelEffectAnimationType) {
|
|
350
|
+
/** A fun animation, sent by a Nitro subscriber */ DiscordVoiceChannelEffectAnimationType[DiscordVoiceChannelEffectAnimationType["Premium"] = 0] = "Premium";
|
|
351
|
+
/** The standard animation */ DiscordVoiceChannelEffectAnimationType[DiscordVoiceChannelEffectAnimationType["Basic"] = 1] = "Basic";
|
|
352
|
+
})(DiscordVoiceChannelEffectAnimationType || (DiscordVoiceChannelEffectAnimationType = {}));
|
|
246
353
|
var DiscordGuildOnboardingPromptType;
|
|
247
354
|
(function(DiscordGuildOnboardingPromptType) {
|
|
248
355
|
DiscordGuildOnboardingPromptType[DiscordGuildOnboardingPromptType["MultipleChoice"] = 0] = "MultipleChoice";
|
|
@@ -282,11 +389,28 @@ var DiscordSkuType;
|
|
|
282
389
|
/** Represents a recurring subscription */ DiscordSkuType[DiscordSkuType["Subscription"] = 5] = "Subscription";
|
|
283
390
|
/** System-generated group for each SUBSCRIPTION SKU created */ DiscordSkuType[DiscordSkuType["SubscriptionGroup"] = 6] = "SubscriptionGroup";
|
|
284
391
|
})(DiscordSkuType || (DiscordSkuType = {}));
|
|
392
|
+
var DiscordSubscriptionStatus;
|
|
393
|
+
(function(DiscordSubscriptionStatus) {
|
|
394
|
+
/** Subscription is active and scheduled to renew. */ DiscordSubscriptionStatus[DiscordSubscriptionStatus["Active"] = 0] = "Active";
|
|
395
|
+
/** Subscription is active but will not renew. */ DiscordSubscriptionStatus[DiscordSubscriptionStatus["Ending"] = 1] = "Ending";
|
|
396
|
+
/** Subscription is inactive and not being charged. */ DiscordSubscriptionStatus[DiscordSubscriptionStatus["Inactive"] = 2] = "Inactive";
|
|
397
|
+
})(DiscordSubscriptionStatus || (DiscordSubscriptionStatus = {}));
|
|
285
398
|
var DiscordInteractionContextType;
|
|
286
399
|
(function(DiscordInteractionContextType) {
|
|
287
400
|
/** Interaction can be used within servers */ DiscordInteractionContextType[DiscordInteractionContextType["Guild"] = 0] = "Guild";
|
|
288
401
|
/** Interaction can be used within DMs with the app's bot user */ DiscordInteractionContextType[DiscordInteractionContextType["BotDm"] = 1] = "BotDm";
|
|
289
402
|
/** Interaction can be used within Group DMs and DMs other than the app's bot user */ DiscordInteractionContextType[DiscordInteractionContextType["PrivateChannel"] = 2] = "PrivateChannel";
|
|
290
403
|
})(DiscordInteractionContextType || (DiscordInteractionContextType = {}));
|
|
404
|
+
var DiscordEventWebhookType;
|
|
405
|
+
(function(DiscordEventWebhookType) {
|
|
406
|
+
/** PING event sent to verify your Webhook Event URL is active */ DiscordEventWebhookType[DiscordEventWebhookType["Ping"] = 0] = "Ping";
|
|
407
|
+
/** Webhook event (details for event in event body object) */ DiscordEventWebhookType[DiscordEventWebhookType["Event"] = 1] = "Event";
|
|
408
|
+
})(DiscordEventWebhookType || (DiscordEventWebhookType = {}));
|
|
409
|
+
var DiscordWebhookEventType;
|
|
410
|
+
(function(DiscordWebhookEventType) {
|
|
411
|
+
/** Sent when an app was authorized by a user to a server or their account */ DiscordWebhookEventType["ApplicationAuthorized"] = "APPLICATION_AUTHORIZED";
|
|
412
|
+
/** Entitlement was created */ DiscordWebhookEventType["EntitlementCreate"] = "ENTITLEMENT_CREATE";
|
|
413
|
+
/** User was added to a Quest (currently unavailable) */ DiscordWebhookEventType["QuestUserEnrollment"] = "QUEST_USER_ENROLLMENT";
|
|
414
|
+
})(DiscordWebhookEventType || (DiscordWebhookEventType = {}));
|
|
291
415
|
|
|
292
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord.ts"],"sourcesContent":["import {\n  type ActivityTypes,\n  type AllowedMentionsTypes,\n  type ApplicationCommandOptionTypes,\n  type ApplicationCommandPermissionTypes,\n  type ApplicationCommandTypes,\n  type ApplicationFlags,\n  type AttachmentFlags,\n  type AuditLogEvents,\n  type ButtonStyles,\n  type ChannelFlags,\n  type ChannelTypes,\n  type DefaultMessageNotificationLevels,\n  type EmbedTypes,\n  type ExplicitContentFilterLevels,\n  type ForumLayout,\n  type GatewayEventNames,\n  type GuildFeatures,\n  type GuildNsfwLevel,\n  type IntegrationExpireBehaviors,\n  type InteractionTypes,\n  type Localization,\n  type MessageActivityTypes,\n  type MessageComponentTypes,\n  type MessageFlags,\n  type MessageTypes,\n  type MfaLevels,\n  type OverwriteTypes,\n  type PickPartial,\n  type PremiumTiers,\n  type PremiumTypes,\n  type RoleFlags,\n  type ScheduledEventEntityType,\n  type ScheduledEventPrivacyLevel,\n  type ScheduledEventStatus,\n  type SkuFlags,\n  type SortOrderTypes,\n  type StickerFormatTypes,\n  type StickerTypes,\n  type SystemChannelFlags,\n  type TargetTypes,\n  type TeamMembershipStates,\n  type TextStyles,\n  type VerificationLevels,\n  type VideoQualityModes,\n  type WebhookTypes,\n} from './shared.js'\n\n/** https://discord.com/developers/docs/resources/user#user-object */\nexport interface DiscordUser {\n  /** The user's username, not unique across the platform */\n  username: string\n  /** The user's display name, if it is set. For bots, this is the application name */\n  global_name: string | null\n  /** The user's chosen language option */\n  locale?: string\n  /** The flags on a user's account */\n  flags?: number\n  /** The type of Nitro subscription on a user's account */\n  premium_type?: PremiumTypes\n  /** The public flags on a user's account */\n  public_flags?: number\n  /** the user's banner color encoded as an integer representation of hexadecimal color code */\n  accent_color?: number\n  /** The user's id */\n  id: string\n  /** The user's discord-tag */\n  discriminator: string\n  /** The user's avatar hash */\n  avatar: string | null\n  /** Whether the user belongs to an OAuth2 application */\n  bot?: boolean\n  /** Whether the user is an Official Discord System user (part of the urgent message system) */\n  system?: boolean\n  /** Whether the user has two factor enabled on their account */\n  mfa_enabled?: boolean\n  /** Whether the email on this account has been verified */\n  verified?: boolean\n  /** The user's email */\n  email?: string | null\n  /** the user's banner, or null if unset */\n  banner?: string\n  /** data for the user's avatar decoration */\n  avatar_decoration_data?: DiscordAvatarDecorationData\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#shared-resources-oauth2-scopes */\nexport enum OAuth2Scope {\n  /**\n   * Allows your app to fetch data from a user's \"Now Playing/Recently Played\" list\n   *\n   * @remarks\n   * This scope is not currently available for apps\n   */\n  ActivitiesRead = 'activities.read',\n  /**\n   * Allows your app to update a user's activity\n   *\n   * @remarks\n   * This scope not currently available for apps.\n   */\n  ActivitiesWrite = 'activities.write',\n  /** Allows your app to read build data for a user's applications */\n  ApplicationsBuildsRead = 'applications.builds.read',\n  /**\n   * Allows your app to upload/update builds for a user's applications\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  ApplicationsBuildsUpload = 'applications.builds.upload',\n  /** Allows your app to add commands to a guild - included by default with the `bot` scope */\n  ApplicationsCommands = 'applications.commands',\n  /**\n   * Allows your app to update its Application Commands via this bearer token\n   *\n   * @remarks\n   * This scope can only be used when using a [Client Credential Grant](https://discord.com/developers/docs/topics/oauth2#client-credentials-grant)\n   */\n  ApplicationsCommandsUpdate = 'applications.commands.update',\n  /** Allows your app to update permissions for its commands in a guild a user has permissions to */\n  ApplicationCommandsPermissionsUpdate = 'applications.commands.permissions.update',\n  /** Allows your app to read entitlements for a user's applications */\n  ApplicationsEntitlements = 'applications.entitlements',\n  /** Allows your app to read and update store data (SKUs, store listings, achievements, etc.) for a user's applications */\n  ApplicationsStoreUpdate = 'applications.store.update',\n  /** For oauth2 bots, this puts the bot in the user's selected guild by default */\n  Bot = 'bot',\n  /** Allows requests to [/users/@me/connections](https://discord.com/developers/docs/resources/user#get-user-connections) */\n  Connections = 'connections',\n  /**\n   * Allows your app to see information about the user's DMs and group DMs\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  DMChannelsRead = 'dm_channels.read',\n  /** Adds the `email` filed to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user) */\n  Email = 'email',\n  /** Allows your app to join users to a group dm */\n  GroupDMJoins = 'gdm.join',\n  /** Allows requests to [/users/@me/guilds](https://discord.com/developers/docs/resources/user#get-current-user-guilds) */\n  Guilds = 'guilds',\n  /** Allows requests to [/guilds/{guild.id}/members/{user.id}](https://discord.com/developers/docs/resources/guild#add-guild-member) */\n  GuildsJoin = 'guilds.join',\n  /** Allows requests to [/users/@me/guilds/{guild.id}/member](https://discord.com/developers/docs/resources/user#get-current-user-guild-member) */\n  GuildsMembersRead = 'guilds.members.read',\n  /**\n   * Allows requests to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   *\n   * @remarks\n   * The return object from [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   * does NOT contain the `email` field unless the scope `email` is also used\n   */\n  Identify = 'identify',\n  /**\n   * For local rpc server api access, this allows you to read messages from all client channels\n   * (otherwise restricted to channels/guilds your app creates)\n   */\n  MessagesRead = 'messages.read',\n  /**\n   * Allows your app to know a user's friends and implicit relationships\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RelationshipsRead = 'relationships.read',\n  /** Allows your app to update a user's connection and metadata for the app */\n  RoleConnectionsWrite = 'role_connections.write',\n  /**\n   * For local rpc server access, this allows you to control a user's local Discord client\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPC = 'rpc',\n  /**\n   * For local rpc server access, this allows you to update a user's activity\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCActivitiesWrite = 'rpc.activities.write',\n  /**\n   * For local rpc server api access, this allows you to receive notifications pushed out to the user\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCNotificationsRead = 'rpc.notifications.read',\n  /**\n   * For local rpc server access, this allows you to read a user's voice settings and listen for voice events\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceRead = 'rpc.voice.read',\n  /**\n   * For local rpc server access, this allows you to update a user's voice settings\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceWrite = 'rpc.voice.write',\n  /**\n   * Allows your app to connect to voice on user's behalf and see all the voice members\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  Voice = 'voice',\n  /** Generate a webhook that is returned in the oauth token response for authorization code grants */\n  WebhookIncoming = 'webhook.incoming',\n}\n\n/** https://discord.com/developers/docs/resources/guild#integration-object-integration-structure */\nexport interface DiscordIntegration {\n  /** Integration Id */\n  id: string\n  /** Integration name */\n  name: string\n  /** Integration type (twitch, youtube, discord, or guild_subscription). */\n  type: 'twitch' | 'youtube' | 'discord'\n  /** Is this integration enabled */\n  enabled?: boolean\n  /** Is this integration syncing */\n  syncing?: boolean\n  /** Role Id that this integration uses for \"subscribers\" */\n  role_id?: string\n  /** Whether emoticons should be synced for this integration (twitch only currently) */\n  enable_emoticons?: boolean\n  /** The behavior of expiring subscribers */\n  expire_behavior?: IntegrationExpireBehaviors\n  /** The grace period (in days) before expiring subscribers */\n  expire_grace_period?: number\n  /** When this integration was last synced */\n  synced_at?: string\n  /** How many subscribers this integration has */\n  subscriber_count?: number\n  /** Has this integration been revoked */\n  revoked?: boolean\n  /** User for this integration */\n  user?: DiscordUser\n  /** Integration account information */\n  account: DiscordIntegrationAccount\n  /** The bot/OAuth2 application for discord integrations */\n  application?: DiscordIntegrationApplication\n  /** the scopes the application has been authorized for */\n  scopes: OAuth2Scope[]\n}\n\n/** https://discord.com/developers/docs/resources/guild#integration-account-object-integration-account-structure */\nexport interface DiscordIntegrationAccount {\n  /** Id of the account */\n  id: string\n  /** Name of the account */\n  name: string\n}\n\n/** https://discord.com/developers/docs/resources/guild#integration-application-object-integration-application-structure */\nexport interface DiscordIntegrationApplication {\n  /** The id of the app */\n  id: string\n  /** The name of the app */\n  name: string\n  /** the icon hash of the app */\n  icon: string | null\n  /** The description of the app */\n  description: string\n  /** The bot associated with this application */\n  bot?: DiscordUser\n}\n\n/** https://github.com/discord/discord-api-docs/blob/master/docs/topics/Gateway.md#integration-create-event-additional-fields */\nexport interface DiscordIntegrationCreateUpdate extends DiscordIntegration {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/** https://github.com/discord/discord-api-docs/blob/master/docs/topics/Gateway.md#integration-delete-event-fields */\nexport interface DiscordIntegrationDelete {\n  /** Integration id */\n  id: string\n  /** Id of the guild */\n  guild_id: string\n  /** Id of the bot/OAuth2 application for this discord integration */\n  application_id?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-integrations-update */\nexport interface DiscordGuildIntegrationsUpdate {\n  /** id of the guild whose integrations were updated */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#typing-start */\nexport interface DiscordTypingStart {\n  /** Unix time (in seconds) of when the user started typing */\n  timestamp: number\n  /** id of the channel */\n  channel_id: string\n  /** id of the guild */\n  guild_id?: string\n  /** id of the user */\n  user_id: string\n  /** The member who started typing if this happened in a guild */\n  member?: DiscordMember\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-member-object */\nexport interface DiscordMember {\n  /** Whether the user is deafened in voice channels */\n  deaf?: boolean\n  /** Whether the user is muted in voice channels */\n  mute?: boolean\n  /** Whether the user has not yet passed the guild's Membership Screening requirements */\n  pending?: boolean\n  /** The user this guild member represents */\n  user?: DiscordUser\n  /** This users guild nickname */\n  nick?: string | null\n  /** The members custom avatar for this server. */\n  avatar?: string\n  /** Array of role object ids */\n  roles: string[]\n  /** When the user joined the guild */\n  joined_at: string\n  /** When the user started boosting the guild */\n  premium_since?: string | null\n  /** The permissions this member has in the guild. Only present on interaction events and OAuth2 current member fetch. */\n  permissions?: string\n  /** when the user's timeout will expire and the user will be able to communicate in the guild again (set null to remove timeout), null or a time in the past if the user is not timed out */\n  communication_disabled_until?: string | null\n  /** data for the member's guild avatar decoration */\n  avatar_decoration_data?: DiscordAvatarDecorationData | null\n}\n\n/** https://discord.com/developers/docs/resources/user#avatar-decoration-data-object */\nexport interface DiscordAvatarDecorationData {\n  /** the avatar decoration hash */\n  asset: string\n  /** id of the avatar decoration's SKU */\n  sku_id: string\n}\n\n/** https://discord.com/developers/docs/resources/application#application-object */\nexport interface DiscordApplication {\n  /** The name of the app */\n  name: string\n  /** The description of the app */\n  description: string\n  /** An array of rpc origin urls, if rpc is enabled */\n  rpc_origins?: string[]\n  /** The url of the app's terms of service */\n  terms_of_service_url?: string\n  /** The url of the app's privacy policy */\n  privacy_policy_url?: string\n  /** The hex encoded key for verification in interactions and the GameSDK's GetTicket */\n  verify_key: string\n  /** If this application is a game sold on Discord, this field will be the id of the \"Game SKU\" that is created, if exists */\n  primary_sku_id?: string\n  /** If this application is a game sold on Discord, this field will be the URL slug that links to the store page */\n  slug?: string\n  /** The application's public flags */\n  flags?: ApplicationFlags\n  /** The id of the app */\n  id: string\n  /** The icon hash of the app */\n  icon: string | null\n  /** When false only app owner can join the app's bot to guilds */\n  bot_public: boolean\n  /** When true the app's bot will only join upon completion of the full oauth2 code grant flow */\n  bot_require_code_grant: boolean\n  /** Partial user object containing info on the owner of the application */\n  owner?: Partial<DiscordUser>\n  /** If the application belongs to a team, this will be a list of the members of that team */\n  team: DiscordTeam | null\n  /** Guild associated with the app. For example, a developer support server. */\n  guild_id?: string\n  /** A partial object of the associated guild */\n  guild?: Partial<DiscordGuild>\n  /** If this application is a game sold on Discord, this field will be the hash of the image on store embeds */\n  cover_image?: string\n  /** up to 5 tags describing the content and functionality of the application */\n  tags?: string[]\n  /** settings for the application's default in-app authorization link, if enabled */\n  install_params?: DiscordInstallParams\n  /** Default scopes and permissions for each supported installation context. */\n  integration_types_config?: Partial<Record<`${DiscordApplicationIntegrationType}`, DiscordApplicationIntegrationTypeConfiguration>>\n  /** the application's default custom authorization link, if enabled */\n  custom_install_url?: string\n  /** the application's role connection verification entry point, which when configured will render the app as a verification method in the guild role verification configuration */\n  role_connections_verification_url?: string\n  /** An approximate count of the app's guild membership. */\n  approximate_guild_count?: number\n  /** Partial user object for the bot user associated with the app */\n  bot?: Partial<DiscordUser>\n  /** Array of redirect URIs for the app */\n  redirect_uris?: string[]\n  /** Interactions endpoint URL for the app */\n  interactions_endpoint_url?: string\n}\n\n/** https://discord.com/developers/docs/resources/application#application-object-application-integration-type-configuration-object */\nexport interface DiscordApplicationIntegrationTypeConfiguration {\n  /**\n   * Install params for each installation context's default in-app authorization link\n   *\n   * https://discord.com/developers/docs/resources/application#install-params-object-install-params-structure\n   */\n  oauth2_install_params?: {\n    /** Scopes to add the application to the server with */\n    scopes: OAuth2Scope[]\n    /** Permissions to request for the bot role */\n    permissions: string\n  }\n}\n\nexport enum DiscordApplicationIntegrationType {\n  /** App is installable to servers */\n  GuildInstall = 0,\n  /** App is installable to users */\n  UserInstall = 1,\n}\n\nexport type DiscordTokenExchange = DiscordTokenExchangeAuthorizationCode | DiscordTokenExchangeRefreshToken | DiscordTokenExchangeClientCredentials\n\nexport interface DiscordTokenExchangeAuthorizationCode {\n  grant_type: 'authorization_code'\n  /** The code for the token exchange */\n  code: string\n  /** The redirect_uri associated with this authorization */\n  redirect_uri: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#client-credentials-grant */\nexport interface DiscordTokenExchangeRefreshToken {\n  grant_type: 'refresh_token'\n  /** the user's refresh token */\n  refresh_token: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#client-credentials-grant */\nexport interface DiscordTokenExchangeClientCredentials {\n  grant_type: 'client_credentials'\n  /** The scope(s) for the access token */\n  scope: OAuth2Scope[]\n}\n\nexport interface DiscordAccessTokenResponse {\n  /** The access token of the user */\n  access_token: string\n  /** The type of token */\n  token_type: string\n  /** The number of seconds after that the access token is expired */\n  expires_in: number\n  /**\n   * The refresh token to refresh the access token\n   *\n   * @remarks\n   * When the token exchange is a client credentials type grant this value is not defined.\n   */\n  refresh_token: string\n  /** The scopes for the access token */\n  scope: string\n  /** The webhook the user created for the application. Requires the `webhook.incoming` scope */\n  webhook?: DiscordIncomingWebhook\n  /** The guild the bot has been added. Requires the `bot` scope */\n  guild?: DiscordGuild\n}\n\nexport interface DiscordTokenRevocation {\n  /** The access token to revoke */\n  token: string\n  /** Optional, the type of token you are using for the revocation */\n  token_type_hint?: 'access_token' | 'refresh_token'\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#get-current-authorization-information-response-structure */\nexport interface DiscordCurrentAuthorization {\n  application: DiscordApplication\n  /** the scopes the user has authorized the application for */\n  scopes: OAuth2Scope[]\n  /** when the access token expires */\n  expires: string\n  /** the user who has authorized, if the user has authorized with the `identify` scope */\n  user?: DiscordUser\n}\n\n/** https://discord.com/developers/docs/resources/user#connection-object-connection-structure */\nexport interface DiscordConnection {\n  /** id of the connection account */\n  id: string\n  /** the username of the connection account */\n  name: string\n  /** the service of this connection */\n  type: DiscordConnectionServiceType\n  /** whether the connection is revoked */\n  revoked?: boolean\n  /** an array of partial server integrations */\n  integrations?: Array<Partial<DiscordIntegration>>\n  /** whether the connection is verified */\n  verified: boolean\n  /** whether friend sync is enabled for this connection */\n  friend_sync: boolean\n  /** whether activities related to this connection will be shown in presence updates */\n  show_activity: boolean\n  /** whether this connection has a corresponding third party OAuth2 token */\n  two_way_link: boolean\n  /** visibility of this connection */\n  visibility: DiscordConnectionVisibility\n}\n\n/** https://discord.com/developers/docs/resources/user#connection-object-services */\nexport enum DiscordConnectionServiceType {\n  BattleNet = 'battlenet',\n  Bungie = 'Bungie.net',\n  Domain = 'domain',\n  eBay = 'ebay',\n  EpicGames = 'epicgames',\n  Facebook = 'facebook',\n  GitHub = 'github',\n  Instagram = 'instagram',\n  LeagueOfLegends = 'leagueoflegends',\n  PayPal = 'paypal',\n  PlayStationNetwork = 'playstation',\n  Reddit = 'reddit',\n  RiotGames = 'riotgames',\n  Spotify = 'spotify',\n  Skype = 'skype',\n  Steam = 'steam',\n  TikTok = 'tiktok',\n  Twitch = 'twitch',\n  Twitter = 'twitter',\n  Xbox = 'xbox',\n  YouTube = 'youtube',\n}\n\n/** https://discord.com/developers/docs/resources/user#connection-object-visibility-types */\nexport enum DiscordConnectionVisibility {\n  /** invisible to everyone except the user themselves */\n  None = 0,\n  /** visible to everyone */\n  Everyone = 1,\n}\n\n/** https://discord.com/developers/docs/resources/user#application-role-connection-object-application-role-connection-structure */\nexport interface DiscordApplicationRoleConnection {\n  /** the vanity name of the platform a bot has connected (max 50 characters) */\n  platform_name: string | null\n  /** the username on the platform a bot has connected (max 100 characters) */\n  platform_username: string | null\n  /** object mapping application role connection metadata keys to their stringified value (max 100 characters) for the user on the platform a bot has connected */\n  metadata: Record<string, string>\n}\n\n/** https://discord.com/developers/docs/topics/teams#data-models-team-object */\nexport interface DiscordTeam {\n  /** Hash of the image of the team's icon */\n  icon: string | null\n  /** Unique ID of the team */\n  id: string\n  /** Members of the team */\n  members: DiscordTeamMember[]\n  /** User ID of the current team owner */\n  owner_user_id: string\n  /** Name of the team */\n  name: string\n}\n\n/** https://discord.com/developers/docs/topics/teams#data-models-team-members-object */\nexport interface DiscordTeamMember {\n  /** The user's membership state on the team */\n  membership_state: TeamMembershipStates\n  /** The id of the parent team of which they are a member */\n  team_id: string\n  /** The avatar, discriminator, id, username, and global_name of the user */\n  user: Partial<DiscordUser> & Pick<DiscordUser, 'avatar' | 'discriminator' | 'id' | 'username' | 'global_name'>\n  /** Role of the team member */\n  role: DiscordTeamMemberRole\n}\n\n/** https://discord.com/developers/docs/topics/gateway#webhooks-update-webhook-update-event-fields */\nexport interface DiscordWebhookUpdate {\n  /** id of the guild */\n  guild_id: string\n  /** id of the channel */\n  channel_id: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#allowed-mentions-object */\nexport interface DiscordAllowedMentions {\n  /** An array of allowed mention types to parse from the content. */\n  parse?: AllowedMentionsTypes[]\n  /** For replies, whether to mention the author of the message being replied to (default false) */\n  replied_user?: boolean\n  /** Array of role_ids to mention (Max size of 100) */\n  roles?: string[]\n  /** Array of user_ids to mention (Max size of 100) */\n  users?: string[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object */\nexport interface DiscordEmbed {\n  /** Title of embed */\n  title?: string\n  /** Type of embed (always \"rich\" for webhook embeds) */\n  type?: EmbedTypes\n  /** Description of embed */\n  description?: string\n  /** Url of embed */\n  url?: string\n  /** Color code of the embed */\n  color?: number\n  /** Timestamp of embed content */\n  timestamp?: string\n  /** Footer information */\n  footer?: DiscordEmbedFooter\n  /** Image information */\n  image?: DiscordEmbedImage\n  /** Thumbnail information */\n  thumbnail?: DiscordEmbedThumbnail\n  /** Video information */\n  video?: DiscordEmbedVideo\n  /** Provider information */\n  provider?: DiscordEmbedProvider\n  /** Author information */\n  author?: DiscordEmbedAuthor\n  /** Fields information */\n  fields?: DiscordEmbedField[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-author-structure */\nexport interface DiscordEmbedAuthor {\n  /** Name of author */\n  name: string\n  /** Url of author */\n  url?: string\n  /** Url of author icon (only supports http(s) and attachments) */\n  icon_url?: string\n  /** A proxied url of author icon */\n  proxy_icon_url?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-field-structure */\nexport interface DiscordEmbedField {\n  /** Name of the field */\n  name: string\n  /** Value of the field */\n  value: string\n  /** Whether or not this field should display inline */\n  inline?: boolean\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-footer-structure */\nexport interface DiscordEmbedFooter {\n  /** Footer text */\n  text: string\n  /** Url of footer icon (only supports http(s) and attachments) */\n  icon_url?: string\n  /** A proxied url of footer icon */\n  proxy_icon_url?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-image-structure */\nexport interface DiscordEmbedImage {\n  /** Source url of image (only supports http(s) and attachments) */\n  url: string\n  /** A proxied url of the image */\n  proxy_url?: string\n  /** Height of image */\n  height?: number\n  /** Width of image */\n  width?: number\n}\n\nexport interface DiscordEmbedProvider {\n  /** Name of provider */\n  name?: string\n  /** Url of provider */\n  url?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-thumbnail-structure */\nexport interface DiscordEmbedThumbnail {\n  /** Source url of thumbnail (only supports http(s) and attachments) */\n  url: string\n  /** A proxied url of the thumbnail */\n  proxy_url?: string\n  /** Height of thumbnail */\n  height?: number\n  /** Width of thumbnail */\n  width?: number\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-video-structure */\nexport interface DiscordEmbedVideo {\n  /** Source url of video */\n  url?: string\n  /** A proxied url of the video */\n  proxy_url?: string\n  /** Height of video */\n  height?: number\n  /** Width of video */\n  width?: number\n}\n\n/** https://discord.com/developers/docs/resources/channel#attachment-object */\nexport interface DiscordAttachment {\n  /** Name of file attached */\n  filename: string\n  /** The title of the file */\n  title?: string\n  /** The attachment's [media type](https://en.wikipedia.org/wiki/Media_type) */\n  content_type?: string\n  /** Size of file in bytes */\n  size: number\n  /** Source url of file */\n  url: string\n  /** A proxied url of file */\n  proxy_url: string\n  /** Attachment id */\n  id: string\n  /** description for the file (max 1024 characters) */\n  description?: string\n  /** Height of file (if image) */\n  height?: number | null\n  /** Width of file (if image) */\n  width?: number | null\n  /** whether this attachment is ephemeral. Ephemeral attachments will automatically be removed after a set period of time. Ephemeral attachments on messages are guaranteed to be available as long as the message itself exists. */\n  ephemeral?: boolean\n  /** The duration of the audio file for a voice message */\n  duration_secs?: number\n  /** A base64 encoded bytearray representing a sampled waveform for a voice message */\n  waveform?: string\n  /** Attachment flags combined as a bitfield */\n  flags?: AttachmentFlags\n}\n\n/** https://discord.com/developers/docs/resources/webhook#webhook-object-webhook-structure */\nexport type DiscordWebhook = DiscordIncomingWebhook | DiscordApplicationWebhook\n\nexport interface DiscordIncomingWebhook {\n  /** The type of the webhook */\n  type: WebhookTypes\n  /** The secure token of the webhook (returned for Incoming Webhooks) */\n  token?: string\n  /** The url used for executing the webhook (returned by the webhooks OAuth2 flow) */\n  url?: string\n\n  /** The id of the webhook */\n  id: string\n  /** The guild id this webhook is for */\n  guild_id?: string\n  /** The channel id this webhook is for */\n  channel_id: string\n  /** The user this webhook was created by (not returned when getting a webhook with its token) */\n  user?: DiscordUser\n  /** The default name of the webhook */\n  name: string | null\n  /** The default user avatar hash of the webhook */\n  avatar: string | null\n  /** The bot/OAuth2 application that created this webhook */\n  application_id: string | null\n  /** The guild of the channel that this webhook is following (returned for Channel Follower Webhooks) */\n  source_guild?: Partial<DiscordGuild>\n  /** The channel that this webhook is following (returned for Channel Follower Webhooks) */\n  source_channel?: Partial<DiscordChannel>\n}\n\nexport interface DiscordApplicationWebhook {\n  /** The type of the webhook */\n  type: WebhookTypes.Application\n  /** The secure token of the webhook (returned for Incoming Webhooks) */\n  token?: string\n  /** The url used for executing the webhook (returned by the webhooks OAuth2 flow) */\n  url?: string\n\n  /** The id of the webhook */\n  id: string\n  /** The guild id this webhook is for */\n  guild_id?: string | null\n  /** The channel id this webhook is for */\n  channel_id?: string | null\n  /** The user this webhook was created by (not returned when getting a webhook with its token) */\n  user?: DiscordUser\n  /** The default name of the webhook */\n  name: string | null\n  /** The default user avatar hash of the webhook */\n  avatar: string | null\n  /** The bot/OAuth2 application that created this webhook */\n  application_id: string | null\n  /** The guild of the channel that this webhook is following (returned for Channel Follower Webhooks), field will be absent if the webhook creator has since lost access to the guild where the followed channel resides */\n  source_guild?: Partial<DiscordGuild>\n  /** The channel that this webhook is following (returned for Channel Follower Webhooks), field will be absent if the webhook creator has since lost access to the guild where the followed channel resides */\n  source_channel?: Partial<DiscordChannel>\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-object */\nexport interface DiscordGuild {\n  /** Guild name (2-100 characters, excluding trailing and leading whitespace) */\n  name: string\n  /** True if the user is the owner of the guild */\n  owner?: boolean\n  /** Afk timeout in seconds */\n  afk_timeout: number\n  /** True if the server widget is enabled */\n  widget_enabled?: boolean\n  /** Verification level required for the guild */\n  verification_level: VerificationLevels\n  /** Default message notifications level */\n  default_message_notifications: DefaultMessageNotificationLevels\n  /** Explicit content filter level */\n  explicit_content_filter: ExplicitContentFilterLevels\n  /** Enabled guild features */\n  features: GuildFeatures[]\n  /** Required MFA level for the guild */\n  mfa_level: MfaLevels\n  /** System channel flags */\n  system_channel_flags: SystemChannelFlags\n  /** True if this is considered a large guild */\n  large?: boolean\n  /** True if this guild is unavailable due to an outage */\n  unavailable?: boolean\n  /** Total number of members in this guild */\n  member_count?: number\n  /** The maximum number of presences for the guild (the default value, currently 25000, is in effect when null is returned) */\n  max_presences?: number | null\n  /** The maximum number of members for the guild */\n  max_members?: number\n  /** The vanity url code for the guild */\n  vanity_url_code: string | null\n  /** The description of a guild */\n  description: string | null\n  /** Premium tier (Server Boost level) */\n  premium_tier: PremiumTiers\n  /** The number of boosts this guild currently has */\n  premium_subscription_count?: number\n  /** The maximum amount of users in a video channel */\n  max_video_channel_users?: number\n  /** Maximum amount of users in a stage video channel */\n  max_stage_video_channel_users?: number\n  /** Approximate number of members in this guild, returned from the GET /guilds/id endpoint when with_counts is true */\n  approximate_member_count?: number\n  /** Approximate number of non-offline members in this guild, returned from the GET /guilds/id endpoint when with_counts is true */\n  approximate_presence_count?: number\n  /** Guild NSFW level */\n  nsfw_level: GuildNsfwLevel\n  /** Whether the guild has the boost progress bar enabled */\n  premium_progress_bar_enabled: boolean\n  /** Guild id */\n  id: string\n  /** Icon hash */\n  icon: string | null\n  /** Icon hash, returned when in the template object */\n  icon_hash?: string | null\n  /** Splash hash */\n  splash: string | null\n  /** Discovery splash hash; only present for guilds with the \"DISCOVERABLE\" feature */\n  discovery_splash: string | null\n  /** Id of the owner */\n  owner_id: string\n  /** Total permissions for the user in the guild (excludes overwrites and implicit permissions) */\n  permissions?: string\n  /** Id of afk channel */\n  afk_channel_id: string | null\n  /** The channel id that the widget will generate an invite to, or null if set to no invite */\n  widget_channel_id?: string | null\n  /** Roles in the guild */\n  roles: DiscordRole[]\n  /** Custom guild emojis */\n  emojis: DiscordEmoji[]\n  /** Application id of the guild creator if it is bot-created */\n  application_id: string | null\n  /** The id of the channel where guild notices such as welcome messages and boost events are posted */\n  system_channel_id: string | null\n  /** The id of the channel where community guilds can display rules and/or guidelines */\n  rules_channel_id: string | null\n  /** When this guild was joined at */\n  joined_at?: string\n  /** States of members currently in voice channels; lacks the guild_id key */\n  voice_states?: Array<Omit<DiscordVoiceState, 'guildId'>>\n  /** Users in the guild */\n  members?: DiscordMember[]\n  /** Channels in the guild */\n  channels?: DiscordChannel[]\n  /** All active threads in the guild that the current user has permission to view */\n  threads?: DiscordChannel[]\n  /** Presences of the members in the guild, will only include non-offline members if the size is greater than large threshold */\n  presences?: Array<Partial<DiscordPresenceUpdate>>\n  /** Banner hash */\n  banner: string | null\n  /** The preferred locale of a Community guild; used in server discovery and notices from Discord; defaults to \"en-US\" */\n  preferred_locale: string\n  /** The id of the channel where admins and moderators of Community guilds receive notices from Discord */\n  public_updates_channel_id: string | null\n  /** The welcome screen of a Community guild, shown to new members, returned in an Invite's guild object */\n  welcome_screen?: DiscordWelcomeScreen\n  /** Stage instances in the guild */\n  stage_instances?: DiscordStageInstance[]\n  /** Custom guild stickers */\n  stickers?: DiscordSticker[]\n  /** The id of the channel where admins and moderators of Community guilds receive safety alerts from Discord */\n  safety_alerts_channel_id: string | null\n}\n\nexport interface DiscordPartialGuild {\n  /** Guild name (2-100 characters, excluding trailing and leading whitespace) */\n  name: string\n  /** Guild id */\n  id: string\n  /** Icon hash */\n  icon: string | null\n  /** true if the user is the owner of the guild */\n  owner: boolean\n  /** Total permissions for the user in the guild (excludes overwrites and implicit permissions) */\n  permissions: string\n  /** Enabled guild features */\n  features: GuildFeatures[]\n  /** Approximate number of members in this guild, returned from the GET /guilds/id endpoint when with_counts is true */\n  approximate_member_count?: number\n  /** Approximate number of non-offline members in this guild, returned from the GET /guilds/id endpoint when with_counts is true */\n  approximate_presence_count?: number\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-structure */\nexport interface DiscordRole {\n  /** Role id */\n  id: string\n  /** If this role is showed separately in the user listing */\n  hoist: boolean\n  /** Permission bit set */\n  permissions: string\n  /** Whether this role is managed by an integration */\n  managed: boolean\n  /** Whether this role is mentionable */\n  mentionable: boolean\n  /** The tags this role has */\n  tags?: DiscordRoleTags\n  /** the role emoji hash */\n  icon?: string\n  /** Role name */\n  name: string\n  /** Integer representation of hexadecimal color code */\n  color: number\n  /** Position of this role (roles with the same position are sorted by id) */\n  position: number\n  /** role unicode emoji */\n  unicode_emoji?: string\n  /** Role flags combined as a bitfield */\n  flags: RoleFlags\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-tags-structure */\nexport interface DiscordRoleTags {\n  /** The id of the bot this role belongs to */\n  bot_id?: string\n  /** The id of the integration this role belongs to */\n  integration_id?: string\n  /** Whether this is the guild's premium subscriber role */\n  premium_subscriber?: null\n  /** Id of this role's subscription sku and listing. */\n  subscription_listing_id?: string\n  /** Whether this role is available for purchase. */\n  available_for_purchase?: null\n  /** Whether this is a guild's linked role */\n  guild_connections?: null\n}\n\n/** https://discord.com/developers/docs/resources/emoji#emoji-object-emoji-structure */\nexport interface DiscordEmoji {\n  /** Emoji name (can only be null in reaction emoji objects) */\n  name?: string\n  /** Emoji id */\n  id?: string\n  /** Roles allowed to use this emoji */\n  roles?: string[]\n  /** User that created this emoji */\n  user?: DiscordUser\n  /** Whether this emoji must be wrapped in colons */\n  require_colons?: boolean\n  /** Whether this emoji is managed */\n  managed?: boolean\n  /** Whether this emoji is animated */\n  animated?: boolean\n  /** Whether this emoji can be used, may be false due to loss of Server Boosts */\n  available?: boolean\n}\n\n/** https://discord.com/developers/docs/resources/voice#voice-state-object-voice-state-structure */\nexport interface DiscordVoiceState {\n  /** The session id for this voice state */\n  session_id: string\n  /** The guild id this voice state is for */\n  guild_id?: string\n  /** The channel id this user is connected to */\n  channel_id: string | null\n  /** The user id this voice state is for */\n  user_id: string\n  /** The guild member this voice state is for */\n  member?: DiscordMemberWithUser\n  /** Whether this user is deafened by the server */\n  deaf: boolean\n  /** Whether this user is muted by the server */\n  mute: boolean\n  /** Whether this user is locally deafened */\n  self_deaf: boolean\n  /** Whether this user is locally muted */\n  self_mute: boolean\n  /** Whether this user is streaming using \"Go Live\" */\n  self_stream?: boolean\n  /** Whether this user's camera is enabled */\n  self_video: boolean\n  /** Whether this user is muted by the current user */\n  suppress: boolean\n  /** The time at which the user requested to speak */\n  request_to_speak_timestamp: string | null\n}\n\n/** https://discord.com/developers/docs/resources/channel#channel-object */\nexport interface DiscordChannel {\n  /** The id of the channel */\n  id: string\n  /** The type of channel */\n  type: ChannelTypes\n  /** The id of the guild */\n  guild_id?: string\n  /** Sorting position of the channel (channels with the same position are sorted by id) */\n  position?: number\n  /** Explicit permission overwrites for members and roles */\n  permission_overwrites?: DiscordOverwrite[]\n  /** The name of the channel (1-100 characters) */\n  name?: string\n  /** The channel topic (0-4096 characters for GUILD_FORUM channels, 0-1024 characters for all others) */\n  topic?: string | null\n  /** Whether the channel is nsfw */\n  nsfw?: boolean\n  /** The id of the last message sent in this channel (may not point to an existing or valid message) */\n  last_message_id?: string | null\n  /** The bitrate (in bits) of the voice or stage channel */\n  bitrate?: number\n  /** The user limit of the voice or stage channel */\n  user_limit?: number\n  /** Amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission `manage_messages` or `manage_channel`, are unaffected */\n  rate_limit_per_user?: number\n  /** the recipients of the DM */\n  recipients?: DiscordUser[]\n  /** icon hash of the group DM */\n  icon?: string\n  /** Id of the creator of the thread */\n  owner_id?: string\n  /** Application id of the group DM creator if it is bot-created */\n  application_id?: string\n  /** For group DM channels: whether the channel is managed by an application via the `gdm.join` OAuth2 scope. */\n  managed?: boolean\n  /** For guild channels: Id of the parent category for a channel (each parent category can contain up to 50 channels), for threads: id of the text channel this thread was created */\n  parent_id?: string | null\n  /** When the last pinned message was pinned. This may be null in events such as GUILD_CREATE when a message is not pinned. */\n  last_pin_timestamp?: string | null\n  /** Voice region id for the voice or stage channel, automatic when set to null */\n  rtc_region?: string | null\n  /** The camera video quality mode of the voice channel, 1 when not present */\n  video_quality_mode?: VideoQualityModes\n  /** An approximate count of messages in a thread, stops counting at 50 */\n  message_count?: number\n  /** An approximate count of users in a thread, stops counting at 50 */\n  member_count?: number\n  /** Thread-specific fields not needed by other channels */\n  thread_metadata?: DiscordThreadMetadata\n  /** Thread member object for the current user, if they have joined the thread, only included on certain API endpoints */\n  member?: DiscordThreadMember\n  /** Default duration for newly created threads, in minutes, to automatically archive the thread after recent activity, can be set to: 60, 1440, 4320, 10080 */\n  default_auto_archive_duration?: number\n  /** computed permissions for the invoking user in the channel, including overwrites, only included when part of the resolved data received on a slash command interaction. This does not include implicit permissions, which may need to be checked separately. */\n  permissions?: string\n  /** The flags of the channel */\n  flags?: ChannelFlags\n  /** number of messages ever sent in a thread, it's similar to `message_count` on message creation, but will not decrement the number when a message is deleted */\n  total_message_sent?: number\n  /** The set of tags that can be used in a GUILD_FORUM channel */\n  available_tags?: DiscordForumTag[]\n  /** The IDs of the set of tags that have been applied to a thread in a GUILD_FORUM channel */\n  applied_tags: string[]\n  /** the emoji to show in the add reaction button on a thread in a GUILD_FORUM channel */\n  default_reaction_emoji?: DiscordDefaultReactionEmoji | null\n  /** the initial rate_limit_per_user to set on newly created threads in a channel. this field is copied to the thread at creation time and does not live update. */\n  default_thread_rate_limit_per_user: number\n  /** the default sort order type used to order posts in GUILD_FORUM channels. Defaults to null, which indicates a preferred sort order hasn't been set by a channel admin */\n  default_sort_order?: SortOrderTypes | null\n  /** the default forum layout view used to display posts in `GUILD_FORUM` channels. Defaults to `0`, which indicates a layout view has not been set by a channel admin */\n  default_forum_layout?: ForumLayout\n  /** When a thread is created this will be true on that channel payload for the thread. */\n  newly_created?: boolean\n}\n\n/** https://discord.com/developers/docs/topics/gateway#presence-update */\nexport interface DiscordPresenceUpdate {\n  /** Either \"idle\", \"dnd\", \"online\", or \"offline\" */\n  status: 'idle' | 'dnd' | 'online' | 'offline'\n  /** The user presence is being updated for */\n  user: DiscordUser\n  /** id of the guild */\n  guild_id: string\n  /** User's current activities */\n  activities: DiscordActivity[]\n  /** User's platform-dependent status */\n  client_status: DiscordClientStatus\n}\n\n/** https://discord.com/developers/docs/resources/guild#welcome-screen-object-welcome-screen-structure */\nexport interface DiscordWelcomeScreen {\n  /** The server description shown in the welcome screen */\n  description: string | null\n  /** The channels shown in the welcome screen, up to 5 */\n  welcome_channels: DiscordWelcomeScreenChannel[]\n}\n\n/** https://discord.com/developers/docs/resources/guild#welcome-screen-object-welcome-screen-channel-structure */\nexport interface DiscordWelcomeScreenChannel {\n  /** The description shown for the channel */\n  description: string\n  /** The channel's id */\n  channel_id: string\n  /** The emoji id, if the emoji is custom */\n  emoji_id: string | null\n  /** The emoji name if custom, the unicode character if standard, or `null` if no emoji is set */\n  emoji_name: string | null\n}\n\n/** https://discord.com/developers/docs/resources/stage-instance#auto-closing-stage-instance-structure */\nexport interface DiscordStageInstance {\n  /** The topic of the Stage instance (1-120 characters) */\n  topic: string\n  /** The id of this Stage instance */\n  id: string\n  /** The guild id of the associated Stage channel */\n  guild_id: string\n  /** The id of the associated Stage channel */\n  channel_id: string\n  /** The id of the scheduled event for this Stage instance */\n  guild_scheduled_event_id?: string\n}\n\nexport interface DiscordThreadMetadata {\n  /** Whether the thread is archived */\n  archived: boolean\n  /** Duration in minutes to automatically archive the thread after recent activity */\n  auto_archive_duration: 60 | 1440 | 4320 | 10080\n  /** When a thread is locked, only users with `MANAGE_THREADS` can unarchive it */\n  locked: boolean\n  /** whether non-moderators can add other non-moderators to a thread; only available on private threads */\n  invitable?: boolean\n  /** Timestamp when the thread's archive status was last changed, used for calculating recent activity */\n  archive_timestamp: string\n  /** Timestamp when the thread was created; only populated for threads created after 2022-01-09 */\n  create_timestamp?: string | null\n}\n\nexport interface DiscordThreadMember {\n  /** Any user-thread settings, currently only used for notifications */\n  flags: number\n  /** The id of the thread */\n  id: string\n  /** The id of the user */\n  user_id: string\n  /** The time the current user last joined the thread */\n  join_timestamp: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#activity-object */\nexport interface DiscordActivity {\n  /** The activity's name */\n  name: string\n  /** Activity type */\n  type: ActivityTypes\n  /** Stream url, is validated when type is 1 */\n  url?: string | null\n  /** Unix timestamp of when the activity was added to the user's session */\n  created_at: number\n  /** What the player is currently doing */\n  details?: string | null\n  /** The user's current party status */\n  state?: string | null\n  /** Whether or not the activity is an instanced game session */\n  instance?: boolean\n  /** Activity flags `OR`d together, describes what the payload includes */\n  flags?: number\n  /** Unix timestamps for start and/or end of the game */\n  timestamps?: DiscordActivityTimestamps\n  /** Application id for the game */\n  application_id?: string\n  /** The emoji used for a custom status */\n  emoji?: DiscordActivityEmoji | null\n  /** Information for the current party of the player */\n  party?: DiscordActivityParty\n  /** Images for the presence and their hover texts */\n  assets?: DiscordActivityAssets\n  /** Secrets for Rich Presence joining and spectating */\n  secrets?: DiscordActivitySecrets\n  /** The custom buttons shown in the Rich Presence (max 2) */\n  buttons?: DiscordActivityButton[]\n}\n\n/** https://discord.com/developers/docs/topics/gateway#client-status-object */\nexport interface DiscordClientStatus {\n  /** The user's status set for an active desktop (Windows, Linux, Mac) application session */\n  desktop?: string\n  /** The user's status set for an active mobile (iOS, Android) application session */\n  mobile?: string\n  /** The user's status set for an active web (browser, bot account) application session */\n  web?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#activity-object-activity-timestamps */\nexport interface DiscordActivityTimestamps {\n  /** Unix time (in milliseconds) of when the activity started */\n  start?: number\n  /** Unix time (in milliseconds) of when the activity ends */\n  end?: number\n}\n\n/** https://discord.com/developers/docs/topics/gateway#activity-object-activity-emoji */\nexport interface DiscordActivityEmoji {\n  /** The name of the emoji */\n  name: string\n  /** Whether this emoji is animated */\n  animated?: boolean\n  /** The id of the emoji */\n  id?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#activity-object-activity-party */\nexport interface DiscordActivityParty {\n  /** Used to show the party's current and maximum size */\n  size?: [currentSize: number, maxSize: number]\n  /** The id of the party */\n  id?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#activity-object-activity-assets */\nexport interface DiscordActivityAssets {\n  /** Text displayed when hovering over the large image of the activity */\n  large_text?: string\n  /** Text displayed when hovering over the small image of the activity */\n  small_text?: string\n  /** The id for a large asset of the activity, usually a snowflake */\n  large_image?: string\n  /** The id for a small asset of the activity, usually a snowflake */\n  small_image?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#activity-object-activity-secrets */\nexport interface DiscordActivitySecrets {\n  /** The secret for joining a party */\n  join?: string\n  /** The secret for spectating a game */\n  spectate?: string\n  /** The secret for a specific instanced match */\n  match?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#activity-object-activity-buttons */\nexport interface DiscordActivityButton {\n  /** The text shown on the button (1-32 characters) */\n  label: string\n  /** The url opened when clicking the button (1-512 characters) */\n  url: string\n}\n\nexport interface DiscordOverwrite {\n  /** Either 0 (role) or 1 (member) */\n  type: OverwriteTypes\n  /** Role or user id */\n  id: string\n  /** Permission bit set */\n  allow?: string\n  /** Permission bit set */\n  deny?: string\n}\n\nexport interface DiscordMemberWithUser extends DiscordMember {\n  /** The user object for this member */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-object */\nexport interface DiscordMessage {\n  /** id of the message */\n  id: string\n  /** id of the channel the message was sent in */\n  channel_id: string\n  /**\n   * id of the guild the message was sent in\n   * Note: For MESSAGE_CREATE and MESSAGE_UPDATE events, the message object may not contain a guild_id or member field since the events are sent directly to the receiving user and the bot who sent the message, rather than being sent through the guild like non-ephemeral messages.\n   */\n  guild_id?: string\n  /**\n   * The author of this message (not guaranteed to be a valid user)\n   * Note: The author object follows the structure of the user object, but is only a valid user in the case where the message is generated by a user or bot user. If the message is generated by a webhook, the author object corresponds to the webhook's id, username, and avatar. You can tell if a message is generated by a webhook by checking for the webhook_id on the message object.\n   */\n  author: DiscordUser\n  /**\n   * Member properties for this message's author\n   * Note: The member object exists in `MESSAGE_CREATE` and `MESSAGE_UPDATE` events from text-based guild channels. This allows bots to obtain real-time member data without requiring bots to store member state in memory.\n   */\n  member?: DiscordMember\n  /** Contents of the message */\n  content?: string\n  /** When this message was sent */\n  timestamp: string\n  /** When this message was edited (or null if never) */\n  edited_timestamp: string | null\n  /** Whether this was a TTS message */\n  tts: boolean\n  /** Whether this message mentions everyone */\n  mention_everyone: boolean\n  /**\n   * Users specifically mentioned in the message\n   * Note: The user objects in the mentions array will only have the partial member field present in `MESSAGE_CREATE` and `MESSAGE_UPDATE` events from text-based guild channels.\n   */\n  mentions: Array<DiscordUser & { member?: Partial<DiscordMember> }>\n  /** Roles specifically mentioned in this message */\n  mention_roles?: string[]\n  /**\n   * Channels specifically mentioned in this message\n   * Note: Not all channel mentions in a message will appear in `mention_channels`. Only textual channels that are visible to everyone in a discoverable guild will ever be included. Only crossposted messages (via Channel Following) currently include `mention_channels` at all. If no mentions in the message meet these requirements, this field will not be sent.\n   */\n  mention_channels?: DiscordChannelMention[]\n  /** Any attached files */\n  attachments: DiscordAttachment[]\n  /** Any embedded content */\n  embeds: DiscordEmbed[]\n  /** Reactions to the message */\n  reactions?: DiscordReaction[]\n  /** Used for validating a message was sent */\n  nonce?: number | string\n  /** Whether this message is pinned */\n  pinned: boolean\n  /** If the message is generated by a webhook, this is the webhook's id */\n  webhook_id?: string\n  /** Type of message */\n  type: MessageTypes\n  /** Sent with Rich Presence-related chat embeds */\n  activity?: DiscordMessageActivity\n  /** Sent with Rich Presence-related chat embeds */\n  application?: Partial<DiscordApplication>\n  /** if the message is an Interaction or application-owned webhook, this is the id of the application */\n  application_id?: string\n  /** Data showing the source of a crossposted channel follow add, pin or reply message */\n  message_reference?: Omit<DiscordMessageReference, 'failIfNotExists'>\n  /** Message flags combined as a bitfield */\n  flags?: MessageFlags\n  /**\n   * The stickers sent with the message (bots currently can only receive messages with stickers, not send)\n   * @deprecated\n   */\n  stickers?: DiscordSticker[]\n  /**\n   * The message associated with the `message_reference`\n   * Note: This field is only returned for messages with a `type` of `19` (REPLY). If the message is a reply but the `referenced_message` field is not present, the backend did not attempt to fetch the message that was being replied to, so its state is unknown. If the field exists but is null, the referenced message was deleted.\n   */\n  referenced_message?: DiscordMessage\n  /** sent if the message is sent as a result of an interaction */\n  interaction_metadata?: DiscordMessageInteractionMetadata\n  /**\n   * Sent if the message is a response to an Interaction\n   *\n   * @deprecated Deprecated in favor of {@link interaction_metadata}\n   */\n  interaction?: DiscordMessageInteraction\n  /** The thread that was started from this message, includes thread member object */\n  thread?: Omit<DiscordChannel, 'member'> & { member: DiscordThreadMember }\n  /** The components related to this message */\n  components?: DiscordMessageComponents\n  /** Sent if the message contains stickers */\n  sticker_items?: DiscordStickerItem[]\n  /** A generally increasing integer (there may be gaps or duplicates) that represents the approximate position of the message in a thread, it can be used to estimate the relative position of the message in a thread in company with `total_message_sent` on parent thread */\n  position?: number\n  /** The poll object */\n  poll?: DiscordPoll\n  /** The call associated with the message */\n  call?: DiscordMessageCall\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-call-object */\nexport interface DiscordMessageCall {\n  /** Array of user object ids that participated in the call */\n  participants: string[]\n  /** Time when call ended */\n  ended_timestamp: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#channel-mention-object */\nexport interface DiscordChannelMention {\n  /** id of the channel */\n  id: string\n  /** id of the guild containing the channel */\n  guild_id: string\n  /** The type of channel */\n  type: number\n  /** The name of the channel */\n  name: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#reaction-object */\nexport interface DiscordReaction {\n  /** Total number of times this emoji has been used to react (including super reacts) */\n  count: number\n  /**\tReaction count details object */\n  count_details: DiscordReactionCountDetails\n  /** Whether the current user reacted using this emoji */\n  me: boolean\n  /**\tWhether the current user super-reacted using this emoji */\n  me_burst: boolean\n  /** Emoji information */\n  emoji: Partial<DiscordEmoji>\n  /** HEX colors used for super reaction */\n  burst_colors: string[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#get-reactions-reaction-types */\nexport enum DiscordReactionType {\n  Normal,\n  Burst,\n}\n\n/** https://discord.com/developers/docs/resources/channel#reaction-count-details-object */\nexport interface DiscordReactionCountDetails {\n  /** Count of super reactions */\n  burst: number\n  /**\tCount of normal reactions */\n  normal: number\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-object-message-activity-structure */\nexport interface DiscordMessageActivity {\n  /** Type of message activity */\n  type: MessageActivityTypes\n  /** `party_id` from a Rich Presence event */\n  party_id?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-object-message-reference-structure */\nexport interface DiscordMessageReference {\n  /** id of the originating message */\n  message_id?: string\n  /**\n   * id of the originating message's channel\n   * Note: `channel_id` is optional when creating a reply, but will always be present when receiving an event/response that includes this data model.\n   */\n  channel_id?: string\n  /** id of the originating message's guild */\n  guild_id?: string\n  /** When sending, whether to error if the referenced message doesn't exist instead of sending as a normal (non-reply) message, default true */\n  fail_if_not_exists: boolean\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-object */\nexport interface DiscordPoll {\n  /** The question of the poll. Only `text` is supported. */\n  question: DiscordPollMedia\n  /** Each of the answers available in the poll. There is a maximum of 10 answers per poll. */\n  answers: DiscordPollAnswer[]\n  /**\n   * The time when the poll ends.\n   *\n   * @remarks\n   * `expiry` is marked as nullable to support non-expiring polls in the future, but all polls have an expiry currently.\n   */\n  expiry: string | null\n  /** Whether a user can select multiple answers */\n  allow_multiselect: boolean\n  /** The layout type of the poll */\n  layout_type: DiscordPollLayoutType\n  /**\n   * The results of the poll\n   *\n   * @remarks\n   * This value will not be sent by discord under specific conditions where they don't fetch them on their backend. When this value is missing it should be interpreted as \"Unknown results\" and not as \"No results\"\n   * The results may not be totally accurate while the poll has not ended. When it ends discord will re-calculate all the results and set {@link DiscordPollResult.is_finalized} to true\n   */\n  results?: DiscordPollResult\n}\n\n/** https://discord.com/developers/docs/resources/poll#layout-type */\nexport enum DiscordPollLayoutType {\n  /** The default layout */\n  Default = 1,\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-media-object */\nexport interface DiscordPollMedia {\n  /**\n   * The text of the field\n   *\n   * @remarks\n   * `text` should always be non-null for both questions and answers, but this is subject to changes.\n   * The maximum length of `text` is 300 for the question, and 55 for any answer.\n   */\n  text?: string\n  /**\n   * The emoji of the field\n   *\n   * @remarks\n   * When creating a poll answer with an emoji, one only needs to send either the `id` (custom emoji) or `name` (default emoji) as the only field.\n   */\n  emoji?: Partial<DiscordEmoji>\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-answer-object */\nexport interface DiscordPollAnswer {\n  /**\n   * The id of the answer\n   *\n   * @remarks\n   * This id labels each answer. It starts at 1 and goes up sequentially. Discord recommend against depending on this value as is a implementation detail.\n   */\n  answer_id: number\n  /** The data of the answer */\n  poll_media: DiscordPollMedia\n}\n\nexport interface DiscordPollAnswerCount {\n  /** The {@link DiscordPollAnswer.answer_id | answer_id} */\n  id: number\n  /** The number of votes for this answer */\n  count: number\n  /** Whether the current user voted for this answer */\n  me_voted: boolean\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-results-object */\nexport interface DiscordPollResult {\n  /** Whether the votes have been precisely counted */\n  is_finalized: boolean\n  /** The counts for each answer */\n  answer_counts: DiscordPollAnswerCount[]\n}\n\n/** https://discord.com/developers/docs/resources/poll#get-answer-voters-response-body */\nexport interface DiscordGetAnswerVotesResponse {\n  /** Users who voted for this answer */\n  users: DiscordUser[]\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#message-poll-vote-add */\nexport interface DiscordPollVoteAdd {\n  /** ID of the user. Usually a snowflake */\n  user_id: string\n  /** ID of the channel. Usually a snowflake */\n  channel_id: string\n  /** ID of the message. Usually a snowflake */\n  message_id: string\n  /** ID of the guild. Usually a snowflake */\n  guild_id?: string\n  /** ID of the answer. */\n  answer_id: number\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#message-poll-vote-remove */\nexport interface DiscordPollVoteRemove {\n  /** ID of the user. Usually a snowflake */\n  user_id: string\n  /** ID of the channel. Usually a snowflake */\n  channel_id: string\n  /** ID of the message. Usually a snowflake */\n  message_id: string\n  /** ID of the guild. Usually a snowflake */\n  guild_id?: string\n  /** ID of the answer. */\n  answer_id: number\n}\n\n/** https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-structure */\nexport interface DiscordSticker {\n  /** [Id of the sticker](https://discord.com/developers/docs/reference#image-formatting) */\n  id: string\n  /** Id of the pack the sticker is from */\n  pack_id?: string\n  /** Name of the sticker */\n  name: string\n  /** Description of the sticker */\n  description: string\n  /** a unicode emoji representing the sticker's expression */\n  tags: string\n  /** [type of sticker](https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-types) */\n  type: StickerTypes\n  /** [Type of sticker format](https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-format-types) */\n  format_type: StickerFormatTypes\n  /**  Whether or not the sticker is available */\n  available?: boolean\n  /** Id of the guild that owns this sticker */\n  guild_id?: string\n  /** The user that uploaded the sticker */\n  user?: DiscordUser\n  /** A sticker's sort order within a pack */\n  sort_value?: number\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#message-interaction-object-message-interaction-structure */\nexport interface DiscordMessageInteraction {\n  /** Id of the interaction */\n  id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** The name of the ApplicationCommand including the name of the subcommand/subcommand group */\n  name: string\n  /** The user who invoked the interaction */\n  user: DiscordUser\n  /** The member who invoked the interaction in the guild */\n  member?: Partial<DiscordMember>\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-interaction-metadata-object-message-interaction-metadata-structure */\nexport interface DiscordMessageInteractionMetadata {\n  /** Id of the interaction */\n  id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** User who triggered the interaction */\n  user: DiscordUser\n  /** IDs for installation context(s) related to an interaction */\n  authorizing_integration_owners: Partial<Record<`${DiscordApplicationIntegrationType}`, string>>\n  /** ID of the original response message, present only on follow-up messages */\n  original_response_message_id?: string\n  /** ID of the message that contained interactive component, present only on messages created from component interactions */\n  interacted_message_id?: string\n  /** Metadata for the interaction that was used to open the modal, present only on modal submit interactions */\n  triggering_interaction_metadata?: DiscordMessageInteractionMetadata\n}\n\nexport type DiscordMessageComponents = DiscordActionRow[]\n\n/** https://discord.com/developers/docs/interactions/message-components#actionrow */\nexport interface DiscordActionRow {\n  /** Action rows are a group of buttons. */\n  type: 1\n  /** The components in this row */\n  components: Array<DiscordSelectMenuComponent | DiscordButtonComponent | DiscordInputTextComponent>\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#select-menu-object */\nexport interface DiscordSelectMenuComponent {\n  type: MessageComponentTypes.SelectMenu\n  /** A custom identifier for this component. Maximum 100 characters. */\n  custom_id: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /** The minimum number of items that must be selected. Default 1. Between 1-25. */\n  min_values?: number\n  /** The maximum number of items that can be selected. Default 1. Between 1-25. */\n  max_values?: number\n  /** List of channel types to include in a channel select menu options list */\n  channelTypes?: ChannelTypes[]\n  /** The choices! Maximum of 25 items. */\n  options: DiscordSelectOption[]\n}\n\nexport interface DiscordSelectOption {\n  /** The user-facing name of the option. Maximum 25 characters. */\n  label: string\n  /** The dev-defined value of the option. Maximum 100 characters. */\n  value: string\n  /** An additional description of the option. Maximum 50 characters. */\n  description?: string\n  /** The id, name, and animated properties of an emoji. */\n  emoji?: {\n    /** Emoji id */\n    id?: string\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /** Will render this option as already-selected by default. */\n  default?: boolean\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#select-menu-object-select-default-value-structure */\nexport interface DiscordSelectMenuDefaultValue {\n  /** ID of a user, role, or channel */\n  id: bigint\n  /** Type of value that id represents. */\n  type: 'user' | 'role' | 'channel'\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#buttons-button-object */\nexport interface DiscordButtonComponent {\n  /** All button components have type 2 */\n  type: MessageComponentTypes.Button\n  /**\n   * Text that appears on the button\n   *\n   * @remarks\n   * A label can have a max of 80 characters\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have a label\n   */\n  label?: string\n  /**\n   * A dev-defined unique string sent on click (max 100 characters).\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Link | Link} or {@link ButtonStyles.Premium | Premium} cannot have a custom_id\n   */\n  custom_id?: string\n  /** For different styles/colors of the buttons */\n  style: ButtonStyles\n  /**\n   * Emoji object that includes fields of name, id, and animated supporting unicode and custom emojis.\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have an emoji\n   */\n  emoji?: {\n    /** Emoji id */\n    id?: string\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /**\n   * Url for {@link ButtonStyles.Link | link} buttons that can navigate a user to the web.\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Link | Link} must have an url, any other button with a different style can not have an url\n   */\n  url?: string\n  /** Whether or not this button is disabled */\n  disabled?: boolean\n  /**\n   * SKU for {@link ButtonStyles.Premium | premium} buttons that can navigate a user to the application shop.\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Premium | Premium} must have a sku_id, any other button with a different style can not have a a sku_id\n   */\n  sku_id?: string\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#text-inputs-text-input-structure */\nexport interface DiscordInputTextComponent {\n  /** InputText Component is of type 3 */\n  type: MessageComponentTypes.InputText\n  /** The style of the InputText */\n  style: TextStyles\n  /** whether this component is required to be filled, default true */\n  required?: boolean\n  /** The customId of the InputText */\n  custom_id: string\n  /** The label of the InputText (max 45 characters) */\n  label: string\n  /** The placeholder of the InputText */\n  placeholder?: string\n  /** The minimum length of the text the user has to provide */\n  min_length?: number\n  /** The maximum length of the text the user has to provide */\n  max_length?: number\n  /** Pre-filled value for input text. */\n  value?: string\n}\n\n/** https://discord.com/developers/docs/resources/sticker#sticker-item-object-sticker-item-structure */\nexport interface DiscordStickerItem {\n  /** Id of the sticker */\n  id: string\n  /** Name of the sticker */\n  name: string\n  /** [Type of sticker format](https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-format-types) */\n  format_type: StickerFormatTypes\n}\n\n/** https://discord.com/developers/docs/resources/sticker#sticker-pack-object-sticker-pack-structure */\nexport interface DiscordStickerPack {\n  /** id of the sticker pack */\n  id: string\n  /** the stickers in the pack */\n  stickers: DiscordSticker[]\n  /** name of the sticker pack */\n  name: string\n  /** id of the pack's SKU */\n  sku_id: string\n  /** id of a sticker in the pack which is shown as the pack's icon */\n  cover_sticker_id?: string\n  /** description of the sticker pack */\n  description: string\n  /** id of the sticker pack's [banner image](https://discord.com/developers/docs/reference#image-formatting) */\n  banner_asset_id?: string\n}\n\nexport interface DiscordInteraction {\n  /** Id of the interaction */\n  id: string\n  /** Id of the application this interaction is for */\n  application_id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** Guild that the interaction was sent from */\n  guild?: Partial<DiscordGuild>\n  /** The guild it was sent from */\n  guild_id?: string\n  /** The channel it was sent from */\n  channel: Partial<DiscordChannel>\n  /**\n   * The ID of channel it was sent from\n   *\n   * @remarks\n   * It is recommended that you begin using this channel field to identify the source channel of the interaction as they may deprecate the existing channel_id field in the future.\n   */\n  channel_id?: string\n  /** Guild member data for the invoking user, including permissions */\n  member?: DiscordInteractionMember\n  /** User object for the invoking user, if invoked in a DM */\n  user?: DiscordUser\n  /** A continuation token for responding to the interaction */\n  token: string\n  /** Read-only property, always `1` */\n  version: 1\n  /** For the message the button was attached to */\n  message?: DiscordMessage\n  /** the command data payload */\n  data?: DiscordInteractionData\n  /** The selected language of the invoking user */\n  locale?: string\n  /** The guild's preferred locale, if invoked in a guild */\n  guild_locale?: string\n  /** The computed permissions for a bot or app in the context of a specific interaction (including channel overwrites) */\n  app_permissions: string\n  /** For monetized apps, any entitlements for the invoking user, representing access to premium SKUs */\n  entitlements: DiscordEntitlement[]\n  /** Mapping of installation contexts that the interaction was authorized for to related user or guild IDs. */\n  authorizing_integration_owners: Partial<Record<DiscordApplicationIntegrationType, string>>\n  /** Context where the interaction was triggered from */\n  context?: DiscordInteractionContextType\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-member-object */\nexport interface DiscordInteractionMember extends DiscordMemberWithUser {\n  /** Total permissions of the member in the channel, including overwrites, returned when in the interaction object */\n  permissions: string\n}\n\nexport interface DiscordInteractionData {\n  /** The type of component */\n  component_type?: MessageComponentTypes\n  /** The custom id provided for this component. */\n  custom_id?: string\n  /** The components if its a Modal Submit interaction. */\n  components?: DiscordMessageComponents\n  /** The values chosen by the user. */\n  values?: string[]\n  /** The Id of the invoked command */\n  id: string\n  /** The name of the invoked command */\n  name: string\n  /** the type of the invoked command */\n  type: ApplicationCommandTypes\n  /** Converted users + roles + channels + attachments */\n  resolved?: {\n    /** The Ids and Message objects */\n    messages?: Record<string, DiscordMessage>\n    /** The Ids and User objects */\n    users?: Record<string, DiscordUser>\n    /** The Ids and partial Member objects */\n    members?: Record<string, Omit<DiscordInteractionMember, 'user' | 'deaf' | 'mute'>>\n    /** The Ids and Role objects */\n    roles?: Record<string, DiscordRole>\n    /** The Ids and partial Channel objects */\n    channels?: Record<string, Pick<DiscordChannel, 'id' | 'name' | 'type' | 'permissions'>>\n    /** The ids and attachment objects */\n    attachments: Record<string, DiscordAttachment>\n  }\n  /** The params + values from the user */\n  options?: DiscordInteractionDataOption[]\n  /** The target id if this is a context menu command. */\n  target_id?: string\n  /** the id of the guild the command is registered to */\n  guild_id?: string\n}\n\nexport interface DiscordInteractionDataOption {\n  /** Name of the parameter */\n  name: string\n  /** Value of application command option type */\n  type: ApplicationCommandOptionTypes\n  /** Value of the option resulting from user input */\n  value?: string | boolean | number\n  /** Present if this option is a group or subcommand */\n  options?: DiscordInteractionDataOption[]\n  /** `true` if this option is the currently focused option for autocomplete */\n  focused?: boolean\n}\n\nexport interface DiscordListActiveThreads {\n  /** The active threads */\n  threads: DiscordChannel[]\n  /** A thread member object for each returned thread the current user has joined */\n  members: DiscordThreadMember[]\n}\n\nexport interface DiscordListArchivedThreads extends DiscordListActiveThreads {\n  /** Whether there are potentially additional threads that could be returned on a subsequent call */\n  has_more: boolean\n}\n\nexport interface DiscordThreadListSync {\n  /** The id of the guild */\n  guild_id: string\n  /** The parent channel ids whose threads are being synced. If omitted, then threads were synced for the entire guild. This array may contain channelIds that have no active threads as well, so you know to clear that data */\n  channel_ids?: string[]\n  /** All active threads in the given channels that the current user can access */\n  threads: DiscordChannel[]\n  /** All thread member objects from the synced threads for the current user, indicating which threads the current user has been added to */\n  members: DiscordThreadMember[]\n}\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-object */\nexport interface DiscordAuditLog {\n  /** List of webhooks found in the audit log */\n  webhooks: DiscordWebhook[]\n  /** List of users found in the audit log */\n  users: DiscordUser[]\n  /** List of audit log entries, sorted from most to least recent */\n  audit_log_entries: DiscordAuditLogEntry[]\n  /** List of partial integration objects */\n  integrations: Array<Partial<DiscordIntegration>>\n  /**\n   * List of threads found in the audit log.\n   * Threads referenced in `THREAD_CREATE` and `THREAD_UPDATE` events are included in the threads map since archived threads might not be kept in memory by clients.\n   */\n  threads: DiscordChannel[]\n  /** List of guild scheduled events found in the audit log */\n  guild_scheduled_events?: DiscordScheduledEvent[]\n  /** List of auto moderation rules referenced in the audit log */\n  auto_moderation_rules?: DiscordAutoModerationRule[]\n  /** List of application commands referenced in the audit log */\n  application_commands: DiscordApplicationCommand[]\n}\n\n/** https://discord.com/developers/docs/resources/auto-moderation#auto-moderation-rule-object */\nexport interface DiscordAutoModerationRule {\n  /** The id of this rule */\n  id: string\n  /** The guild id of the rule */\n  guild_id: string\n  /** The name of the rule */\n  name: string\n  /** The id of the user who created this rule. */\n  creator_id: string\n  /** Indicates in what event context a rule should be checked. */\n  event_type: AutoModerationEventTypes\n  /** The type of trigger for this rule */\n  trigger_type: AutoModerationTriggerTypes\n  /** The metadata used to determine whether a rule should be triggered. */\n  trigger_metadata: DiscordAutoModerationRuleTriggerMetadata\n  /** Actions which will execute whenever a rule is triggered. */\n  actions: DiscordAutoModerationAction[]\n  /** Whether the rule is enabled. */\n  enabled: boolean\n  /** The role ids that are whitelisted. Max 20. */\n  exempt_roles: string[]\n  /** The channel ids that are whitelisted. Max 50. */\n  exempt_channels: string[]\n}\n\nexport enum AutoModerationEventTypes {\n  /** When a user sends a message */\n  MessageSend = 1,\n  /** Wen a member edits their profile */\n  MemberUpdate,\n}\n\nexport enum AutoModerationTriggerTypes {\n  /** Check if content contains words from a user defined list of keywords. Max 6 per guild */\n  Keyword = 1,\n  /** Check if content represents generic spam. Max 1 per guild */\n  Spam = 3,\n  /** Check if content contains words from internal pre-defined word sets. Max 1 per guild */\n  KeywordPreset,\n  /** Check if content contains more unique mentions than allowed. Max 1 per guild */\n  MentionSpam,\n  /** Check if member profile contains words from a user defined list of keywords. Max 1 per guild */\n  MemberProfile,\n}\n\nexport interface DiscordAutoModerationRuleTriggerMetadata {\n  /**\n   * The keywords needed to match.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MemberProfile}.\n   *\n   * Can have up to 1000 elements in the array and each string can have up to 60 characters\n   */\n  keyword_filter?: string[]\n  /**\n   * Regular expression patterns which will be matched against content.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MemberProfile}.\n   *\n   * Can have up to 10 elements in the array and each string can have up to 260 characters\n   */\n  regex_patterns: string[]\n  /**\n   * The pre-defined lists of words to match from.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.KeywordPreset}.\n   */\n  presets?: DiscordAutoModerationRuleTriggerMetadataPresets[]\n  /**\n   * The substrings which will exempt from triggering the preset trigger type.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.Keyword}, {@link AutoModerationTriggerTypes.KeywordPreset} and {@link AutoModerationTriggerTypes.MemberProfile}.\n   *\n   * When used with {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MemberProfile} there can have up to 100 elements in the array and each string can have up to 60 characters.\n   * When used with {@link AutoModerationTriggerTypes.KeywordPreset} there can have up to 1000 elements in the array and each string can have up to 60 characters.\n   */\n  allow_list?: string[]\n  /**\n   * Total number of mentions (role & user) allowed per message.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.MentionSpam}.\n   *\n   * Maximum of 50\n   */\n  mention_total_limit?: number\n  /**\n   * Whether to automatically detect mention raids.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.MentionSpam}.\n   */\n  mention_raid_protection_enabled?: boolean\n}\n\nexport enum DiscordAutoModerationRuleTriggerMetadataPresets {\n  /** Words that may be considered forms of swearing or cursing */\n  Profanity = 1,\n  /** Words that refer to sexually explicit behavior or activity */\n  SexualContent,\n  /** Personal insults or words that may be considered hate speech */\n  Slurs,\n}\n\nexport interface DiscordAutoModerationAction {\n  /** The type of action to take when a rule is triggered */\n  type: AutoModerationActionType\n  /** additional metadata needed during execution for this specific action type */\n  metadata: DiscordAutoModerationActionMetadata\n}\n\nexport enum AutoModerationActionType {\n  /** Blocks the content of a message according to the rule */\n  BlockMessage = 1,\n  /** Logs user content to a specified channel */\n  SendAlertMessage,\n  /**\n   * Times out user for specified duration\n   *\n   * @remarks\n   * A timeout action can only be set up for {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MentionSpam} rules.\n   *\n   * The `MODERATE_MEMBERS` permission is required to use the timeout action type.\n   */\n  Timeout,\n  /** prevents a member from using text, voice, or other interactions */\n  BlockMemberInteraction,\n}\n\nexport interface DiscordAutoModerationActionMetadata {\n  /** The id of channel to which user content should be logged. Only in ActionType.SendAlertMessage */\n  channel_id?: string\n  /** Additional explanation that will be shown to members whenever their message is blocked. Maximum of 150 characters. Only supported for AutoModerationActionType.BlockMessage */\n  custom_message?: string\n  /** Timeout duration in seconds maximum of 2419200 seconds (4 weeks). Only supported for TriggerType.Keyword && Only in ActionType.Timeout */\n  duration_seconds?: number\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#auto-moderation-action-execution-auto-moderation-action-execution-event-fields */\nexport interface DiscordAutoModerationActionExecution {\n  /** The id of the guild */\n  guild_id: string\n  /** The id of the rule that was executed */\n  rule_id: string\n  /** The id of the user which generated the content which triggered the rule */\n  user_id: string\n  /** The content from the user */\n  content: string\n  /** Action which was executed */\n  action: DiscordAutoModerationAction\n  /** The trigger type of the rule that was executed. */\n  rule_trigger_type: AutoModerationTriggerTypes\n  /** The id of the channel in which user content was posted */\n  channel_id?: string | null\n  /** The id of the message. Will not exist if message was blocked by automod or content was not part of any message */\n  message_id?: string | null\n  /** The id of any system auto moderation messages posted as a result of this action */\n  alert_system_message_id?: string | null\n  /** The word or phrase that triggerred the rule. */\n  matched_keyword: string | null\n  /** The substring in content that triggered the rule */\n  matched_content: string | null\n}\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-entry-object-audit-log-entry-structure */\nexport interface DiscordAuditLogEntry {\n  /** ID of the affected entity (webhook, user, role, etc.) */\n  target_id: string | null\n  /** Changes made to the `target_id` */\n  changes?: DiscordAuditLogChange[]\n  /** User or app that made the changes */\n  user_id: string | null\n  /** ID of the entry */\n  id: string\n  /** Type of action that occurred */\n  action_type: AuditLogEvents\n  /** Additional info for certain event types */\n  options?: DiscordOptionalAuditEntryInfo\n  /** Reason for the change (1-512 characters) */\n  reason?: string\n}\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-change-object-audit-log-change-structure */\nexport type DiscordAuditLogChange =\n  | {\n      new_value: string\n      old_value: string\n      key:\n        | 'name'\n        | 'description'\n        | 'discovery_splash_hash'\n        | 'banner_hash'\n        | 'preferred_locale'\n        | 'rules_channel_id'\n        | 'public_updates_channel_id'\n        | 'icon_hash'\n        | 'image_hash'\n        | 'splash_hash'\n        | 'owner_id'\n        | 'region'\n        | 'afk_channel_id'\n        | 'vanity_url_code'\n        | 'widget_channel_id'\n        | 'system_channel_id'\n        | 'topic'\n        | 'application_id'\n        | 'permissions'\n        | 'allow'\n        | 'deny'\n        | 'code'\n        | 'channel_id'\n        | 'inviter_id'\n        | 'nick'\n        | 'avatar_hash'\n        | 'id'\n        | 'location'\n        | 'command_id'\n    }\n  | {\n      new_value: number\n      old_value: number\n      key:\n        | 'afk_timeout'\n        | 'mfa_level'\n        | 'verification_level'\n        | 'explicit_content_filter'\n        | 'default_message_notifications'\n        | 'prune_delete_days'\n        | 'position'\n        | 'bitrate'\n        | 'rate_limit_per_user'\n        | 'color'\n        | 'max_uses'\n        | 'uses'\n        | 'max_age'\n        | 'expire_behavior'\n        | 'expire_grace_period'\n        | 'user_limit'\n        | 'privacy_level'\n        | 'auto_archive_duration'\n        | 'default_auto_archive_duration'\n        | 'entity_type'\n        | 'status'\n        | 'communication_disabled_until'\n    }\n  | {\n      new_value: Array<Partial<DiscordRole>>\n      old_value?: Array<Partial<DiscordRole>>\n      key: '$add' | '$remove'\n    }\n  | {\n      new_value: boolean\n      old_value: boolean\n      key:\n        | 'widget_enabled'\n        | 'nsfw'\n        | 'hoist'\n        | 'mentionable'\n        | 'temporary'\n        | 'deaf'\n        | 'mute'\n        | 'enable_emoticons'\n        | 'archived'\n        | 'locked'\n        | 'invitable'\n    }\n  | {\n      new_value: DiscordOverwrite[]\n      old_value: DiscordOverwrite[]\n      key: 'permission_overwrites'\n    }\n  | {\n      new_value: string | number\n      old_value: string | number\n      key: 'type'\n    }\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-entry-object-optional-audit-entry-info */\nexport interface DiscordOptionalAuditEntryInfo {\n  /**\n   * ID of the app whose permissions were targeted.\n   *\n   * Event types: `APPLICATION_COMMAND_PERMISSION_UPDATE`\n   */\n  application_id: string\n  /**\n   * Name of the Auto Moderation rule that was triggered.\n   *\n   * Event types: `AUTO_MODERATION_BLOCK_MESSAGE`, `AUTO_MODERATION_FLAG_TO_CHANNEL`, `AUTO_MODERATION_USER_COMMUNICATION_DISABLED`\n   */\n  auto_moderation_rule_name: string\n  /**\n   * Trigger type of the Auto Moderation rule that was triggered.\n   *\n   * Event types: `AUTO_MODERATION_BLOCK_MESSAGE`, `AUTO_MODERATION_FLAG_TO_CHANNEL`, `AUTO_MODERATION_USER_COMMUNICATION_DISABLED`\n   */\n  auto_moderation_rule_trigger_type: string\n  /**\n   * Channel in which the entities were targeted.\n   *\n   * Event types: `MEMBER_MOVE`, `MESSAGE_PIN`, `MESSAGE_UNPIN`, `MESSAGE_DELETE`, `STAGE_INSTANCE_CREATE`, `STAGE_INSTANCE_UPDATE`, `STAGE_INSTANCE_DELETE`\n   */\n  channel_id: string\n  /**\n   * Number of entities that were targeted.\n   *\n   * Event types: `MESSAGE_DELETE`, `MESSAGE_BULK_DELETE`, `MEMBER_DISCONNECT`, `MEMBER_MOVE`\n   */\n  count: string\n  /**\n   * Number of days after which inactive members were kicked.\n   *\n   * Event types: `MEMBER_PRUNE`\n   */\n  delete_member_days: string\n  /**\n   * ID of the overwritten entity.\n   *\n   * Event types: `CHANNEL_OVERWRITE_CREATE`, `CHANNEL_OVERWRITE_UPDATE`, `CHANNEL_OVERWRITE_DELETE`\n   */\n  id: string\n  /**\n   * Number of members removed by the prune.\n   *\n   * Event types: `MEMBER_PRUNE`\n   */\n  members_removed: string\n  /**\n   * ID of the message that was targeted.\n   *\n   * Event types: `MESSAGE_PIN`, `MESSAGE_UNPIN`, `STAGE_INSTANCE_CREATE`, `STAGE_INSTANCE_UPDATE`, `STAGE_INSTANCE_DELETE`\n   */\n  message_id: string\n  /**\n   * Name of the role if type is \"0\" (not present if type is \"1\").\n   *\n   * Event types: `CHANNEL_OVERWRITE_CREATE`, `CHANNEL_OVERWRITE_UPDATE`, `CHANNEL_OVERWRITE_DELETE`\n   */\n  role_name: string\n  /**\n   * Type of overwritten entity - \"0\", for \"role\", or \"1\" for \"member\".\n   *\n   * Event types: `CHANNEL_OVERWRITE_CREATE`, `CHANNEL_OVERWRITE_UPDATE`, `CHANNEL_OVERWRITE_DELETE`\n   */\n  type: string\n  /**\n   * The type of integration which performed the action\n   *\n   * Event types: `MEMBER_KICK`, `MEMBER_ROLE_UPDATE`\n   */\n  integration_type: string\n}\n\nexport interface DiscordScheduledEvent {\n  /** the id of the scheduled event */\n  id: string\n  /** the guild id which the scheduled event belongs to */\n  guild_id: string\n  /** the channel id in which the scheduled event will be hosted if specified */\n  channel_id: string | null\n  /** the id of the user that created the scheduled event */\n  creator_id?: string | null\n  /** the name of the scheduled event */\n  name: string\n  /** the description of the scheduled event */\n  description?: string\n  /** the time the scheduled event will start */\n  scheduled_start_time: string\n  /** the time the scheduled event will end if it does end. */\n  scheduled_end_time: string | null\n  /** the privacy level of the scheduled event */\n  privacy_level: ScheduledEventPrivacyLevel\n  /** the status of the scheduled event */\n  status: ScheduledEventStatus\n  /** the type of hosting entity associated with a scheduled event */\n  entity_type: ScheduledEventEntityType\n  /** any additional id of the hosting entity associated with event */\n  entity_id: string | null\n  /** the entity metadata for the scheduled event */\n  entity_metadata: DiscordScheduledEventEntityMetadata | null\n  /** the user that created the scheduled event */\n  creator?: DiscordUser\n  /** the number of users subscribed to the scheduled event */\n  user_count?: number\n  /** the cover image hash of the scheduled event */\n  image?: string | null\n}\n\nexport interface DiscordScheduledEventEntityMetadata {\n  /** location of the event */\n  location?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#get-gateway-bot */\nexport interface DiscordGetGatewayBot {\n  /** The WSS URL that can be used for connecting to the gateway */\n  url: string\n  /** The recommended number of shards to use when connecting */\n  shards: number\n  /** Information on the current session start limit */\n  session_start_limit: DiscordSessionStartLimit\n}\n\n/** https://discord.com/developers/docs/topics/gateway#session-start-limit-object */\nexport interface DiscordSessionStartLimit {\n  /** The total number of session starts the current user is allowed */\n  total: number\n  /** The remaining number of session starts the current user is allowed */\n  remaining: number\n  /** The number of milliseconds after which the limit resets */\n  reset_after: number\n  /** The number of identify requests allowed per 5 seconds */\n  max_concurrency: number\n}\n\n/** https://discord.com/developers/docs/resources/invite#invite-metadata-object */\nexport interface DiscordInviteMetadata extends DiscordInvite {\n  /** Number of times this invite has been used */\n  uses: number\n  /** Max number of times this invite can be used */\n  max_uses: number\n  /** Duration (in seconds) after which the invite expires */\n  max_age: number\n  /** Whether this invite only grants temporary membership */\n  temporary: boolean\n  /** When this invite was created */\n  created_at: string\n}\n\n/** https://discord.com/developers/docs/resources/invite#invite-object */\nexport interface DiscordInvite {\n  /** The type of invite */\n  type: DiscordInviteType\n  /** The invite code (unique Id) */\n  code: string\n  /** The guild this invite is for */\n  guild?: Partial<DiscordGuild>\n  /** The channel this invite is for */\n  channel: Partial<DiscordChannel> | null\n  /** The user who created the invite */\n  inviter?: DiscordUser\n  /** The type of target for this voice channel invite */\n  target_type?: TargetTypes\n  /** The target user for this invite */\n  target_user?: DiscordUser\n  /** The embedded application to open for this voice channel embedded application invite */\n  target_application?: Partial<DiscordApplication>\n  /** Approximate count of online members (only present when target_user is set) */\n  approximate_presence_count?: number\n  /** Approximate count of total members */\n  approximate_member_count?: number\n  /** The expiration date of this invite, returned from the `GET /invites/<code>` endpoint when `with_expiration` is `true` */\n  expires_at?: string | null\n  /** Stage instance data if there is a public Stage instance in the Stage channel this invite is for */\n  stage_instance?: DiscordInviteStageInstance\n  /** guild scheduled event data */\n  guild_scheduled_event?: DiscordScheduledEvent\n}\n\nexport enum DiscordInviteType {\n  Guild,\n  GroupDm,\n  Friend,\n}\n\nexport interface DiscordInviteStageInstance {\n  /** The members speaking in the Stage */\n  members: Array<Partial<DiscordMember>>\n  /** The number of users in the Stage */\n  participant_count: number\n  /** The number of users speaking in the Stage */\n  speaker_count: number\n  /** The topic of the Stage instance (1-120 characters) */\n  topic: string\n}\n\n/** https://discord.com/developers/docs/interactions/application-commands#application-command-object-application-command-structure */\nexport interface DiscordApplicationCommand extends DiscordCreateApplicationCommand {\n  /** Unique ID of command */\n  id: string\n  /** ID of the parent application */\n  application_id: string\n  /** Guild id of the command, if not global */\n  guild_id?: string\n}\n\nexport interface DiscordCreateApplicationCommand {\n  /** Type of command, defaults to `ApplicationCommandTypes.ChatInput` */\n  type?: ApplicationCommandTypes\n  /**\n   * Name of command, 1-32 characters.\n   * `ApplicationCommandTypes.ChatInput` command names must match the following regex `^[-_\\p{L}\\p{N}\\p{sc=Deva}\\p{sc=Thai}]{1,32}$` with the unicode flag set.\n   * If there is a lowercase variant of any letters used, you must use those.\n   * Characters with no lowercase variants and/or uncased letters are still allowed.\n   * ApplicationCommandTypes.User` and `ApplicationCommandTypes.Message` commands may be mixed case and can include spaces.\n   */\n  name: string\n  /** Localization object for `name` field. Values follow the same restrictions as `name` */\n  name_localizations?: Localization | null\n  /** Description for `ApplicationCommandTypes.ChatInput` commands, 1-100 characters. */\n  description?: string\n  /** Localization object for `description` field. Values follow the same restrictions as `description` */\n  description_localizations?: Localization | null\n  /** Parameters for the command, max of 25 */\n  options?: DiscordApplicationCommandOption[]\n  /** Set of permissions represented as a bit set */\n  default_member_permissions?: string | null\n  /**\n   * Installation contexts where the command is available\n   *\n   * @remarks\n   * This value is available only for globally-scoped commands\n   * Defaults to the application configured contexts\n   */\n  integration_types?: DiscordApplicationIntegrationType[]\n  /**\n   * Interaction context(s) where the command can be used\n   *\n   * @remarks\n   * This value is available only for globally-scoped commands\n   * By default, all interaction context types included for new commands.\n   */\n  contexts?: DiscordInteractionContextType[] | null\n  /**\n   * Indicates whether the command is available in DMs with the app, only for globally-scoped commands. By default, commands are visible.\n   *\n   * @deprecated use {@link contexts} instead\n   */\n  dm_permission?: boolean\n  /** Indicates whether the command is age-restricted, defaults to false */\n  nsfw?: boolean\n  /** Auto incrementing version identifier updated during substantial record changes */\n  version?: string\n}\n\n/** https://discord.com/developers/docs/interactions/application-commands#application-command-object-application-command-option-structure */\nexport interface DiscordApplicationCommandOption {\n  /** Type of option */\n  type: ApplicationCommandOptionTypes\n  /**\n   * Name of command, 1-32 characters.\n   *\n   * @remarks\n   * This value should be unique within an array of {@link DiscordApplicationCommandOption}\n   *\n   * {@link ApplicationCommandTypes.ChatInput | ChatInput} command names must match the following regex `^[-_\\p{L}\\p{N}\\p{sc=Deva}\\p{sc=Thai}]{1,32}$` with the unicode flag set.\n   * If there is a lowercase variant of any letters used, you must use those.\n   * Characters with no lowercase variants and/or uncased letters are still allowed.\n   *\n   * {@link ApplicationCommandTypes.User | User} and {@link ApplicationCommandTypes.Message | Message} commands may be mixed case and can include spaces.\n   */\n  name: string\n  /** Localization object for the `name` field. Values follow the same restrictions as `name` */\n  name_localizations?: Localization | null\n  /** 1-100 character description */\n  description: string\n  /** Localization object for the `description` field. Values follow the same restrictions as `description` */\n  description_localizations?: Localization | null\n  /**\n   * If the parameter is required or optional. default `false`\n   *\n   * @remarks\n   * Valid in all option types except {@link ApplicationCommandOptionTypes.SubCommand | SubCommand} and {@link ApplicationCommandOptionTypes.SubCommandGroup | SubCommandGroup}\n   */\n  required?: boolean\n  /**\n   * Choices for the option from which the user can choose, max 25\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}, {@link ApplicationCommandOptionTypes.Integer | Integer}, or {@link ApplicationCommandOptionTypes.Number | Number}\n   *\n   * If you provide an array of choices, they will be the ONLY accepted values for this option\n   */\n  choices?: DiscordApplicationCommandOptionChoice[]\n  /**\n   * If the option is a subcommand or subcommand group type, these nested options will be the parameters\n   *\n   * @remarks\n   * Only valid in option of type {@link ApplicationCommandOptionTypes.SubCommand | SubCommand} or {@link ApplicationCommandOptionTypes.SubCommandGroup | SubCommandGroup}\n   */\n  options?: DiscordApplicationCommandOption[]\n  /**\n   * If autocomplete interactions are enabled for this option.\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}, {@link ApplicationCommandOptionTypes.Integer | Integer}, or {@link ApplicationCommandOptionTypes.Number | Number}\n   *\n   * When {@link DiscordApplicationCommandOption.choices | choices} are provided, this may not be set to true\n   */\n  autocomplete?: boolean\n  /**\n   * The channels shown will be restricted to these types\n   *\n   * @remarks\n   * Only valid in option of type {@link ApplicationCommandOptionTypes.Channel | Channel}\n   */\n  channel_types?: ChannelTypes[]\n  /**\n   * The minimum permitted value\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.Integer | Integer} or {@link ApplicationCommandOptionTypes.Number | Number}\n   */\n  min_value?: number\n  /**\n   * The maximum permitted value\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.Integer | Integer} or {@link ApplicationCommandOptionTypes.Number | Number}\n   */\n  max_value?: number\n  /**\n   * The minimum permitted length, should be in the range of from 0 to 600\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}\n   */\n  min_length?: number\n  /**\n   * The maximum permitted length, should be in the range of from 0 to 600\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}\n   */\n  max_length?: number\n}\n\n/** https://discord.com/developers/docs/interactions/application-commands#application-command-permissions-object */\nexport interface DiscordApplicationCommandOptionChoice {\n  /** 1-100 character choice name */\n  name: string\n  /** Localization object for the `name` field. Values follow the same restrictions as `name` */\n  name_localizations?: Localization | null\n  /** Value for the choice, up to 100 characters if string */\n  value: string | number\n}\n\n/** https://discord.com/developers/docs/interactions/slash-commands#guildapplicationcommandpermissions */\nexport interface DiscordGuildApplicationCommandPermissions {\n  /** ID of the command or the application ID. When the `id` field is the application ID instead of a command ID, the permissions apply to all commands that do not contain explicit overwrites. */\n  id: string\n  /** ID of the application the command belongs to */\n  application_id: string\n  /** ID of the guild */\n  guild_id: string\n  /** Permissions for the command in the guild, max of 100 */\n  permissions: DiscordApplicationCommandPermissions[]\n}\n\n/** https://discord.com/developers/docs/interactions/slash-commands#applicationcommandpermissions */\nexport interface DiscordApplicationCommandPermissions {\n  /** ID of the role, user, or channel. It can also be a permission constant */\n  id: string\n  /** ApplicationCommandPermissionTypes.Role, ApplicationCommandPermissionTypes.User, or ApplicationCommandPermissionTypes.Channel */\n  type: ApplicationCommandPermissionTypes\n  /** `true` to allow, `false`, to disallow */\n  permission: boolean\n}\n\n/** https://discord.com/developers/docs/resources/guild#get-guild-widget-example-get-guild-widget */\nexport interface DiscordGuildWidget {\n  id: string\n  name: string\n  instant_invite: string\n  channels: Array<{\n    id: string\n    name: string\n    position: number\n  }>\n  members: Array<{\n    id: string\n    username: string\n    discriminator: string\n    avatar?: string | null\n    status: string\n    avatar_url: string\n  }>\n  presence_count: number\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-preview-object */\nexport interface DiscordGuildPreview {\n  /** Guild id */\n  id: string\n  /** Guild name (2-100 characters) */\n  name: string\n  /** Icon hash */\n  icon: string | null\n  /** Splash hash */\n  splash: string | null\n  /** Discovery splash hash */\n  discovery_splash: string | null\n  /** Custom guild emojis */\n  emojis: DiscordEmoji[]\n  /** Enabled guild features */\n  features: GuildFeatures[]\n  /** Approximate number of members in this guild */\n  approximate_member_count: number\n  /** Approximate number of online members in this guild */\n  approximate_presence_count: number\n  /** The description for the guild, if the guild is discoverable */\n  description: string | null\n  /** Custom guild stickers */\n  stickers: DiscordSticker[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#followed-channel-object */\nexport interface DiscordFollowedChannel {\n  /** Source message id */\n  channel_id: string\n  /** Created target webhook id */\n  webhook_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#payloads-gateway-payload-structure */\nexport interface DiscordGatewayPayload {\n  /** opcode for the payload */\n  op: number\n  /** Event data */\n  d: unknown | null\n  /** Sequence number, used for resuming sessions and heartbeats */\n  s: number | null\n  /** The event name for this payload */\n  t: GatewayEventNames | null\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-members-chunk */\nexport interface DiscordGuildMembersChunk {\n  /** The id of the guild */\n  guild_id: string\n  /** Set of guild members */\n  members: DiscordMemberWithUser[]\n  /** The chunk index in the expected chunks for this response (0 <= chunk_index < chunk_count) */\n  chunk_index: number\n  /** The total number of expected chunks for this response */\n  chunk_count: number\n  /** If passing an invalid id to `REQUEST_GUILD_MEMBERS`, it will be returned here */\n  not_found?: string[]\n  /** If passing true to `REQUEST_GUILD_MEMBERS`, presences of the returned members will be here */\n  presences?: DiscordPresenceUpdate[]\n  /** The nonce used in the Guild Members Request */\n  nonce?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#channel-pins-update */\nexport interface DiscordChannelPinsUpdate {\n  /** The id of the guild */\n  guild_id?: string\n  /** The id of the channel */\n  channel_id: string\n  /** The time at which the most recent pinned message was pinned */\n  last_pin_timestamp?: string | null\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-role-delete */\nexport interface DiscordGuildRoleDelete {\n  /** id of the guild */\n  guild_id: string\n  /** id of the role */\n  role_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-ban-add */\nexport interface DiscordGuildBanAddRemove {\n  /** id of the guild */\n  guild_id: string\n  /** The banned user */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/topics/gateway#message-reaction-remove */\nexport interface DiscordMessageReactionRemove extends Omit<DiscordMessageReactionAdd, 'member' | 'burst_colors'> {}\n\n/** https://discord.com/developers/docs/topics/gateway#message-reaction-add */\nexport interface DiscordMessageReactionAdd {\n  /** The id of the user */\n  user_id: string\n  /** The id of the channel */\n  channel_id: string\n  /** The id of the message */\n  message_id: string\n  /** The id of the guild */\n  guild_id?: string\n  /** The member who reacted if this happened in a guild */\n  member?: DiscordMemberWithUser\n  /** The emoji used to react */\n  emoji: Partial<DiscordEmoji>\n  /** The id of the author of this message */\n  message_author_id?: string\n  /** true if this is a super-reaction */\n  burst: boolean\n  /** Colors used for super-reaction animation in \"#rrggbb\" format */\n  burst_colors?: string[]\n  /** The type of reaction */\n  type: DiscordReactionType\n}\n\n/** https://discord.com/developers/docs/topics/gateway#voice-server-update */\nexport interface DiscordVoiceServerUpdate {\n  /** Voice connection token */\n  token: string\n  /** The guild this voice server update is for */\n  guild_id: string\n  /** The voice server host */\n  endpoint: string | null\n}\n\n/** https://discord.com/developers/docs/topics/gateway#invite-create */\nexport interface DiscordInviteCreate {\n  /** The channel the invite is for */\n  channel_id: string\n  /** The unique invite code */\n  code: string\n  /** The time at which the invite was created */\n  created_at: string\n  /** The guild of the invite */\n  guild_id?: string\n  /** The user that created the invite */\n  inviter?: DiscordUser\n  /** How long the invite is valid for (in seconds) */\n  max_age: number\n  /** The maximum number of times the invite can be used */\n  max_uses: number\n  /** The type of target for this voice channel invite */\n  target_type: TargetTypes\n  /** The target user for this invite */\n  target_user?: DiscordUser\n  /** The embedded application to open for this voice channel embedded application invite */\n  target_application?: Partial<DiscordApplication>\n  /** Whether or not the invite is temporary (invited users will be kicked on disconnect unless they're assigned a role) */\n  temporary: boolean\n  /** How many times the invite has been used (always will be 0) */\n  uses: number\n}\n\n/** https://discord.com/developers/docs/topics/gateway#hello */\nexport interface DiscordHello {\n  /** The interval (in milliseconds) the client should heartbeat with */\n  heartbeat_interval: number\n}\n\n/** https://discord.com/developers/docs/topics/gateway#ready */\nexport interface DiscordReady {\n  /** Gateway version */\n  v: number\n  /** Information about the user including email */\n  user: DiscordUser\n  /** The guilds the user is in */\n  guilds: DiscordUnavailableGuild[]\n  /** Used for resuming connections */\n  session_id: string\n  /** Gateway url for resuming connections */\n  resume_gateway_url: string\n  /** The shard information associated with this session, if sent when identifying */\n  shard?: [number, number]\n  /** Contains id and flags */\n  application: Partial<DiscordApplication> & Pick<DiscordApplication, 'id' | 'flags'>\n}\n\n/** https://discord.com/developers/docs/resources/guild#unavailable-guild-object */\nexport interface DiscordUnavailableGuild extends Pick<DiscordGuild, 'id' | 'unavailable'> {}\n\n/** https://discord.com/developers/docs/topics/gateway#message-delete-bulk */\nexport interface DiscordMessageDeleteBulk {\n  /** The ids of the messages */\n  ids: string[]\n  /** The id of the channel */\n  channel_id: string\n  /** The id of the guild */\n  guild_id?: string\n}\n\n/** https://discord.com/developers/docs/resources/template#template-object-template-structure */\nexport interface DiscordTemplate {\n  /** The template code (unique Id) */\n  code: string\n  /** Template name */\n  name: string\n  /** The description for the template */\n  description: string | null\n  /** Number of times this template has been used */\n  usage_count: number\n  /** The Id of the user who created the template */\n  creator_id: string\n  /** The user who created the template */\n  creator: DiscordUser\n  /** When this template was created */\n  created_at: string\n  /** When this template was last synced to the source guild */\n  updated_at: string\n  /** The Id of the guild this template is based on */\n  source_guild_id: string\n  /** The guild snapshot this template contains */\n  serialized_source_guild: Omit<\n    PickPartial<\n      DiscordGuild,\n      | 'name'\n      | 'description'\n      | 'verification_level'\n      | 'default_message_notifications'\n      | 'explicit_content_filter'\n      | 'preferred_locale'\n      | 'afk_timeout'\n      | 'channels'\n      | 'afk_channel_id'\n      | 'system_channel_id'\n      | 'system_channel_flags'\n    >,\n    'roles'\n  > & {\n    roles: Array<\n      Omit<PickPartial<DiscordRole, 'name' | 'color' | 'hoist' | 'mentionable' | 'permissions' | 'icon' | 'unicode_emoji'>, 'id'> & { id: number }\n    >\n  }\n  /** Whether the template has un-synced changes */\n  is_dirty: boolean | null\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-member-add */\nexport interface DiscordGuildMemberAdd extends DiscordMemberWithUser {\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#message-delete */\nexport interface DiscordMessageDelete {\n  /** The id of the message */\n  id: string\n  /** The id of the channel */\n  channel_id: string\n  /** The id of the guild */\n  guild_id?: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#thread-members-update-thread-members-update-event-fields */\nexport interface DiscordThreadMembersUpdate {\n  /** The id of the thread */\n  id: string\n  /** The id of the guild */\n  guild_id: string\n  /** The users who were added to the thread */\n  added_members?: DiscordThreadMember[]\n  /** The id of the users who were removed from the thread */\n  removed_member_ids?: string[]\n  /** the approximate number of members in the thread, capped at 50 */\n  member_count: number\n}\n\n/** https://discord.com/developers/docs/topics/gateway#thread-member-update */\nexport interface DiscordThreadMemberUpdate {\n  /** The id of the thread */\n  id: string\n  /** The id of the guild */\n  guild_id: string\n  /** The timestamp when the bot joined this thread. */\n  joined_at: string\n  /** The flags this user has for this thread. Not useful for bots. */\n  flags: number\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-role-create */\nexport interface DiscordGuildRoleCreate {\n  /** The id of the guild */\n  guild_id: string\n  /** The role created */\n  role: DiscordRole\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-emojis-update */\nexport interface DiscordGuildEmojisUpdate {\n  /** id of the guild */\n  guild_id: string\n  /** Array of emojis */\n  emojis: DiscordEmoji[]\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#guild-stickers-update */\nexport interface DiscordGuildStickersUpdate {\n  /** id of the guild */\n  guild_id: string\n  /** Array of sticker */\n  stickers: DiscordSticker[]\n}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-member-update */\nexport interface DiscordGuildMemberUpdate {\n  /** The id of the guild */\n  guild_id: string\n  /** User role ids */\n  roles: string[]\n  /** The user */\n  user: DiscordUser\n  /** Nickname of the user in the guild */\n  nick?: string | null\n  /** the member's [guild avatar hash](https://discord.com/developers/docs/reference#image-formatting) */\n  avatar: string\n  /** When the user joined the guild */\n  joined_at: string\n  /** When the user starting boosting the guild */\n  premium_since?: string | null\n  /** whether the user is deafened in voice channels */\n  deaf?: boolean\n  /** whether the user is muted in voice channels */\n  mute?: boolean\n  /** Whether the user has not yet passed the guild's Membership Screening requirements */\n  pending?: boolean\n  /** when the user's [timeout](https://support.discord.com/hc/en-us/articles/4413305239191-Time-Out-FAQ) will expire and the user will be able to communicate in the guild again, null or a time in the past if the user is not timed out. Will throw a 403 error if the user has the ADMINISTRATOR permission or is the owner of the guild */\n  communication_disabled_until?: string\n  /** Data for the member's guild avatar decoration */\n  avatar_decoration_data?: DiscordAvatarDecorationData\n}\n\n/** https://discord.com/developers/docs/topics/gateway#message-reaction-remove-all */\nexport interface DiscordMessageReactionRemoveAll extends Pick<DiscordMessageReactionAdd, 'channel_id' | 'message_id' | 'guild_id'> {}\n\n/** https://discord.com/developers/docs/topics/gateway#guild-role-update */\nexport interface DiscordGuildRoleUpdate {\n  /** The id of the guild */\n  guild_id: string\n  /** The role updated */\n  role: DiscordRole\n}\n\nexport interface DiscordScheduledEventUserAdd {\n  /** id of the guild scheduled event  */\n  guild_scheduled_event_id: string\n  /** id of the user                   */\n  user_id: string\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#message-reaction-remove-emoji */\nexport type DiscordMessageReactionRemoveEmoji = Pick<DiscordMessageReactionAdd, 'channel_id' | 'guild_id' | 'message_id' | 'emoji'>\n\n/** https://discord.com/developers/docs/topics/gateway#guild-member-remove */\nexport interface DiscordGuildMemberRemove {\n  /** The id of the guild */\n  guild_id: string\n  /** The user who was removed */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/resources/guild#ban-object */\nexport interface DiscordBan {\n  /** The reason for the ban */\n  reason: string | null\n  /** The banned user */\n  user: DiscordUser\n}\n\nexport interface DiscordScheduledEventUserRemove {\n  /** id of the guild scheduled event */\n  guild_scheduled_event_id: string\n  /** id of the user */\n  user_id: string\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway#invite-delete */\nexport interface DiscordInviteDelete {\n  /** The channel of the invite */\n  channel_id: string\n  /** The guild of the invite */\n  guild_id?: string\n  /** The unique invite code */\n  code: string\n}\n\n/** https://discord.com/developers/docs/resources/voice#voice-region-object-voice-region-structure */\nexport interface DiscordVoiceRegion {\n  /** Unique Id for the region */\n  id: string\n  /** Name of the region */\n  name: string\n  /** true for a single server that is closest to the current user's client */\n  optimal: boolean\n  /** Whether this is a deprecated voice region (avoid switching to these) */\n  deprecated: boolean\n  /** Whether this is a custom voice region (used for events/etc) */\n  custom: boolean\n}\n\nexport interface DiscordGuildWidgetSettings {\n  /** whether the widget is enabled */\n  enabled: boolean\n  /** the widget channel id */\n  channel_id: string | null\n}\n\nexport interface DiscordInstallParams {\n  /** Scopes to add the application to the server with */\n  scopes: OAuth2Scope[]\n  /** Permissions to request for the bot role */\n  permissions: string\n}\n\nexport interface DiscordForumTag {\n  /** The id of the tag */\n  id: string\n  /** The name of the tag (0-20 characters) */\n  name: string\n  /** Whether this tag can only be added to or removed from threads by a member with the MANAGE_THREADS permission */\n  moderated: boolean\n  /** The id of a guild's custom emoji At most one of emoji_id and emoji_name may be set. */\n  emoji_id: string\n  /** The unicode character of the emoji */\n  emoji_name: string | null\n}\n\nexport interface DiscordDefaultReactionEmoji {\n  /** The id of a guild's custom emoji */\n  emoji_id: string\n  /** The unicode character of the emoji */\n  emoji_name: string | null\n}\n\nexport interface DiscordModifyChannel {\n  /** 1-100 character channel name */\n  name?: string\n  /** The type of channel; only conversion between text and news is supported and only in guilds with the \"NEWS\" feature */\n  type?: ChannelTypes\n  /** The position of the channel in the left-hand listing */\n  position?: number | null\n  /** 0-1024 character channel topic */\n  topic?: string | null\n  /** Whether the channel is nsfw */\n  nsfw?: boolean | null\n  /** Amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission `manage_messages` or `manage_channel`, are unaffected */\n  rate_limit_per_user?: number | null\n  /** The bitrate (in bits) of the voice channel; 8000 to 96000 (128000 for VIP servers) */\n  bitrate?: number | null\n  /** The user limit of the voice channel; 0 refers to no limit, 1 to 99 refers to a user limit */\n  user_limit?: number | null\n  /** Channel or category-specific permissions */\n  permission_overwrites?: DiscordOverwrite[] | null\n  /** Id of the new parent category for a channel */\n  parent_id?: string | null\n  /** Voice region id for the voice channel, automatic when set to null */\n  rtc_region?: string | null\n  /** The camera video quality mode of the voice channel */\n  video_quality_mode?: VideoQualityModes\n  /** Whether the thread is archived */\n  archived?: boolean\n  /** Duration in minutes to automatically archive the thread after recent activity */\n  auto_archive_duration?: 60 | 1440 | 4320 | 10080\n  /** When a thread is locked, only users with `MANAGE_THREADS` can unarchive it */\n  locked?: boolean\n  /** whether non-moderators can add other non-moderators to a thread; only available on private threads */\n  invitable?: boolean\n  /** The set of tags that can be used in a GUILD_FORUM channel */\n  available_tags?: Array<{\n    /** The id of the tag */\n    id: string\n    /** The name of the tag (0-20 characters) */\n    name: string\n    /** Whether this tag can only be added to or removed from threads by a member with the MANAGE_THREADS permission */\n    moderated: boolean\n    /** The id of a guild's custom emoji At most one of emoji_id and emoji_name may be set. */\n    emoji_id: string\n    /** The unicode character of the emoji */\n    emoji_name: string\n  }>\n  /** The IDs of the set of tags that have been applied to a thread in a GUILD_FORUM channel; limited to 5 */\n  applied_tags?: string[]\n  /** the emoji to show in the add reaction button on a thread in a GUILD_FORUM channel */\n  default_reaction_emoji?: {\n    /** The id of a guild's custom emoji */\n    emoji_id: string\n    /** The unicode character of the emoji */\n    emoji_name: string | null\n  }\n  /** the initial rate_limit_per_user to set on newly created threads in a channel. this field is copied to the thread at creation time and does not live update. */\n  default_thread_rate_limit_per_user?: number\n  /** the default sort order type used to order posts in forum channels */\n  default_sort_order?: SortOrderTypes | null\n  /** the default forum layout view used to display posts in `GUILD_FORUM` channels. Defaults to `0`, which indicates a layout view has not been set by a channel admin */\n  default_forum_layout?: ForumLayout\n}\n\n/** https://discord.com/developers/docs/resources/emoji#create-guild-emoji */\nexport interface DiscordCreateGuildEmoji {\n  /** Name of the emoji */\n  name: string\n  /** The 128x128 emoji image. Emojis and animated emojis have a maximum file size of 256kb. Attempting to upload an emoji larger than this limit will fail and return 400 Bad Request and an error message, but not a JSON status code. If a URL is provided to the image parameter, Discordeno will automatically convert it to a base64 string internally. */\n  image: string\n  /** Roles allowed to use this emoji */\n  roles?: string[]\n}\n\n/** https://discord.com/developers/docs/resources/emoji#modify-guild-emoji */\nexport interface DiscordModifyGuildEmoji {\n  /** Name of the emoji */\n  name?: string\n  /** Roles allowed to use this emoji */\n  roles?: string[] | null\n}\n\nexport interface DiscordCreateGuildChannel {\n  /** Channel name (1-100 characters) */\n  name: string\n  /** The type of channel */\n  type?: ChannelTypes\n  /** Channel topic (0-1024 characters) */\n  topic?: string\n  /** The bitrate (in bits) of the voice channel (voice only) */\n  bitrate?: number\n  /** The user limit of the voice channel (voice only) */\n  user_limit?: number\n  /** Amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission `manage_messages` or `manage_channel`, are unaffected */\n  rate_limit_per_user?: number\n  /** Sorting position of the channel */\n  position?: number\n  /** The channel's permission overwrites */\n  permission_overwrites?: DiscordOverwrite[]\n  /** Id of the parent category for a channel */\n  parent_id?: string\n  /** Whether the channel is nsfw */\n  nsfw?: boolean\n  /** Default duration (in minutes) that clients (not the API) use for newly created threads in this channel, to determine when to automatically archive the thread after the last activity */\n  default_auto_archive_duration?: number\n  /** Emoji to show in the add reaction button on a thread in a forum channel */\n  default_reaction_emoji?: {\n    /** The id of a guild's custom emoji. Exactly one of `emojiId` and `emojiName` must be set. */\n    emoji_id?: string | null\n    /** The unicode character of the emoji. Exactly one of `emojiId` and `emojiName` must be set. */\n    emoji_name?: string | null\n  }\n  /** Set of tags that can be used in a forum channel */\n  available_tags?: Array<{\n    /** The id of the tag */\n    id: string\n    /** The name of the tag (0-20 characters) */\n    name: string\n    /** whether this tag can only be added to or removed from threads by a member with the MANAGE_THREADS permission */\n    moderated: boolean\n    /** The id of a guild's custom emoji */\n    emoji_id: string\n    /** The unicode character of the emoji */\n    emoji_name?: string\n  }>\n  /** the default sort order type used to order posts in forum channels */\n  default_sort_order?: SortOrderTypes | null\n}\n\nexport interface DiscordCreateMessage {\n  /** The message contents (up to 2000 characters) */\n  content?: string\n  /** Can be used to verify a message was sent (up to 25 characters). Value will appear in the Message Create event. */\n  nonce?: string | number\n  /** true if this is a TTS message */\n  tts?: boolean\n  /** Embedded `rich` content (up to 6000 characters) */\n  embeds?: DiscordEmbed[]\n  /** Allowed mentions for the message */\n  allowed_mentions?: DiscordAllowedMentions\n  /** Include to make your message a reply */\n  message_reference?: {\n    /** id of the originating message */\n    message_id?: string\n    /**\n     * id of the originating message's channel\n     * Note: `channel_id` is optional when creating a reply, but will always be present when receiving an event/response that includes this data model.\n     */\n    channel_id?: string\n    /** id of the originating message's guild */\n    guild_id?: string\n    /** When sending, whether to error if the referenced message doesn't exist instead of sending as a normal (non-reply) message, default true */\n    fail_if_not_exists: boolean\n  }\n  /** The components you would like to have sent in this message */\n  components?: DiscordMessageComponents\n  /** IDs of up to 3 stickers in the server to send in the message */\n  stickerIds?: [string] | [string, string] | [string, string, string]\n}\n\n/** https://discord.com/developers/docs/resources/guild#modify-guild-welcome-screen */\nexport interface DiscordModifyGuildWelcomeScreen {\n  /** Whether the welcome screen is enabled */\n  enabled?: boolean | null\n  /** Channels linked in the welcome screen and their display options */\n  welcome_screen?: DiscordWelcomeScreenChannel[] | null\n  /** The server description to show in the welcome screen */\n  description?: string | null\n}\n\nexport interface DiscordFollowAnnouncementChannel {\n  /** The id of the channel to send announcements to. */\n  webhook_channel_id: string\n}\n\nexport interface DiscordEditChannelPermissionOverridesOptions {\n  /** Permission bit set */\n  allow: string\n  /** Permission bit set */\n  deny: string\n  /** Either 0 (role) or 1 (member) */\n  type: OverwriteTypes\n}\n\n/** https://discord.com/developers/docs/resources/guild#modify-guild-channel-positions */\nexport interface DiscordModifyGuildChannelPositions {\n  /** Channel id */\n  id: string\n  /** Sorting position of the channel */\n  position?: number | null\n  /** Syncs the permission overwrites with the new parent, if moving to a new category */\n  lock_positions?: boolean | null\n  /** The new parent ID for the channel that is moved */\n  parent_id?: string | null\n}\n\nexport interface DiscordCreateWebhook {\n  /** Name of the webhook (1-80 characters) */\n  name: string\n  /** Image url for the default webhook avatar */\n  avatar?: string | null\n}\n\n/** https://discord.com/developers/docs/resources/channel#start-thread-in-forum-channel */\nexport interface DiscordCreateForumPostWithMessage {\n  /** 1-100 character channel name */\n  name: string\n  /** duration in minutes to automatically archive the thread after recent activity, can be set to: 60, 1440, 4320, 10080 */\n  auto_archive_duration?: 60 | 1440 | 4320 | 10080\n  /** amount of seconds a user has to wait before sending another message (0-21600) */\n  rate_limit_per_user?: number\n  /** contents of the first message in the forum thread */\n  message: {\n    /** Message contents (up to 2000 characters) */\n    content?: string\n    /** Embedded rich content (up to 6000 characters) */\n    embeds?: DiscordEmbed[]\n    /** Allowed mentions for the message */\n    allowed_mentions?: DiscordAllowedMentions[]\n    /** Components to include with the message */\n    components?: DiscordMessageComponents[]\n    /** IDs of up to 3 stickers in the server to send in the message */\n    sticker_ids?: string[]\n    /** JSON-encoded body of non-file params, only for multipart/form-data requests. See {@link https://discord.com/developers/docs/reference#uploading-files Uploading Files} */\n    payload_json?: string\n    /** Attachment objects with filename and description. See {@link https://discord.com/developers/docs/reference#uploading-files Uploading Files} */\n    attachments?: DiscordAttachment[]\n    /** Message flags combined as a bitfield, only SUPPRESS_EMBEDS can be set */\n    flags?: MessageFlags\n  }\n  /** the IDs of the set of tags that have been applied to a thread in a GUILD_FORUM channel */\n  applied_tags?: string[]\n}\n\nexport type DiscordArchivedThreads = DiscordActiveThreads & {\n  hasMore: boolean\n}\n\nexport interface DiscordActiveThreads {\n  threads: DiscordChannel[]\n  members: DiscordThreadMember[]\n}\n\nexport interface DiscordVanityUrl {\n  code: string | null\n  uses: number\n}\n\nexport interface DiscordPrunedCount {\n  pruned: number\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-guild-onboarding-structure */\nexport interface DiscordGuildOnboarding {\n  /** ID of the guild this onboarding is part of */\n  guild_id: string\n  /** Prompts shown during onboarding and in customize community */\n  prompts: DiscordGuildOnboardingPrompt[]\n  /** Channel IDs that members get opted into automatically */\n  default_channel_ids: string[]\n  /** Whether onboarding is enabled in the guild */\n  enabled: boolean\n  /** Current mode of onboarding */\n  mode: DiscordGuildOnboardingMode\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-onboarding-prompt-structure */\nexport interface DiscordGuildOnboardingPrompt {\n  /** ID of the prompt */\n  id: string\n  /** Type of prompt */\n  type: DiscordGuildOnboardingPromptType\n  /** Options available within the prompt */\n  options: DiscordGuildOnboardingPromptOption[]\n  /** Title of the prompt */\n  title: string\n  /** Indicates whether users are limited to selecting one option for the prompt */\n  single_select: boolean\n  /** Indicates whether the prompt is required before a user completes the onboarding flow */\n  required: boolean\n  /** Indicates whether the prompt is present in the onboarding flow. If `false`, the prompt will only appear in the Channels & Roles tab */\n  in_onboarding: boolean\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-prompt-option-structure */\nexport interface DiscordGuildOnboardingPromptOption {\n  /** ID of the prompt option */\n  id: string\n  /** IDs for channels a member is added to when the option is selected */\n  channel_ids: string[]\n  /** IDs for roles assigned to a member when the option is selected */\n  role_ids: string[]\n  /**\n   * Emoji of the option\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji?: DiscordEmoji\n  /**\n   * Emoji ID of the option\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji_id?: string\n  /**\n   * Emoji name of the option\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji_name?: string\n  /**\n   * Whether the emoji is animated\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji_animated?: boolean\n  /** Title of the option */\n  title: string\n  /** Description of the option */\n  description: string | undefined\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-prompt-types */\nexport enum DiscordGuildOnboardingPromptType {\n  MultipleChoice,\n  DropDown,\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-onboarding-mode */\nexport enum DiscordGuildOnboardingMode {\n  /** Counts only Default Channels towards constraints */\n  OnboardingDefault,\n  /** Counts Default Channels and Questions towards constraints */\n  OnboardingAdvanced,\n}\n\n/** https://discord.com/developers/docs/topics/teams#team-member-roles-team-member-role-types */\nexport enum DiscordTeamMemberRole {\n  /** Owners are the most permissiable role, and can take destructive, irreversible actions like deleting the team itself. Teams are limited to 1 owner. */\n  Owner = 'owner',\n  /** Admins have similar access as owners, except they cannot take destructive actions on the team or team-owned apps. */\n  Admin = 'admin',\n  /**\n   * Developers can access information about team-owned apps, like the client secret or public key.\n   * They can also take limited actions on team-owned apps, like configuring interaction endpoints or resetting the bot token.\n   * Members with the Developer role *cannot* manage the team or its members, or take destructive actions on team-owned apps.\n   */\n  Developer = 'developer',\n  /** Read-only members can access information about a team and any team-owned apps. Some examples include getting the IDs of applications and exporting payout records. */\n  ReadOnly = 'read_only',\n}\n\n/** https://discord.com/developers/docs/monetization/entitlements#entitlement-object-entitlement-structure */\nexport interface DiscordEntitlement {\n  /** ID of the entitlement */\n  id: string\n  /** ID of the SKU */\n  sku_id: string\n  /** ID of the user that is granted access to the entitlement's sku */\n  user_id?: string\n  /** ID of the guild that is granted access to the entitlement's sku */\n  guild_id?: string\n  /** ID of the parent application */\n  application_id: string\n  /** Type of entitlement */\n  type: DiscordEntitlementType\n  /** Entitlement was deleted */\n  deleted: boolean\n  /** Start date at which the entitlement is valid. Not present when using test entitlements */\n  starts_at?: string\n  /** Date at which the entitlement is no longer valid. Not present when using test entitlements */\n  ends_at?: string\n  /** For consumable items, whether or not the entitlement has been consumed */\n  consumed?: boolean\n}\n\n/** https://discord.com/developers/docs/monetization/entitlements#entitlement-object-entitlement-types */\nexport enum DiscordEntitlementType {\n  /** Entitlement was purchased by user */\n  Purchase = 1,\n  /** Entitlement for Discord Nitro subscription */\n  PremiumSubscription = 2,\n  /** Entitlement was gifted by developer */\n  DeveloperGift = 3,\n  /** Entitlement was purchased by a dev in application test mode */\n  TestModePurchase = 4,\n  /** Entitlement was granted when the SKU was free */\n  FreePurchase = 5,\n  /** Entitlement was gifted by another user */\n  UserGift = 6,\n  /** Entitlement was claimed by user for free as a Nitro Subscriber */\n  PremiumPurchase = 7,\n  /** Entitlement was purchased as an app subscription */\n  ApplicationSubscription = 8,\n}\n\n/** https://discord.com/developers/docs/monetization/skus#sku-object-sku-structure */\nexport interface DiscordSku {\n  /** ID of SKU */\n  id: string\n  /** Type of SKU */\n  type: DiscordSkuType\n  /** ID of the parent application */\n  application_id: string\n  /** Customer-facing name of your premium offering */\n  name: string\n  /** System-generated URL slug based on the SKU's name */\n  slug: string\n  /** SKU flags combined as a bitfield */\n  flags: SkuFlags\n}\n\n/** https://discord.com/developers/docs/monetization/skus#sku-object-sku-types */\nexport enum DiscordSkuType {\n  /** Durable one-time purchase */\n  Durable = 2,\n  /** Consumable one-time purchase */\n  Consumable = 3,\n  /** Represents a recurring subscription */\n  Subscription = 5,\n  /** System-generated group for each SUBSCRIPTION SKU created */\n  SubscriptionGroup = 6,\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-object-interaction-context-types */\nexport enum DiscordInteractionContextType {\n  /** Interaction can be used within servers */\n  Guild = 0,\n  /** Interaction can be used within DMs with the app's bot user */\n  BotDm = 1,\n  /** Interaction can be used within Group DMs and DMs other than the app's bot user */\n  PrivateChannel = 2,\n}\n\n/** https://discord.com/developers/docs/resources/guild#bulk-guild-ban */\nexport interface DiscordBulkBan {\n  /** list of user ids, that were successfully banned */\n  banned_users: string[]\n  /** list of user ids, that were not banned */\n  failed_users: string[]\n}\n"],"names":["OAuth2Scope","DiscordApplicationIntegrationType","DiscordConnectionServiceType","DiscordConnectionVisibility","DiscordReactionType","DiscordPollLayoutType","AutoModerationEventTypes","AutoModerationTriggerTypes","DiscordAutoModerationRuleTriggerMetadataPresets","AutoModerationActionType","DiscordInviteType","DiscordGuildOnboardingPromptType","DiscordGuildOnboardingMode","DiscordTeamMemberRole","DiscordEntitlementType","DiscordSkuType","DiscordInteractionContextType"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAuFYA;IACV;;;;;GAKC;IAED;;;;;GAKC;IAED,iEAAiE;IAEjE;;;;;GAKC;IAED,0FAA0F;IAE1F;;;;;GAKC;IAED,gGAAgG;IAEhG,mEAAmE;IAEnE,uHAAuH;IAEvH,+EAA+E;IAE/E,yHAAyH;IAEzH;;;;;GAKC;IAED,gHAAgH;IAEhH,gDAAgD;IAEhD,uHAAuH;IAEvH,oIAAoI;IAEpI,+IAA+I;IAE/I;;;;;;GAMC;IAED;;;GAGC;IAED;;;;;GAKC;IAED,2EAA2E;IAE3E;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED,kGAAkG;GA5HxFA,gBAAAA;;UA2UAC;IACV,kCAAkC;IAElC,gCAAgC;GAHtBA,sCAAAA;;UAgGAC;;;;;;;;;;;;;;;;;;;;;;GAAAA,iCAAAA;;UAyBAC;IACV,qDAAqD;IAErD,wBAAwB;GAHdA,gCAAAA;;UAk3BAC;;;GAAAA,wBAAAA;;UAgEAC;IACV,uBAAuB;GADbA,0BAAAA;;UA+dAC;IACV,gCAAgC;IAEhC,qCAAqC;GAH3BA,6BAAAA;;UAOAC;IACV,0FAA0F;IAE1F,8DAA8D;IAE9D,yFAAyF;IAEzF,iFAAiF;IAEjF,iGAAiG;GATvFA,+BAAAA;;UAmEAC;IACV,8DAA8D;IAE9D,+DAA+D;IAE/D,iEAAiE;GALvDA,oDAAAA;;UAgBAC;IACV,0DAA0D;IAE1D,6CAA6C;IAE7C;;;;;;;GAOC;IAED,oEAAoE;GAd1DA,6BAAAA;;UA4VAC;;;;GAAAA,sBAAAA;;UAy9BAC;;;GAAAA,qCAAAA;;UAMAC;IACV,qDAAqD;IAErD,8DAA8D;GAHpDA,+BAAAA;;UAQAC;IACV,uJAAuJ;IAEvJ,sHAAsH;IAEtH;;;;GAIC;IAED,uKAAuK;GAX7JA,0BAAAA;;UAwCAC;IACV,sCAAsC;IAEtC,+CAA+C;IAE/C,wCAAwC;IAExC,gEAAgE;IAEhE,kDAAkD;IAElD,2CAA2C;IAE3C,mEAAmE;IAEnE,qDAAqD;GAf3CA,2BAAAA;;UAoCAC;IACV,8BAA8B;IAE9B,iCAAiC;IAEjC,wCAAwC;IAExC,6DAA6D;GAPnDA,mBAAAA;;UAYAC;IACV,2CAA2C;IAE3C,+DAA+D;IAE/D,mFAAmF;GALzEA,kCAAAA"}
|
|
416
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord.ts"],"sourcesContent":["import {\n  type ActivityTypes,\n  type AllowedMentionsTypes,\n  type ApplicationCommandOptionTypes,\n  type ApplicationCommandPermissionTypes,\n  type ApplicationCommandTypes,\n  type ApplicationFlags,\n  type AttachmentFlags,\n  type AuditLogEvents,\n  type ButtonStyles,\n  type ChannelFlags,\n  type ChannelTypes,\n  type DefaultMessageNotificationLevels,\n  type EmbedTypes,\n  type ExplicitContentFilterLevels,\n  type ForumLayout,\n  type GatewayEventNames,\n  type GuildFeatures,\n  type GuildNsfwLevel,\n  type IntegrationExpireBehaviors,\n  type InteractionResponseTypes,\n  type InteractionTypes,\n  type Localization,\n  type MessageActivityTypes,\n  type MessageComponentTypes,\n  type MessageFlags,\n  type MessageTypes,\n  type MfaLevels,\n  type OverwriteTypes,\n  type PickPartial,\n  type PremiumTiers,\n  type PremiumTypes,\n  type RoleFlags,\n  type ScheduledEventEntityType,\n  type ScheduledEventPrivacyLevel,\n  type ScheduledEventStatus,\n  type SkuFlags,\n  type SortOrderTypes,\n  type StickerFormatTypes,\n  type StickerTypes,\n  type SystemChannelFlags,\n  type TargetTypes,\n  type TeamMembershipStates,\n  type TextStyles,\n  type VerificationLevels,\n  type VideoQualityModes,\n  type WebhookTypes,\n} from './shared.js'\n\n/** https://discord.com/developers/docs/resources/user#user-object */\nexport interface DiscordUser {\n  /** The user's username, not unique across the platform */\n  username: string\n  /** The user's display name, if it is set. For bots, this is the application name */\n  global_name: string | null\n  /** The user's chosen language option */\n  locale?: string\n  /** The flags on a user's account */\n  flags?: number\n  /** The type of Nitro subscription on a user's account */\n  premium_type?: PremiumTypes\n  /** The public flags on a user's account */\n  public_flags?: number\n  /** the user's banner color encoded as an integer representation of hexadecimal color code */\n  accent_color?: number\n  /** The user's id */\n  id: string\n  /** The user's discord-tag */\n  discriminator: string\n  /** The user's avatar hash */\n  avatar: string | null\n  /** Whether the user belongs to an OAuth2 application */\n  bot?: boolean\n  /** Whether the user is an Official Discord System user (part of the urgent message system) */\n  system?: boolean\n  /** Whether the user has two factor enabled on their account */\n  mfa_enabled?: boolean\n  /** Whether the email on this account has been verified */\n  verified?: boolean\n  /** The user's email */\n  email?: string | null\n  /** the user's banner, or null if unset */\n  banner?: string\n  /** data for the user's avatar decoration */\n  avatar_decoration_data?: DiscordAvatarDecorationData\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#shared-resources-oauth2-scopes */\nexport enum OAuth2Scope {\n  /**\n   * Allows your app to fetch data from a user's \"Now Playing/Recently Played\" list\n   *\n   * @remarks\n   * This scope is not currently available for apps\n   */\n  ActivitiesRead = 'activities.read',\n  /**\n   * Allows your app to update a user's activity\n   *\n   * @remarks\n   * This scope not currently available for apps.\n   */\n  ActivitiesWrite = 'activities.write',\n  /** Allows your app to read build data for a user's applications */\n  ApplicationsBuildsRead = 'applications.builds.read',\n  /**\n   * Allows your app to upload/update builds for a user's applications\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  ApplicationsBuildsUpload = 'applications.builds.upload',\n  /** Allows your app to add commands to a guild - included by default with the `bot` scope */\n  ApplicationsCommands = 'applications.commands',\n  /**\n   * Allows your app to update its Application Commands via this bearer token\n   *\n   * @remarks\n   * This scope can only be used when using a [Client Credential Grant](https://discord.com/developers/docs/topics/oauth2#client-credentials-grant)\n   */\n  ApplicationsCommandsUpdate = 'applications.commands.update',\n  /** Allows your app to update permissions for its commands in a guild a user has permissions to */\n  ApplicationCommandsPermissionsUpdate = 'applications.commands.permissions.update',\n  /** Allows your app to read entitlements for a user's applications */\n  ApplicationsEntitlements = 'applications.entitlements',\n  /** Allows your app to read and update store data (SKUs, store listings, achievements, etc.) for a user's applications */\n  ApplicationsStoreUpdate = 'applications.store.update',\n  /** For oauth2 bots, this puts the bot in the user's selected guild by default */\n  Bot = 'bot',\n  /** Allows requests to [/users/@me/connections](https://discord.com/developers/docs/resources/user#get-user-connections) */\n  Connections = 'connections',\n  /**\n   * Allows your app to see information about the user's DMs and group DMs\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  DMChannelsRead = 'dm_channels.read',\n  /** Adds the `email` filed to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user) */\n  Email = 'email',\n  /** Allows your app to join users to a group dm */\n  GroupDMJoins = 'gdm.join',\n  /** Allows requests to [/users/@me/guilds](https://discord.com/developers/docs/resources/user#get-current-user-guilds) */\n  Guilds = 'guilds',\n  /** Allows requests to [/guilds/{guild.id}/members/{user.id}](https://discord.com/developers/docs/resources/guild#add-guild-member) */\n  GuildsJoin = 'guilds.join',\n  /** Allows requests to [/users/@me/guilds/{guild.id}/member](https://discord.com/developers/docs/resources/user#get-current-user-guild-member) */\n  GuildsMembersRead = 'guilds.members.read',\n  /**\n   * Allows requests to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   *\n   * @remarks\n   * The return object from [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   * does NOT contain the `email` field unless the scope `email` is also used\n   */\n  Identify = 'identify',\n  /**\n   * For local rpc server api access, this allows you to read messages from all client channels\n   * (otherwise restricted to channels/guilds your app creates)\n   */\n  MessagesRead = 'messages.read',\n  /**\n   * Allows your app to know a user's friends and implicit relationships\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RelationshipsRead = 'relationships.read',\n  /** Allows your app to update a user's connection and metadata for the app */\n  RoleConnectionsWrite = 'role_connections.write',\n  /**\n   * For local rpc server access, this allows you to control a user's local Discord client\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPC = 'rpc',\n  /**\n   * For local rpc server access, this allows you to update a user's activity\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCActivitiesWrite = 'rpc.activities.write',\n  /**\n   * For local rpc server api access, this allows you to receive notifications pushed out to the user\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCNotificationsRead = 'rpc.notifications.read',\n  /**\n   * For local rpc server access, this allows you to read a user's voice settings and listen for voice events\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceRead = 'rpc.voice.read',\n  /**\n   * For local rpc server access, this allows you to update a user's voice settings\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceWrite = 'rpc.voice.write',\n  /**\n   * Allows your app to connect to voice on user's behalf and see all the voice members\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  Voice = 'voice',\n  /** Generate a webhook that is returned in the oauth token response for authorization code grants */\n  WebhookIncoming = 'webhook.incoming',\n}\n\n/** https://discord.com/developers/docs/resources/guild#integration-object-integration-structure */\nexport interface DiscordIntegration {\n  /** Integration Id */\n  id: string\n  /** Integration name */\n  name: string\n  /** Integration type (twitch, youtube, discord, or guild_subscription). */\n  type: 'twitch' | 'youtube' | 'discord'\n  /** Is this integration enabled */\n  enabled?: boolean\n  /** Is this integration syncing */\n  syncing?: boolean\n  /** Role Id that this integration uses for \"subscribers\" */\n  role_id?: string\n  /** Whether emoticons should be synced for this integration (twitch only currently) */\n  enable_emoticons?: boolean\n  /** The behavior of expiring subscribers */\n  expire_behavior?: IntegrationExpireBehaviors\n  /** The grace period (in days) before expiring subscribers */\n  expire_grace_period?: number\n  /** When this integration was last synced */\n  synced_at?: string\n  /** How many subscribers this integration has */\n  subscriber_count?: number\n  /** Has this integration been revoked */\n  revoked?: boolean\n  /** User for this integration */\n  user?: DiscordUser\n  /** Integration account information */\n  account: DiscordIntegrationAccount\n  /** The bot/OAuth2 application for discord integrations */\n  application?: DiscordIntegrationApplication\n  /** the scopes the application has been authorized for */\n  scopes: OAuth2Scope[]\n}\n\n/** https://discord.com/developers/docs/resources/guild#integration-account-object-integration-account-structure */\nexport interface DiscordIntegrationAccount {\n  /** Id of the account */\n  id: string\n  /** Name of the account */\n  name: string\n}\n\n/** https://discord.com/developers/docs/resources/guild#integration-application-object-integration-application-structure */\nexport interface DiscordIntegrationApplication {\n  /** The id of the app */\n  id: string\n  /** The name of the app */\n  name: string\n  /** the icon hash of the app */\n  icon: string | null\n  /** The description of the app */\n  description: string\n  /** The bot associated with this application */\n  bot?: DiscordUser\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#integration-update-integration-update-event-additional-fields */\nexport interface DiscordIntegrationCreateUpdate extends DiscordIntegration {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#integration-delete */\nexport interface DiscordIntegrationDelete {\n  /** Integration id */\n  id: string\n  /** Id of the guild */\n  guild_id: string\n  /** Id of the bot/OAuth2 application for this discord integration */\n  application_id?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-integrations-update */\nexport interface DiscordGuildIntegrationsUpdate {\n  /** id of the guild whose integrations were updated */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#typing-start */\nexport interface DiscordTypingStart {\n  /** Unix time (in seconds) of when the user started typing */\n  timestamp: number\n  /** id of the channel */\n  channel_id: string\n  /** id of the guild */\n  guild_id?: string\n  /** id of the user */\n  user_id: string\n  /** The member who started typing if this happened in a guild */\n  member?: DiscordMember\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-member-object */\nexport interface DiscordMember {\n  /** Whether the user is deafened in voice channels */\n  deaf?: boolean\n  /** Whether the user is muted in voice channels */\n  mute?: boolean\n  /** Whether the user has not yet passed the guild's Membership Screening requirements */\n  pending?: boolean\n  /** The user this guild member represents */\n  user?: DiscordUser\n  /** This user's guild nickname */\n  nick?: string | null\n  /** The member's custom avatar for this server. */\n  avatar?: string\n  /** The member's guild banner */\n  banner?: string\n  /** Array of role object ids */\n  roles: string[]\n  /** When the user joined the guild */\n  joined_at: string\n  /** When the user started boosting the guild */\n  premium_since?: string | null\n  /** The permissions this member has in the guild. Only present on interaction events and OAuth2 current member fetch. */\n  permissions?: string\n  /** when the user's timeout will expire and the user will be able to communicate in the guild again (set null to remove timeout), null or a time in the past if the user is not timed out */\n  communication_disabled_until?: string | null\n  /** Guild member flags */\n  flags: number\n  /** data for the member's guild avatar decoration */\n  avatar_decoration_data?: DiscordAvatarDecorationData | null\n}\n\n/** https://discord.com/developers/docs/resources/user#avatar-decoration-data-object */\nexport interface DiscordAvatarDecorationData {\n  /** the avatar decoration hash */\n  asset: string\n  /** id of the avatar decoration's SKU */\n  sku_id: string\n}\n\n/** https://discord.com/developers/docs/resources/application#application-object */\nexport interface DiscordApplication {\n  /** The name of the app */\n  name: string\n  /** The description of the app */\n  description: string\n  /** An array of rpc origin urls, if rpc is enabled */\n  rpc_origins?: string[]\n  /** The url of the app's terms of service */\n  terms_of_service_url?: string\n  /** The url of the app's privacy policy */\n  privacy_policy_url?: string\n  /** The hex encoded key for verification in interactions and the GameSDK's GetTicket */\n  verify_key: string\n  /** If this application is a game sold on Discord, this field will be the id of the \"Game SKU\" that is created, if exists */\n  primary_sku_id?: string\n  /** If this application is a game sold on Discord, this field will be the URL slug that links to the store page */\n  slug?: string\n  /** The application's public flags */\n  flags?: ApplicationFlags\n  /** The id of the app */\n  id: string\n  /** The icon hash of the app */\n  icon: string | null\n  /** When false only app owner can join the app's bot to guilds */\n  bot_public: boolean\n  /** When true the app's bot will only join upon completion of the full oauth2 code grant flow */\n  bot_require_code_grant: boolean\n  /** Partial user object containing info on the owner of the application */\n  owner?: Partial<DiscordUser>\n  /** If the application belongs to a team, this will be a list of the members of that team */\n  team: DiscordTeam | null\n  /** Guild associated with the app. For example, a developer support server. */\n  guild_id?: string\n  /** A partial object of the associated guild */\n  guild?: Partial<DiscordGuild>\n  /** If this application is a game sold on Discord, this field will be the hash of the image on store embeds */\n  cover_image?: string\n  /** up to 5 tags describing the content and functionality of the application */\n  tags?: string[]\n  /** settings for the application's default in-app authorization link, if enabled */\n  install_params?: DiscordInstallParams\n  /** Default scopes and permissions for each supported installation context. */\n  integration_types_config?: Partial<Record<`${DiscordApplicationIntegrationType}`, DiscordApplicationIntegrationTypeConfiguration>>\n  /** the application's default custom authorization link, if enabled */\n  custom_install_url?: string\n  /** the application's role connection verification entry point, which when configured will render the app as a verification method in the guild role verification configuration */\n  role_connections_verification_url?: string | null\n  /** An approximate count of the app's guild membership. */\n  approximate_guild_count?: number\n  /** Approximate count of users that have installed the app. */\n  approximate_user_install_count?: number\n  /** Partial user object for the bot user associated with the app */\n  bot?: Partial<DiscordUser>\n  /** Array of redirect URIs for the app */\n  redirect_uris?: string[]\n  /** Interactions endpoint URL for the app */\n  interactions_endpoint_url?: string | null\n  /** Event webhook URL for the app to receive webhook events */\n  event_webhooks_url?: string | null\n  /** If webhook events are enabled for the app. 1 to disable, and 2 to enable. */\n  event_webhooks_status: DiscordApplicationEventWebhookStatus\n  /** List of Webhook event types the app subscribes to */\n  event_webhooks_types?: DiscordWebhookEventType[]\n}\n\n/** https://discord.com/developers/docs/resources/application#application-object-application-integration-type-configuration-object */\nexport interface DiscordApplicationIntegrationTypeConfiguration {\n  /**\n   * Install params for each installation context's default in-app authorization link\n   *\n   * https://discord.com/developers/docs/resources/application#install-params-object-install-params-structure\n   */\n  oauth2_install_params?: DiscordInstallParams\n}\n\nexport enum DiscordApplicationIntegrationType {\n  /** App is installable to servers */\n  GuildInstall = 0,\n  /** App is installable to users */\n  UserInstall = 1,\n}\n\n/** https://discord.com/developers/docs/resources/application#application-object-application-event-webhook-status */\nexport enum DiscordApplicationEventWebhookStatus {\n  /** Webhook events are disabled by developer */\n  Disabled = 1,\n  /** Webhook events are enabled by developer */\n  Enabled = 2,\n  /** Webhook events are disabled by Discord, usually due to inactivity */\n  DisabledByDiscord = 3,\n}\n\nexport type DiscordTokenExchange = DiscordTokenExchangeAuthorizationCode | DiscordTokenExchangeRefreshToken | DiscordTokenExchangeClientCredentials\n\nexport interface DiscordTokenExchangeAuthorizationCode {\n  grant_type: 'authorization_code'\n  /** The code for the token exchange */\n  code: string\n  /** The redirect_uri associated with this authorization */\n  redirect_uri: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#client-credentials-grant */\nexport interface DiscordTokenExchangeRefreshToken {\n  grant_type: 'refresh_token'\n  /** the user's refresh token */\n  refresh_token: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#client-credentials-grant */\nexport interface DiscordTokenExchangeClientCredentials {\n  grant_type: 'client_credentials'\n  /** The scope(s) for the access token */\n  scope: OAuth2Scope[]\n}\n\nexport interface DiscordAccessTokenResponse {\n  /** The access token of the user */\n  access_token: string\n  /** The type of token */\n  token_type: string\n  /** The number of seconds after that the access token is expired */\n  expires_in: number\n  /**\n   * The refresh token to refresh the access token\n   *\n   * @remarks\n   * When the token exchange is a client credentials type grant this value is not defined.\n   */\n  refresh_token: string\n  /** The scopes for the access token */\n  scope: string\n  /** The webhook the user created for the application. Requires the `webhook.incoming` scope */\n  webhook?: DiscordIncomingWebhook\n  /** The guild the bot has been added. Requires the `bot` scope */\n  guild?: DiscordGuild\n}\n\nexport interface DiscordTokenRevocation {\n  /** The access token to revoke */\n  token: string\n  /** Optional, the type of token you are using for the revocation */\n  token_type_hint?: 'access_token' | 'refresh_token'\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#get-current-authorization-information-response-structure */\nexport interface DiscordCurrentAuthorization {\n  application: DiscordApplication\n  /** the scopes the user has authorized the application for */\n  scopes: OAuth2Scope[]\n  /** when the access token expires */\n  expires: string\n  /** the user who has authorized, if the user has authorized with the `identify` scope */\n  user?: DiscordUser\n}\n\n/** https://discord.com/developers/docs/resources/user#connection-object-connection-structure */\nexport interface DiscordConnection {\n  /** id of the connection account */\n  id: string\n  /** the username of the connection account */\n  name: string\n  /** the service of this connection */\n  type: DiscordConnectionServiceType\n  /** whether the connection is revoked */\n  revoked?: boolean\n  /** an array of partial server integrations */\n  integrations?: Partial<DiscordIntegration>[]\n  /** whether the connection is verified */\n  verified: boolean\n  /** whether friend sync is enabled for this connection */\n  friend_sync: boolean\n  /** whether activities related to this connection will be shown in presence updates */\n  show_activity: boolean\n  /** whether this connection has a corresponding third party OAuth2 token */\n  two_way_link: boolean\n  /** visibility of this connection */\n  visibility: DiscordConnectionVisibility\n}\n\n/** https://discord.com/developers/docs/resources/user#connection-object-services */\nexport enum DiscordConnectionServiceType {\n  AmazonMusic = 'amazon-music',\n  BattleNet = 'battlenet',\n  Bungie = 'Bungie.net',\n  Domain = 'domain',\n  eBay = 'ebay',\n  EpicGames = 'epicgames',\n  Facebook = 'facebook',\n  GitHub = 'github',\n  Instagram = 'instagram',\n  LeagueOfLegends = 'leagueoflegends',\n  PayPal = 'paypal',\n  PlayStationNetwork = 'playstation',\n  Reddit = 'reddit',\n  RiotGames = 'riotgames',\n  Roblox = 'roblox',\n  Spotify = 'spotify',\n  Skype = 'skype',\n  Steam = 'steam',\n  TikTok = 'tiktok',\n  Twitch = 'twitch',\n  Twitter = 'twitter',\n  Xbox = 'xbox',\n  YouTube = 'youtube',\n}\n\n/** https://discord.com/developers/docs/resources/user#connection-object-visibility-types */\nexport enum DiscordConnectionVisibility {\n  /** invisible to everyone except the user themselves */\n  None = 0,\n  /** visible to everyone */\n  Everyone = 1,\n}\n\n/** https://discord.com/developers/docs/resources/user#application-role-connection-object-application-role-connection-structure */\nexport interface DiscordApplicationRoleConnection {\n  /** the vanity name of the platform a bot has connected (max 50 characters) */\n  platform_name: string | null\n  /** the username on the platform a bot has connected (max 100 characters) */\n  platform_username: string | null\n  /** object mapping application role connection metadata keys to their stringified value (max 100 characters) for the user on the platform a bot has connected */\n  metadata: Record<string, string>\n}\n\n/** https://discord.com/developers/docs/topics/teams#data-models-team-object */\nexport interface DiscordTeam {\n  /** Hash of the image of the team's icon */\n  icon: string | null\n  /** Unique ID of the team */\n  id: string\n  /** Members of the team */\n  members: DiscordTeamMember[]\n  /** User ID of the current team owner */\n  owner_user_id: string\n  /** Name of the team */\n  name: string\n}\n\n/** https://discord.com/developers/docs/topics/teams#data-models-team-members-object */\nexport interface DiscordTeamMember {\n  /** The user's membership state on the team */\n  membership_state: TeamMembershipStates\n  /** The id of the parent team of which they are a member */\n  team_id: string\n  /** The avatar, discriminator, id, username, and global_name of the user */\n  user: Partial<DiscordUser> & Pick<DiscordUser, 'avatar' | 'discriminator' | 'id' | 'username' | 'global_name'>\n  /** Role of the team member */\n  role: DiscordTeamMemberRole\n}\n\n/** https://discord.com/developers/docs/events/gateway#webhooks-update-webhook-update-event-fields */\nexport interface DiscordWebhookUpdate {\n  /** id of the guild */\n  guild_id: string\n  /** id of the channel */\n  channel_id: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#allowed-mentions-object */\nexport interface DiscordAllowedMentions {\n  /** An array of allowed mention types to parse from the content. */\n  parse?: AllowedMentionsTypes[]\n  /** For replies, whether to mention the author of the message being replied to (default false) */\n  replied_user?: boolean\n  /** Array of role_ids to mention (Max size of 100) */\n  roles?: string[]\n  /** Array of user_ids to mention (Max size of 100) */\n  users?: string[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object */\nexport interface DiscordEmbed {\n  /** Title of embed */\n  title?: string\n  /** Type of embed (always \"rich\" for webhook embeds) */\n  type?: EmbedTypes\n  /** Description of embed */\n  description?: string\n  /** Url of embed */\n  url?: string\n  /** Color code of the embed */\n  color?: number\n  /** Timestamp of embed content */\n  timestamp?: string\n  /** Footer information */\n  footer?: DiscordEmbedFooter\n  /** Image information */\n  image?: DiscordEmbedImage\n  /** Thumbnail information */\n  thumbnail?: DiscordEmbedThumbnail\n  /** Video information */\n  video?: DiscordEmbedVideo\n  /** Provider information */\n  provider?: DiscordEmbedProvider\n  /** Author information */\n  author?: DiscordEmbedAuthor\n  /** Fields information */\n  fields?: DiscordEmbedField[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-author-structure */\nexport interface DiscordEmbedAuthor {\n  /** Name of author */\n  name: string\n  /** Url of author */\n  url?: string\n  /** Url of author icon (only supports http(s) and attachments) */\n  icon_url?: string\n  /** A proxied url of author icon */\n  proxy_icon_url?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-field-structure */\nexport interface DiscordEmbedField {\n  /** Name of the field */\n  name: string\n  /** Value of the field */\n  value: string\n  /** Whether or not this field should display inline */\n  inline?: boolean\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-footer-structure */\nexport interface DiscordEmbedFooter {\n  /** Footer text */\n  text: string\n  /** Url of footer icon (only supports http(s) and attachments) */\n  icon_url?: string\n  /** A proxied url of footer icon */\n  proxy_icon_url?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-image-structure */\nexport interface DiscordEmbedImage {\n  /** Source url of image (only supports http(s) and attachments) */\n  url: string\n  /** A proxied url of the image */\n  proxy_url?: string\n  /** Height of image */\n  height?: number\n  /** Width of image */\n  width?: number\n}\n\nexport interface DiscordEmbedProvider {\n  /** Name of provider */\n  name?: string\n  /** Url of provider */\n  url?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-thumbnail-structure */\nexport interface DiscordEmbedThumbnail {\n  /** Source url of thumbnail (only supports http(s) and attachments) */\n  url: string\n  /** A proxied url of the thumbnail */\n  proxy_url?: string\n  /** Height of thumbnail */\n  height?: number\n  /** Width of thumbnail */\n  width?: number\n}\n\n/** https://discord.com/developers/docs/resources/channel#embed-object-embed-video-structure */\nexport interface DiscordEmbedVideo {\n  /** Source url of video */\n  url?: string\n  /** A proxied url of the video */\n  proxy_url?: string\n  /** Height of video */\n  height?: number\n  /** Width of video */\n  width?: number\n}\n\n/** https://discord.com/developers/docs/resources/channel#attachment-object */\nexport interface DiscordAttachment {\n  /** Name of file attached */\n  filename: string\n  /** The title of the file */\n  title?: string\n  /** The attachment's [media type](https://en.wikipedia.org/wiki/Media_type) */\n  content_type?: string\n  /** Size of file in bytes */\n  size: number\n  /** Source url of file */\n  url: string\n  /** A proxied url of file */\n  proxy_url: string\n  /** Attachment id */\n  id: string\n  /** description for the file (max 1024 characters) */\n  description?: string\n  /** Height of file (if image) */\n  height?: number | null\n  /** Width of file (if image) */\n  width?: number | null\n  /** whether this attachment is ephemeral. Ephemeral attachments will automatically be removed after a set period of time. Ephemeral attachments on messages are guaranteed to be available as long as the message itself exists. */\n  ephemeral?: boolean\n  /** The duration of the audio file for a voice message */\n  duration_secs?: number\n  /** A base64 encoded bytearray representing a sampled waveform for a voice message */\n  waveform?: string\n  /** Attachment flags combined as a bitfield */\n  flags?: AttachmentFlags\n}\n\n/** https://discord.com/developers/docs/resources/webhook#webhook-object-webhook-structure */\nexport type DiscordWebhook = DiscordIncomingWebhook | DiscordApplicationWebhook\n\nexport interface DiscordIncomingWebhook {\n  /** The type of the webhook */\n  type: WebhookTypes\n  /** The secure token of the webhook (returned for Incoming Webhooks) */\n  token?: string\n  /** The url used for executing the webhook (returned by the webhooks OAuth2 flow) */\n  url?: string\n\n  /** The id of the webhook */\n  id: string\n  /** The guild id this webhook is for */\n  guild_id?: string\n  /** The channel id this webhook is for */\n  channel_id: string\n  /** The user this webhook was created by (not returned when getting a webhook with its token) */\n  user?: DiscordUser\n  /** The default name of the webhook */\n  name: string | null\n  /** The default user avatar hash of the webhook */\n  avatar: string | null\n  /** The bot/OAuth2 application that created this webhook */\n  application_id: string | null\n  /** The guild of the channel that this webhook is following (returned for Channel Follower Webhooks) */\n  source_guild?: Partial<DiscordGuild>\n  /** The channel that this webhook is following (returned for Channel Follower Webhooks) */\n  source_channel?: Partial<DiscordChannel>\n}\n\nexport interface DiscordApplicationWebhook {\n  /** The type of the webhook */\n  type: WebhookTypes.Application\n  /** The secure token of the webhook (returned for Incoming Webhooks) */\n  token?: string\n  /** The url used for executing the webhook (returned by the webhooks OAuth2 flow) */\n  url?: string\n\n  /** The id of the webhook */\n  id: string\n  /** The guild id this webhook is for */\n  guild_id?: string | null\n  /** The channel id this webhook is for */\n  channel_id?: string | null\n  /** The user this webhook was created by (not returned when getting a webhook with its token) */\n  user?: DiscordUser\n  /** The default name of the webhook */\n  name: string | null\n  /** The default user avatar hash of the webhook */\n  avatar: string | null\n  /** The bot/OAuth2 application that created this webhook */\n  application_id: string | null\n  /** The guild of the channel that this webhook is following (returned for Channel Follower Webhooks), field will be absent if the webhook creator has since lost access to the guild where the followed channel resides */\n  source_guild?: Partial<DiscordGuild>\n  /** The channel that this webhook is following (returned for Channel Follower Webhooks), field will be absent if the webhook creator has since lost access to the guild where the followed channel resides */\n  source_channel?: Partial<DiscordChannel>\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-object */\nexport interface DiscordGuild {\n  /** Guild name (2-100 characters, excluding trailing and leading whitespace) */\n  name: string\n  /** True if the user is the owner of the guild */\n  owner?: boolean\n  /** Afk timeout in seconds */\n  afk_timeout: number\n  /** True if the server widget is enabled */\n  widget_enabled?: boolean\n  /** Verification level required for the guild */\n  verification_level: VerificationLevels\n  /** Default message notifications level */\n  default_message_notifications: DefaultMessageNotificationLevels\n  /** Explicit content filter level */\n  explicit_content_filter: ExplicitContentFilterLevels\n  /** Enabled guild features */\n  features: GuildFeatures[]\n  /** Required MFA level for the guild */\n  mfa_level: MfaLevels\n  /** System channel flags */\n  system_channel_flags: SystemChannelFlags\n  /** True if this is considered a large guild */\n  large?: boolean\n  /** True if this guild is unavailable due to an outage */\n  unavailable?: boolean\n  /** Total number of members in this guild */\n  member_count?: number\n  /** The maximum number of presences for the guild (the default value, currently 25000, is in effect when null is returned) */\n  max_presences?: number | null\n  /** The maximum number of members for the guild */\n  max_members?: number\n  /** The vanity url code for the guild */\n  vanity_url_code: string | null\n  /** The description of a guild */\n  description: string | null\n  /** Premium tier (Server Boost level) */\n  premium_tier: PremiumTiers\n  /** The number of boosts this guild currently has */\n  premium_subscription_count?: number\n  /** The maximum amount of users in a video channel */\n  max_video_channel_users?: number\n  /** Maximum amount of users in a stage video channel */\n  max_stage_video_channel_users?: number\n  /** Approximate number of members in this guild, returned from the GET /guilds/id endpoint when with_counts is true */\n  approximate_member_count?: number\n  /** Approximate number of non-offline members in this guild, returned from the GET /guilds/id endpoint when with_counts is true */\n  approximate_presence_count?: number\n  /** Guild NSFW level */\n  nsfw_level: GuildNsfwLevel\n  /** Whether the guild has the boost progress bar enabled */\n  premium_progress_bar_enabled: boolean\n  /** Guild id */\n  id: string\n  /** Icon hash */\n  icon: string | null\n  /** Icon hash, returned when in the template object */\n  icon_hash?: string | null\n  /** Splash hash */\n  splash: string | null\n  /** Discovery splash hash; only present for guilds with the \"DISCOVERABLE\" feature */\n  discovery_splash: string | null\n  /** Id of the owner */\n  owner_id: string\n  /** Total permissions for the user in the guild (excludes overwrites and implicit permissions) */\n  permissions?: string\n  /** Id of afk channel */\n  afk_channel_id: string | null\n  /** The channel id that the widget will generate an invite to, or null if set to no invite */\n  widget_channel_id?: string | null\n  /** Roles in the guild */\n  roles: DiscordRole[]\n  /** Custom guild emojis */\n  emojis: DiscordEmoji[]\n  /** Application id of the guild creator if it is bot-created */\n  application_id: string | null\n  /** The id of the channel where guild notices such as welcome messages and boost events are posted */\n  system_channel_id: string | null\n  /** The id of the channel where community guilds can display rules and/or guidelines */\n  rules_channel_id: string | null\n  /** When this guild was joined at */\n  joined_at?: string\n  /** States of members currently in voice channels; lacks the guild_id key */\n  voice_states?: Omit<DiscordVoiceState, 'guildId'>[]\n  /** Users in the guild */\n  members?: DiscordMember[]\n  /** Channels in the guild */\n  channels?: DiscordChannel[]\n  /** All active threads in the guild that the current user has permission to view */\n  threads?: DiscordChannel[]\n  /** Presences of the members in the guild, will only include non-offline members if the size is greater than large threshold */\n  presences?: Partial<DiscordPresenceUpdate>[]\n  /** Banner hash */\n  banner: string | null\n  /** The preferred locale of a Community guild; used in server discovery and notices from Discord; defaults to \"en-US\" */\n  preferred_locale: string\n  /** The id of the channel where admins and moderators of Community guilds receive notices from Discord */\n  public_updates_channel_id: string | null\n  /** The welcome screen of a Community guild, shown to new members, returned in an Invite's guild object */\n  welcome_screen?: DiscordWelcomeScreen\n  /** Stage instances in the guild */\n  stage_instances?: DiscordStageInstance[]\n  /** Custom guild stickers */\n  stickers?: DiscordSticker[]\n  /** The id of the channel where admins and moderators of Community guilds receive safety alerts from Discord */\n  safety_alerts_channel_id: string | null\n  /**\n   * Soundboard sounds in the guild\n   *\n   * @remarks\n   * Only sent by the gateway\n   */\n  soundboard_sounds?: DiscordSoundboardSound[]\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-structure */\nexport interface DiscordRole {\n  /** Role id */\n  id: string\n  /** If this role is showed separately in the user listing */\n  hoist: boolean\n  /** Permission bit set */\n  permissions: string\n  /** Whether this role is managed by an integration */\n  managed: boolean\n  /** Whether this role is mentionable */\n  mentionable: boolean\n  /** The tags this role has */\n  tags?: DiscordRoleTags\n  /** the role emoji hash */\n  icon?: string\n  /** Role name */\n  name: string\n  /** Integer representation of hexadecimal color code */\n  color: number\n  /** Position of this role (roles with the same position are sorted by id) */\n  position: number\n  /** role unicode emoji */\n  unicode_emoji?: string\n  /** Role flags combined as a bitfield */\n  flags: RoleFlags\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-tags-structure */\nexport interface DiscordRoleTags {\n  /** The id of the bot this role belongs to */\n  bot_id?: string\n  /** The id of the integration this role belongs to */\n  integration_id?: string\n  /** Whether this is the guild's premium subscriber role */\n  premium_subscriber?: null\n  /** Id of this role's subscription sku and listing. */\n  subscription_listing_id?: string\n  /** Whether this role is available for purchase. */\n  available_for_purchase?: null\n  /** Whether this is a guild's linked role */\n  guild_connections?: null\n}\n\n/** https://discord.com/developers/docs/resources/emoji#emoji-object-emoji-structure */\nexport interface DiscordEmoji {\n  /** Emoji name (can only be null in reaction emoji objects) */\n  name?: string\n  /** Emoji id */\n  id?: string\n  /** Roles allowed to use this emoji */\n  roles?: string[]\n  /** User that created this emoji */\n  user?: DiscordUser\n  /** Whether this emoji must be wrapped in colons */\n  require_colons?: boolean\n  /** Whether this emoji is managed */\n  managed?: boolean\n  /** Whether this emoji is animated */\n  animated?: boolean\n  /** Whether this emoji can be used, may be false due to loss of Server Boosts */\n  available?: boolean\n}\n\n/** https://discord.com/developers/docs/resources/voice#voice-state-object-voice-state-structure */\nexport interface DiscordVoiceState {\n  /** The session id for this voice state */\n  session_id: string\n  /** The guild id this voice state is for */\n  guild_id?: string\n  /** The channel id this user is connected to */\n  channel_id: string | null\n  /** The user id this voice state is for */\n  user_id: string\n  /** The guild member this voice state is for */\n  member?: DiscordMemberWithUser\n  /** Whether this user is deafened by the server */\n  deaf: boolean\n  /** Whether this user is muted by the server */\n  mute: boolean\n  /** Whether this user is locally deafened */\n  self_deaf: boolean\n  /** Whether this user is locally muted */\n  self_mute: boolean\n  /** Whether this user is streaming using \"Go Live\" */\n  self_stream?: boolean\n  /** Whether this user's camera is enabled */\n  self_video: boolean\n  /** Whether this user is muted by the current user */\n  suppress: boolean\n  /** The time at which the user requested to speak */\n  request_to_speak_timestamp: string | null\n}\n\n/** https://discord.com/developers/docs/resources/channel#channel-object */\nexport interface DiscordChannel {\n  /** The id of the channel */\n  id: string\n  /** The type of channel */\n  type: ChannelTypes\n  /** The id of the guild */\n  guild_id?: string\n  /** Sorting position of the channel (channels with the same position are sorted by id) */\n  position?: number\n  /** Explicit permission overwrites for members and roles */\n  permission_overwrites?: DiscordOverwrite[]\n  /** The name of the channel (1-100 characters) */\n  name?: string\n  /** The channel topic (0-4096 characters for GUILD_FORUM channels, 0-1024 characters for all others) */\n  topic?: string | null\n  /** Whether the channel is nsfw */\n  nsfw?: boolean\n  /** The id of the last message sent in this channel (may not point to an existing or valid message) */\n  last_message_id?: string | null\n  /** The bitrate (in bits) of the voice or stage channel */\n  bitrate?: number\n  /** The user limit of the voice or stage channel */\n  user_limit?: number\n  /** Amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission `manage_messages` or `manage_channel`, are unaffected */\n  rate_limit_per_user?: number\n  /** the recipients of the DM */\n  recipients?: DiscordUser[]\n  /** icon hash of the group DM */\n  icon?: string\n  /** Id of the creator of the thread */\n  owner_id?: string\n  /** Application id of the group DM creator if it is bot-created */\n  application_id?: string\n  /** For group DM channels: whether the channel is managed by an application via the `gdm.join` OAuth2 scope. */\n  managed?: boolean\n  /** For guild channels: Id of the parent category for a channel (each parent category can contain up to 50 channels), for threads: id of the text channel this thread was created */\n  parent_id?: string | null\n  /** When the last pinned message was pinned. This may be null in events such as GUILD_CREATE when a message is not pinned. */\n  last_pin_timestamp?: string | null\n  /** Voice region id for the voice or stage channel, automatic when set to null */\n  rtc_region?: string | null\n  /** The camera video quality mode of the voice channel, 1 when not present */\n  video_quality_mode?: VideoQualityModes\n  /** An approximate count of messages in a thread, stops counting at 50 */\n  message_count?: number\n  /** An approximate count of users in a thread, stops counting at 50 */\n  member_count?: number\n  /** Thread-specific fields not needed by other channels */\n  thread_metadata?: DiscordThreadMetadata\n  /** Thread member object for the current user, if they have joined the thread, only included on certain API endpoints */\n  member?: DiscordThreadMember\n  /** Default duration for newly created threads, in minutes, to automatically archive the thread after recent activity, can be set to: 60, 1440, 4320, 10080 */\n  default_auto_archive_duration?: number\n  /** computed permissions for the invoking user in the channel, including overwrites, only included when part of the resolved data received on a slash command interaction. This does not include implicit permissions, which may need to be checked separately. */\n  permissions?: string\n  /** The flags of the channel */\n  flags?: ChannelFlags\n  /** number of messages ever sent in a thread, it's similar to `message_count` on message creation, but will not decrement the number when a message is deleted */\n  total_message_sent?: number\n  /** The set of tags that can be used in a GUILD_FORUM channel */\n  available_tags?: DiscordForumTag[]\n  /** The IDs of the set of tags that have been applied to a thread in a GUILD_FORUM channel */\n  applied_tags?: string[]\n  /** the emoji to show in the add reaction button on a thread in a GUILD_FORUM channel */\n  default_reaction_emoji?: DiscordDefaultReactionEmoji | null\n  /** the initial rate_limit_per_user to set on newly created threads in a channel. this field is copied to the thread at creation time and does not live update. */\n  default_thread_rate_limit_per_user?: number\n  /** the default sort order type used to order posts in GUILD_FORUM channels. Defaults to null, which indicates a preferred sort order hasn't been set by a channel admin */\n  default_sort_order?: SortOrderTypes | null\n  /** the default forum layout view used to display posts in `GUILD_FORUM` channels. Defaults to `0`, which indicates a layout view has not been set by a channel admin */\n  default_forum_layout?: ForumLayout\n  /** When a thread is created this will be true on that channel payload for the thread. */\n  newly_created?: boolean\n}\n\n/** https://discord.com/developers/docs/events/gateway#presence-update */\nexport interface DiscordPresenceUpdate {\n  /** Either \"idle\", \"dnd\", \"online\", or \"offline\" */\n  status: 'idle' | 'dnd' | 'online' | 'offline'\n  /** The user presence is being updated for */\n  user: DiscordUser\n  /** id of the guild */\n  guild_id: string\n  /** User's current activities */\n  activities: DiscordActivity[]\n  /** User's platform-dependent status */\n  client_status: DiscordClientStatus\n}\n\n/** https://discord.com/developers/docs/resources/guild#welcome-screen-object-welcome-screen-structure */\nexport interface DiscordWelcomeScreen {\n  /** The server description shown in the welcome screen */\n  description: string | null\n  /** The channels shown in the welcome screen, up to 5 */\n  welcome_channels: DiscordWelcomeScreenChannel[]\n}\n\n/** https://discord.com/developers/docs/resources/guild#welcome-screen-object-welcome-screen-channel-structure */\nexport interface DiscordWelcomeScreenChannel {\n  /** The description shown for the channel */\n  description: string\n  /** The channel's id */\n  channel_id: string\n  /** The emoji id, if the emoji is custom */\n  emoji_id: string | null\n  /** The emoji name if custom, the unicode character if standard, or `null` if no emoji is set */\n  emoji_name: string | null\n}\n\n/** https://discord.com/developers/docs/resources/stage-instance#auto-closing-stage-instance-structure */\nexport interface DiscordStageInstance {\n  /** The topic of the Stage instance (1-120 characters) */\n  topic: string\n  /** The id of this Stage instance */\n  id: string\n  /** The guild id of the associated Stage channel */\n  guild_id: string\n  /** The id of the associated Stage channel */\n  channel_id: string\n  /** The id of the scheduled event for this Stage instance */\n  guild_scheduled_event_id?: string\n}\n\nexport interface DiscordThreadMetadata {\n  /** Whether the thread is archived */\n  archived: boolean\n  /** Duration in minutes to automatically archive the thread after recent activity */\n  auto_archive_duration: 60 | 1440 | 4320 | 10080\n  /** When a thread is locked, only users with `MANAGE_THREADS` can unarchive it */\n  locked: boolean\n  /** whether non-moderators can add other non-moderators to a thread; only available on private threads */\n  invitable?: boolean\n  /** Timestamp when the thread's archive status was last changed, used for calculating recent activity */\n  archive_timestamp: string\n  /** Timestamp when the thread was created; only populated for threads created after 2022-01-09 */\n  create_timestamp?: string | null\n}\n\nexport interface DiscordThreadMember {\n  /** Any user-thread settings, currently only used for notifications */\n  flags: number\n  /** The id of the thread */\n  id: string\n  /** The id of the user */\n  user_id: string\n  /** The time the current user last joined the thread */\n  join_timestamp: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#activity-object */\nexport interface DiscordActivity {\n  /** The activity's name */\n  name: string\n  /** Activity type */\n  type: ActivityTypes\n  /** Stream url, is validated when type is 1 */\n  url?: string | null\n  /** Unix timestamp of when the activity was added to the user's session */\n  created_at: number\n  /** What the player is currently doing */\n  details?: string | null\n  /** The user's current party status */\n  state?: string | null\n  /** Whether or not the activity is an instanced game session */\n  instance?: boolean\n  /** Activity flags `OR`d together, describes what the payload includes */\n  flags?: number\n  /** Unix timestamps for start and/or end of the game */\n  timestamps?: DiscordActivityTimestamps\n  /** Application id for the game */\n  application_id?: string\n  /** The emoji used for a custom status */\n  emoji?: DiscordActivityEmoji | null\n  /** Information for the current party of the player */\n  party?: DiscordActivityParty\n  /** Images for the presence and their hover texts */\n  assets?: DiscordActivityAssets\n  /** Secrets for Rich Presence joining and spectating */\n  secrets?: DiscordActivitySecrets\n  /** The custom buttons shown in the Rich Presence (max 2) */\n  buttons?: DiscordActivityButton[]\n}\n\n/** https://discord.com/developers/docs/resources/application#get-application-activity-instance-activity-instance-object */\nexport interface DiscordActivityInstance {\n  /** Application ID */\n  application_id: string\n  /** Activity Instance ID */\n  instance_id: string\n  /** Unique identifier for the launch */\n  launch_id: string\n  /** The Location the instance is runnning in */\n  location: DiscordActivityLocation\n  /** The IDs of the Users currently connected to the instance */\n  users: string[]\n}\n\n/** https://discord.com/developers/docs/resources/application#get-application-activity-instance-activity-location-object */\nexport interface DiscordActivityLocation {\n  /** The unique identifier for the location */\n  id: string\n  /** Enum describing kind of location */\n  kind: DiscordActivityLocationKind\n  /** The id of the Channel */\n  channel_id: string\n  /** The id of the Guild */\n  guild_id?: string | null\n}\n\n/** https://discord.com/developers/docs/resources/application#get-application-activity-instance-activity-location-kind-enum */\nexport enum DiscordActivityLocationKind {\n  /** The Location is a Guild Channel */\n  GuildChannel = 'gc',\n  /** The Location is a Private Channel, such as a DM or GDM */\n  PrivateChannel = 'pc',\n}\n\n/** https://discord.com/developers/docs/events/gateway#client-status-object */\nexport interface DiscordClientStatus {\n  /** The user's status set for an active desktop (Windows, Linux, Mac) application session */\n  desktop?: string\n  /** The user's status set for an active mobile (iOS, Android) application session */\n  mobile?: string\n  /** The user's status set for an active web (browser, bot account) application session */\n  web?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#activity-object-activity-timestamps */\nexport interface DiscordActivityTimestamps {\n  /** Unix time (in milliseconds) of when the activity started */\n  start?: number\n  /** Unix time (in milliseconds) of when the activity ends */\n  end?: number\n}\n\n/** https://discord.com/developers/docs/events/gateway#activity-object-activity-emoji */\nexport interface DiscordActivityEmoji {\n  /** The name of the emoji */\n  name: string\n  /** Whether this emoji is animated */\n  animated?: boolean\n  /** The id of the emoji */\n  id?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#activity-object-activity-party */\nexport interface DiscordActivityParty {\n  /** Used to show the party's current and maximum size */\n  size?: [currentSize: number, maxSize: number]\n  /** The id of the party */\n  id?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#activity-object-activity-assets */\nexport interface DiscordActivityAssets {\n  /** Text displayed when hovering over the large image of the activity */\n  large_text?: string\n  /** Text displayed when hovering over the small image of the activity */\n  small_text?: string\n  /** The id for a large asset of the activity, usually a snowflake */\n  large_image?: string\n  /** The id for a small asset of the activity, usually a snowflake */\n  small_image?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#activity-object-activity-secrets */\nexport interface DiscordActivitySecrets {\n  /** The secret for joining a party */\n  join?: string\n  /** The secret for spectating a game */\n  spectate?: string\n  /** The secret for a specific instanced match */\n  match?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#activity-object-activity-buttons */\nexport interface DiscordActivityButton {\n  /** The text shown on the button (1-32 characters) */\n  label: string\n  /** The url opened when clicking the button (1-512 characters) */\n  url: string\n}\n\nexport interface DiscordOverwrite {\n  /** Either 0 (role) or 1 (member) */\n  type: OverwriteTypes\n  /** Role or user id */\n  id: string\n  /** Permission bit set */\n  allow?: string\n  /** Permission bit set */\n  deny?: string\n}\n\nexport interface DiscordMemberWithUser extends DiscordMember {\n  /** The user object for this member */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-object */\nexport interface DiscordMessage {\n  /** id of the message */\n  id: string\n  /** id of the channel the message was sent in */\n  channel_id: string\n  /**\n   * id of the guild the message was sent in\n   * Note: For MESSAGE_CREATE and MESSAGE_UPDATE events, the message object may not contain a guild_id or member field since the events are sent directly to the receiving user and the bot who sent the message, rather than being sent through the guild like non-ephemeral messages.\n   */\n  guild_id?: string\n  /**\n   * The author of this message (not guaranteed to be a valid user)\n   * Note: The author object follows the structure of the user object, but is only a valid user in the case where the message is generated by a user or bot user. If the message is generated by a webhook, the author object corresponds to the webhook's id, username, and avatar. You can tell if a message is generated by a webhook by checking for the webhook_id on the message object.\n   */\n  author: DiscordUser\n  /**\n   * Member properties for this message's author\n   * Note: The member object exists in `MESSAGE_CREATE` and `MESSAGE_UPDATE` events from text-based guild channels. This allows bots to obtain real-time member data without requiring bots to store member state in memory.\n   */\n  member?: DiscordMember\n  /** Contents of the message */\n  content?: string\n  /** When this message was sent */\n  timestamp: string\n  /** When this message was edited (or null if never) */\n  edited_timestamp: string | null\n  /** Whether this was a TTS message */\n  tts: boolean\n  /** Whether this message mentions everyone */\n  mention_everyone: boolean\n  /**\n   * Users specifically mentioned in the message\n   * Note: The user objects in the mentions array will only have the partial member field present in `MESSAGE_CREATE` and `MESSAGE_UPDATE` events from text-based guild channels.\n   */\n  mentions: Array<DiscordUser & { member?: Partial<DiscordMember> }>\n  /** Roles specifically mentioned in this message */\n  mention_roles?: string[]\n  /**\n   * Channels specifically mentioned in this message\n   * Note: Not all channel mentions in a message will appear in `mention_channels`. Only textual channels that are visible to everyone in a discoverable guild will ever be included. Only crossposted messages (via Channel Following) currently include `mention_channels` at all. If no mentions in the message meet these requirements, this field will not be sent.\n   */\n  mention_channels?: DiscordChannelMention[]\n  /** Any attached files */\n  attachments: DiscordAttachment[]\n  /** Any embedded content */\n  embeds: DiscordEmbed[]\n  /** Reactions to the message */\n  reactions?: DiscordReaction[]\n  /** Used for validating a message was sent */\n  nonce?: number | string\n  /** Whether this message is pinned */\n  pinned: boolean\n  /** If the message is generated by a webhook, this is the webhook's id */\n  webhook_id?: string\n  /** Type of message */\n  type: MessageTypes\n  /** Sent with Rich Presence-related chat embeds */\n  activity?: DiscordMessageActivity\n  /** Sent with Rich Presence-related chat embeds */\n  application?: Partial<DiscordApplication>\n  /** if the message is an Interaction or application-owned webhook, this is the id of the application */\n  application_id?: string\n  /** Data showing the source of a crosspost, channel follow add, pin, or reply message */\n  message_reference?: Omit<DiscordMessageReference, 'failIfNotExists'>\n  /** Message flags combined as a bitfield */\n  flags?: MessageFlags\n  /**\n   * The stickers sent with the message (bots currently can only receive messages with stickers, not send)\n   * @deprecated\n   */\n  stickers?: DiscordSticker[]\n  /**\n   * The message associated with the 'message_reference'\n   * Note: This field is only returned for messages with a 'type' of '19', '21', or '23'. If the message is one of these but the 'referenced_message' field is not present, the backend did not attempt to fetch the message that was being replied to, so its state is unknown. If the field exists but is null, the referenced message was deleted.\n   */\n  referenced_message?: DiscordMessage\n  /** The message associated with the `message_reference`. This is a minimal subset of fields in a message (e.g. `author` is excluded.)  */\n  message_snapshots?: DiscordMessageSnapshot[]\n  /** sent if the message is sent as a result of an interaction */\n  interaction_metadata?: DiscordMessageInteractionMetadata\n  /**\n   * Sent if the message is a response to an Interaction\n   *\n   * @deprecated Deprecated in favor of {@link interaction_metadata}\n   */\n  interaction?: DiscordMessageInteraction\n  /** The thread that was started from this message, includes thread member object */\n  thread?: Omit<DiscordChannel, 'member'> & { member: DiscordThreadMember }\n  /** The components related to this message */\n  components?: DiscordMessageComponents\n  /** Sent if the message contains stickers */\n  sticker_items?: DiscordStickerItem[]\n  /** A generally increasing integer (there may be gaps or duplicates) that represents the approximate position of the message in a thread, it can be used to estimate the relative position of the message in a thread in company with `total_message_sent` on parent thread */\n  position?: number\n  /** The poll object */\n  poll?: DiscordPoll\n  /** The call associated with the message */\n  call?: DiscordMessageCall\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-call-object */\nexport interface DiscordMessageCall {\n  /** Array of user object ids that participated in the call */\n  participants: string[]\n  /** Time when call ended */\n  ended_timestamp: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#channel-mention-object */\nexport interface DiscordChannelMention {\n  /** id of the channel */\n  id: string\n  /** id of the guild containing the channel */\n  guild_id: string\n  /** The type of channel */\n  type: number\n  /** The name of the channel */\n  name: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#reaction-object */\nexport interface DiscordReaction {\n  /** Total number of times this emoji has been used to react (including super reacts) */\n  count: number\n  /**\tReaction count details object */\n  count_details: DiscordReactionCountDetails\n  /** Whether the current user reacted using this emoji */\n  me: boolean\n  /**\tWhether the current user super-reacted using this emoji */\n  me_burst: boolean\n  /** Emoji information */\n  emoji: Partial<DiscordEmoji>\n  /** HEX colors used for super reaction */\n  burst_colors: string[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#get-reactions-reaction-types */\nexport enum DiscordReactionType {\n  Normal,\n  Burst,\n}\n\n/** https://discord.com/developers/docs/resources/channel#reaction-count-details-object */\nexport interface DiscordReactionCountDetails {\n  /** Count of super reactions */\n  burst: number\n  /**\tCount of normal reactions */\n  normal: number\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-object-message-activity-structure */\nexport interface DiscordMessageActivity {\n  /** Type of message activity */\n  type: MessageActivityTypes\n  /** `party_id` from a Rich Presence event */\n  party_id?: string\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-object-message-reference-structure */\nexport interface DiscordMessageReference {\n  /** Type of reference */\n  type?: DiscordMessageReferenceType\n  /** id of the originating message */\n  message_id?: string\n  /**\n   * id of the originating message's channel\n   * Note: `channel_id` is optional when creating a reply, but will always be present when receiving an event/response that includes this data model.\n   */\n  channel_id?: string\n  /** id of the originating message's guild */\n  guild_id?: string\n  /** When sending, whether to error if the referenced message doesn't exist instead of sending as a normal (non-reply) message, default true */\n  fail_if_not_exists: boolean\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-reference-object-message-reference-types */\nexport enum DiscordMessageReferenceType {\n  /**\n   * A standard reference used by replies.\n   *\n   * @remarks\n   * When the type is set to this value, the field referenced_message on the message will be present\n   */\n  Default,\n  /**\n   * Reference used to point to a message at a point in time.\n   *\n   * @remarks\n   * When the type is set to this value, the field message_snapshot on the message will be present\n   *\n   * This value can only be used for basic messages;\n   * i.e. messages which do not have strong bindings to a non global entity.\n   * Thus we support only messages with `DEFAULT` or `REPLY` types, but disallowed if there are any polls, calls, or components.\n   */\n  Forward,\n}\n\n/** https://discord.com/developers/docs/resources/channel#message-snapshot-object-message-snapshot-structure */\nexport interface DiscordMessageSnapshot {\n  /** Minimal subset of fields in the forwarded message */\n  message: Pick<\n    DiscordMessage,\n    | 'type'\n    | 'content'\n    | 'embeds'\n    | 'attachments'\n    | 'timestamp'\n    | 'edited_timestamp'\n    | 'flags'\n    | 'mentions'\n    | 'mention_roles'\n    | 'stickers'\n    | 'sticker_items'\n    | 'components'\n  >\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-object */\nexport interface DiscordPoll {\n  /** The question of the poll. Only `text` is supported. */\n  question: DiscordPollMedia\n  /** Each of the answers available in the poll. There is a maximum of 10 answers per poll. */\n  answers: DiscordPollAnswer[]\n  /**\n   * The time when the poll ends.\n   *\n   * @remarks\n   * `expiry` is marked as nullable to support non-expiring polls in the future, but all polls have an expiry currently.\n   */\n  expiry: string | null\n  /** Whether a user can select multiple answers */\n  allow_multiselect: boolean\n  /** The layout type of the poll */\n  layout_type: DiscordPollLayoutType\n  /**\n   * The results of the poll\n   *\n   * @remarks\n   * This value will not be sent by discord under specific conditions where they don't fetch them on their backend. When this value is missing it should be interpreted as \"Unknown results\" and not as \"No results\"\n   * The results may not be totally accurate while the poll has not ended. When it ends discord will re-calculate all the results and set {@link DiscordPollResult.is_finalized} to true\n   */\n  results?: DiscordPollResult\n}\n\n/** https://discord.com/developers/docs/resources/poll#layout-type */\nexport enum DiscordPollLayoutType {\n  /** The default layout */\n  Default = 1,\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-media-object */\nexport interface DiscordPollMedia {\n  /**\n   * The text of the field\n   *\n   * @remarks\n   * `text` should always be non-null for both questions and answers, but this is subject to changes.\n   * The maximum length of `text` is 300 for the question, and 55 for any answer.\n   */\n  text?: string\n  /**\n   * The emoji of the field\n   *\n   * @remarks\n   * When creating a poll answer with an emoji, one only needs to send either the `id` (custom emoji) or `name` (default emoji) as the only field.\n   */\n  emoji?: Partial<DiscordEmoji>\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-answer-object */\nexport interface DiscordPollAnswer {\n  /**\n   * The id of the answer\n   *\n   * @remarks\n   * This id labels each answer. It starts at 1 and goes up sequentially. Discord recommend against depending on this value as is a implementation detail.\n   */\n  answer_id: number\n  /** The data of the answer */\n  poll_media: DiscordPollMedia\n}\n\nexport interface DiscordPollAnswerCount {\n  /** The {@link DiscordPollAnswer.answer_id | answer_id} */\n  id: number\n  /** The number of votes for this answer */\n  count: number\n  /** Whether the current user voted for this answer */\n  me_voted: boolean\n}\n\n/** https://discord.com/developers/docs/resources/poll#poll-results-object */\nexport interface DiscordPollResult {\n  /** Whether the votes have been precisely counted */\n  is_finalized: boolean\n  /** The counts for each answer */\n  answer_counts: DiscordPollAnswerCount[]\n}\n\n/** https://discord.com/developers/docs/resources/poll#get-answer-voters-response-body */\nexport interface DiscordGetAnswerVotesResponse {\n  /** Users who voted for this answer */\n  users: DiscordUser[]\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-poll-vote-add */\nexport interface DiscordPollVoteAdd {\n  /** ID of the user. Usually a snowflake */\n  user_id: string\n  /** ID of the channel. Usually a snowflake */\n  channel_id: string\n  /** ID of the message. Usually a snowflake */\n  message_id: string\n  /** ID of the guild. Usually a snowflake */\n  guild_id?: string\n  /** ID of the answer. */\n  answer_id: number\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-poll-vote-remove */\nexport interface DiscordPollVoteRemove {\n  /** ID of the user. Usually a snowflake */\n  user_id: string\n  /** ID of the channel. Usually a snowflake */\n  channel_id: string\n  /** ID of the message. Usually a snowflake */\n  message_id: string\n  /** ID of the guild. Usually a snowflake */\n  guild_id?: string\n  /** ID of the answer. */\n  answer_id: number\n}\n\n/** https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-structure */\nexport interface DiscordSticker {\n  /** [Id of the sticker](https://discord.com/developers/docs/reference#image-formatting) */\n  id: string\n  /** Id of the pack the sticker is from */\n  pack_id?: string\n  /** Name of the sticker */\n  name: string\n  /** Description of the sticker */\n  description: string\n  /** a unicode emoji representing the sticker's expression */\n  tags: string\n  /** [type of sticker](https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-types) */\n  type: StickerTypes\n  /** [Type of sticker format](https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-format-types) */\n  format_type: StickerFormatTypes\n  /**  Whether or not the sticker is available */\n  available?: boolean\n  /** Id of the guild that owns this sticker */\n  guild_id?: string\n  /** The user that uploaded the sticker */\n  user?: DiscordUser\n  /** A sticker's sort order within a pack */\n  sort_value?: number\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#message-interaction-object-message-interaction-structure */\nexport interface DiscordMessageInteraction {\n  /** Id of the interaction */\n  id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** The name of the ApplicationCommand including the name of the subcommand/subcommand group */\n  name: string\n  /** The user who invoked the interaction */\n  user: DiscordUser\n  /** The member who invoked the interaction in the guild */\n  member?: Partial<DiscordMember>\n}\n\n/** https://discord.com/developers/docs/resources/message#message-interaction-metadata-object */\nexport type DiscordMessageInteractionMetadata =\n  | DiscordApplicationCommandInteractionMetadata\n  | DiscordMessageComponentInteractionMetadata\n  | DiscordModalSubmitInteractionMetadata\n\n/** https://discord.com/developers/docs/resources/message#message-interaction-metadata-object-application-command-interaction-metadata-structure */\nexport interface DiscordApplicationCommandInteractionMetadata {\n  /** Id of the interaction */\n  id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** User who triggered the interaction */\n  user: DiscordUser\n  /** IDs for installation context(s) related to an interaction */\n  authorizing_integration_owners: Partial<Record<`${DiscordApplicationIntegrationType}`, string>>\n  /** ID of the original response message, present only on follow-up messages */\n  original_response_message_id?: string\n  /** The user the command was run on, present only on user command interactions */\n  target_user?: DiscordUser\n  /** The ID of the message the command was run on, present only on message command interactions. The original response message will also have message_reference and referenced_message pointing to this message. */\n  target_message_id?: string\n}\n\n/** https://discord.com/developers/docs/resources/message#message-interaction-metadata-object-message-component-interaction-metadata-structure */\nexport interface DiscordMessageComponentInteractionMetadata {\n  id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** User who triggered the interaction */\n  user: DiscordUser\n  /** IDs for installation context(s) related to an interaction */\n  authorizing_integration_owners: Partial<Record<`${DiscordApplicationIntegrationType}`, string>>\n  /** ID of the original response message, present only on follow-up messages */\n  original_response_message_id?: string\n  /** ID of the message that contained interactive component, present only on messages created from component interactions */\n  interacted_message_id?: string\n}\n\n/** https://discord.com/developers/docs/resources/message#message-interaction-metadata-object-modal-submit-interaction-metadata-structure */\nexport interface DiscordModalSubmitInteractionMetadata {\n  id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** User who triggered the interaction */\n  user: DiscordUser\n  /** IDs for installation context(s) related to an interaction */\n  authorizing_integration_owners: Partial<Record<`${DiscordApplicationIntegrationType}`, string>>\n  /** ID of the original response message, present only on follow-up messages */\n  original_response_message_id?: string\n  /** Metadata for the interaction that was used to open the modal, present only on modal submit interactions */\n  triggering_interaction_metadata?: DiscordMessageInteractionMetadata\n}\n\nexport type DiscordMessageComponents = DiscordMessageComponent[]\nexport type DiscordMessageComponent = DiscordActionRow | DiscordSelectMenuComponent | DiscordButtonComponent | DiscordInputTextComponent\n\n/** https://discord.com/developers/docs/interactions/message-components#actionrow */\nexport interface DiscordActionRow {\n  /** Action rows are a group of buttons. */\n  type: MessageComponentTypes.ActionRow\n  /** The components in this row */\n  components: Exclude<DiscordMessageComponent, DiscordActionRow>[]\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#select-menu-object */\nexport interface DiscordSelectMenuComponent {\n  type:\n    | MessageComponentTypes.SelectMenu\n    | MessageComponentTypes.SelectMenuChannels\n    | MessageComponentTypes.SelectMenuRoles\n    | MessageComponentTypes.SelectMenuUsers\n    | MessageComponentTypes.SelectMenuUsersAndRoles\n  /** A custom identifier for this component. Maximum 100 characters. */\n  custom_id: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /** The minimum number of items that must be selected. Default 1. Between 1-25. */\n  min_values?: number\n  /** The maximum number of items that can be selected. Default 1. Between 1-25. */\n  max_values?: number\n  /**\n   * List of default values for auto-populated select menu components\n   *\n   * @remarks\n   * The number of default values must be in the range defined by min_values and max_values\n   */\n  default_values?: DiscordSelectMenuDefaultValue[]\n  /** List of channel types to include in a channel select menu options list */\n  channel_types?: ChannelTypes[]\n  /** The choices! Maximum of 25 items. */\n  options?: DiscordSelectOption[]\n  /**\n   * Whether select menu is disabled\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\nexport interface DiscordSelectOption {\n  /** The user-facing name of the option. Maximum 25 characters. */\n  label: string\n  /** The dev-defined value of the option. Maximum 100 characters. */\n  value: string\n  /** An additional description of the option. Maximum 50 characters. */\n  description?: string\n  /** The id, name, and animated properties of an emoji. */\n  emoji?: {\n    /** Emoji id */\n    id?: string\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /** Will render this option as already-selected by default. */\n  default?: boolean\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#select-menu-object-select-default-value-structure */\nexport interface DiscordSelectMenuDefaultValue {\n  /** ID of a user, role, or channel */\n  id: bigint\n  /** Type of value that id represents. */\n  type: 'user' | 'role' | 'channel'\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#buttons-button-object */\nexport interface DiscordButtonComponent {\n  /** All button components have type 2 */\n  type: MessageComponentTypes.Button\n  /**\n   * Text that appears on the button\n   *\n   * @remarks\n   * A label can have a max of 80 characters\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have a label\n   */\n  label?: string\n  /**\n   * A dev-defined unique string sent on click (max 100 characters).\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Link | Link} or {@link ButtonStyles.Premium | Premium} cannot have a custom_id\n   */\n  custom_id?: string\n  /** For different styles/colors of the buttons */\n  style: ButtonStyles\n  /**\n   * Emoji object that includes fields of name, id, and animated supporting unicode and custom emojis.\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have an emoji\n   */\n  emoji?: {\n    /** Emoji id */\n    id?: string\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /**\n   * Url for {@link ButtonStyles.Link | link} buttons that can navigate a user to the web.\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Link | Link} must have an url, any other button with a different style can not have an url\n   */\n  url?: string\n  /** Whether or not this button is disabled */\n  disabled?: boolean\n  /**\n   * SKU for {@link ButtonStyles.Premium | premium} buttons that can navigate a user to the application shop.\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Premium | Premium} must have a sku_id, any other button with a different style can not have a a sku_id\n   */\n  sku_id?: string\n}\n\n/** https://discord.com/developers/docs/interactions/message-components#text-inputs-text-input-structure */\nexport interface DiscordInputTextComponent {\n  /** InputText Component is of type 3 */\n  type: MessageComponentTypes.InputText\n  /** The style of the InputText */\n  style: TextStyles\n  /** whether this component is required to be filled, default true */\n  required?: boolean\n  /** The customId of the InputText */\n  custom_id: string\n  /** The label of the InputText (max 45 characters) */\n  label: string\n  /** The placeholder of the InputText */\n  placeholder?: string\n  /** The minimum length of the text the user has to provide */\n  min_length?: number\n  /** The maximum length of the text the user has to provide */\n  max_length?: number\n  /** Pre-filled value for input text. */\n  value?: string\n}\n\n/** https://discord.com/developers/docs/resources/sticker#sticker-item-object-sticker-item-structure */\nexport interface DiscordStickerItem {\n  /** Id of the sticker */\n  id: string\n  /** Name of the sticker */\n  name: string\n  /** [Type of sticker format](https://discord.com/developers/docs/resources/sticker#sticker-object-sticker-format-types) */\n  format_type: StickerFormatTypes\n}\n\n/** https://discord.com/developers/docs/resources/sticker#sticker-pack-object-sticker-pack-structure */\nexport interface DiscordStickerPack {\n  /** id of the sticker pack */\n  id: string\n  /** the stickers in the pack */\n  stickers: DiscordSticker[]\n  /** name of the sticker pack */\n  name: string\n  /** id of the pack's SKU */\n  sku_id: string\n  /** id of a sticker in the pack which is shown as the pack's icon */\n  cover_sticker_id?: string\n  /** description of the sticker pack */\n  description: string\n  /** id of the sticker pack's [banner image](https://discord.com/developers/docs/reference#image-formatting) */\n  banner_asset_id?: string\n}\n\nexport interface DiscordInteraction {\n  /** Id of the interaction */\n  id: string\n  /** Id of the application this interaction is for */\n  application_id: string\n  /** The type of interaction */\n  type: InteractionTypes\n  /** Guild that the interaction was sent from */\n  guild?: Partial<DiscordGuild>\n  /** The guild it was sent from */\n  guild_id?: string\n  /** The channel it was sent from */\n  channel: Partial<DiscordChannel>\n  /**\n   * The ID of channel it was sent from\n   *\n   * @remarks\n   * It is recommended that you begin using this channel field to identify the source channel of the interaction as they may deprecate the existing channel_id field in the future.\n   */\n  channel_id?: string\n  /** Guild member data for the invoking user, including permissions */\n  member?: DiscordInteractionMember\n  /** User object for the invoking user, if invoked in a DM */\n  user?: DiscordUser\n  /** A continuation token for responding to the interaction */\n  token: string\n  /** Read-only property, always `1` */\n  version: 1\n  /** For the message the button was attached to */\n  message?: DiscordMessage\n  /** the command data payload */\n  data?: DiscordInteractionData\n  /** The selected language of the invoking user */\n  locale?: string\n  /** The guild's preferred locale, if invoked in a guild */\n  guild_locale?: string\n  /** The computed permissions for a bot or app in the context of a specific interaction (including channel overwrites) */\n  app_permissions: string\n  /** For monetized apps, any entitlements for the invoking user, representing access to premium SKUs */\n  entitlements: DiscordEntitlement[]\n  /** Mapping of installation contexts that the interaction was authorized for to related user or guild IDs. */\n  authorizing_integration_owners: Partial<Record<DiscordApplicationIntegrationType, string>>\n  /** Context where the interaction was triggered from */\n  context?: DiscordInteractionContextType\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback-interaction-callback-response-object */\nexport interface DiscordInteractionCallbackResponse {\n  /** The interaction object associated with the interaction response */\n  interaction: DiscordInteractionCallback\n  /** The resource that was created by the interaction response. */\n  resource?: DiscordInteractionResource\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback-interaction-callback-object */\nexport interface DiscordInteractionCallback {\n  /** ID of the interaction */\n  id: string\n  /** Interaction type */\n  type: InteractionTypes\n  /** Instance ID of the Activity if one was launched or joined */\n  activity_instance_id?: string\n  /** ID of the message that was created by the interaction */\n  response_message_id?: string\n  /** Whether or not the message is in a loading state */\n  response_message_loading?: boolean\n  /** Whether or not the response message was ephemeral */\n  response_message_ephemeral?: boolean\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback-interaction-callback-resource-object */\nexport interface DiscordInteractionResource {\n  type: InteractionResponseTypes\n  /**\n   * Represents the Activity launched by this interaction.\n   *\n   * @remarks\n   * Only present if type is `LAUNCH_ACTIVITY`.\n   */\n  activity_instance?: DiscordActivityInstanceResource\n  /**\n   * Message created by the interaction.\n   *\n   * @remarks\n   * Only present if type is either `CHANNEL_MESSAGE_WITH_SOURCE` or `UPDATE_MESSAGE`.\n   */\n  message?: DiscordMessage\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback-interaction-callback-activity-instance-resource */\nexport interface DiscordActivityInstanceResource {\n  /** Instance ID of the Activity if one was launched or joined. */\n  id: string\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-member-object */\nexport interface DiscordInteractionMember extends DiscordMemberWithUser {\n  /** Total permissions of the member in the channel, including overwrites, returned when in the interaction object */\n  permissions: string\n}\n\nexport interface DiscordInteractionData {\n  /** The type of component */\n  component_type?: MessageComponentTypes\n  /** The custom id provided for this component. */\n  custom_id?: string\n  /** The components if its a Modal Submit interaction. */\n  components?: DiscordMessageComponents\n  /** The values chosen by the user. */\n  values?: string[]\n  /** The Id of the invoked command */\n  id: string\n  /** The name of the invoked command */\n  name: string\n  /** the type of the invoked command */\n  type: ApplicationCommandTypes\n  /** Converted users + roles + channels + attachments */\n  resolved?: {\n    /** The Ids and Message objects */\n    messages?: Record<string, DiscordMessage>\n    /** The Ids and User objects */\n    users?: Record<string, DiscordUser>\n    /** The Ids and partial Member objects */\n    members?: Record<string, Omit<DiscordInteractionMember, 'user' | 'deaf' | 'mute'>>\n    /** The Ids and Role objects */\n    roles?: Record<string, DiscordRole>\n    /** The Ids and partial Channel objects */\n    channels?: Record<string, Pick<DiscordChannel, 'id' | 'name' | 'type' | 'permissions'>>\n    /** The ids and attachment objects */\n    attachments: Record<string, DiscordAttachment>\n  }\n  /** The params + values from the user */\n  options?: DiscordInteractionDataOption[]\n  /** The target id if this is a context menu command. */\n  target_id?: string\n  /** the id of the guild the command is registered to */\n  guild_id?: string\n}\n\nexport interface DiscordInteractionDataOption {\n  /** Name of the parameter */\n  name: string\n  /** Value of application command option type */\n  type: ApplicationCommandOptionTypes\n  /** Value of the option resulting from user input */\n  value?: string | boolean | number\n  /** Present if this option is a group or subcommand */\n  options?: DiscordInteractionDataOption[]\n  /** `true` if this option is the currently focused option for autocomplete */\n  focused?: boolean\n}\n\nexport interface DiscordListActiveThreads {\n  /** The active threads */\n  threads: DiscordChannel[]\n  /** A thread member object for each returned thread the current user has joined */\n  members: DiscordThreadMember[]\n}\n\nexport interface DiscordListArchivedThreads extends DiscordListActiveThreads {\n  /** Whether there are potentially additional threads that could be returned on a subsequent call */\n  has_more: boolean\n}\n\nexport interface DiscordThreadListSync {\n  /** The id of the guild */\n  guild_id: string\n  /** The parent channel ids whose threads are being synced. If omitted, then threads were synced for the entire guild. This array may contain channelIds that have no active threads as well, so you know to clear that data */\n  channel_ids?: string[]\n  /** All active threads in the given channels that the current user can access */\n  threads: DiscordChannel[]\n  /** All thread member objects from the synced threads for the current user, indicating which threads the current user has been added to */\n  members: DiscordThreadMember[]\n}\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-object */\nexport interface DiscordAuditLog {\n  /** List of webhooks found in the audit log */\n  webhooks: DiscordWebhook[]\n  /** List of users found in the audit log */\n  users: DiscordUser[]\n  /** List of audit log entries, sorted from most to least recent */\n  audit_log_entries: DiscordAuditLogEntry[]\n  /** List of partial integration objects */\n  integrations: Partial<DiscordIntegration>[]\n  /**\n   * List of threads found in the audit log.\n   * Threads referenced in `THREAD_CREATE` and `THREAD_UPDATE` events are included in the threads map since archived threads might not be kept in memory by clients.\n   */\n  threads: DiscordChannel[]\n  /** List of guild scheduled events found in the audit log */\n  guild_scheduled_events?: DiscordScheduledEvent[]\n  /** List of auto moderation rules referenced in the audit log */\n  auto_moderation_rules?: DiscordAutoModerationRule[]\n  /** List of application commands referenced in the audit log */\n  application_commands: DiscordApplicationCommand[]\n}\n\n/** https://discord.com/developers/docs/resources/auto-moderation#auto-moderation-rule-object */\nexport interface DiscordAutoModerationRule {\n  /** The id of this rule */\n  id: string\n  /** The guild id of the rule */\n  guild_id: string\n  /** The name of the rule */\n  name: string\n  /** The id of the user who created this rule. */\n  creator_id: string\n  /** Indicates in what event context a rule should be checked. */\n  event_type: AutoModerationEventTypes\n  /** The type of trigger for this rule */\n  trigger_type: AutoModerationTriggerTypes\n  /** The metadata used to determine whether a rule should be triggered. */\n  trigger_metadata: DiscordAutoModerationRuleTriggerMetadata\n  /** Actions which will execute whenever a rule is triggered. */\n  actions: DiscordAutoModerationAction[]\n  /** Whether the rule is enabled. */\n  enabled: boolean\n  /** The role ids that are whitelisted. Max 20. */\n  exempt_roles: string[]\n  /** The channel ids that are whitelisted. Max 50. */\n  exempt_channels: string[]\n}\n\nexport enum AutoModerationEventTypes {\n  /** When a user sends a message */\n  MessageSend = 1,\n  /** Wen a member edits their profile */\n  MemberUpdate,\n}\n\nexport enum AutoModerationTriggerTypes {\n  /** Check if content contains words from a user defined list of keywords. Max 6 per guild */\n  Keyword = 1,\n  /** Check if content represents generic spam. Max 1 per guild */\n  Spam = 3,\n  /** Check if content contains words from internal pre-defined word sets. Max 1 per guild */\n  KeywordPreset,\n  /** Check if content contains more unique mentions than allowed. Max 1 per guild */\n  MentionSpam,\n  /** Check if member profile contains words from a user defined list of keywords. Max 1 per guild */\n  MemberProfile,\n}\n\nexport interface DiscordAutoModerationRuleTriggerMetadata {\n  /**\n   * The keywords needed to match.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MemberProfile}.\n   *\n   * Can have up to 1000 elements in the array and each string can have up to 60 characters\n   */\n  keyword_filter?: string[]\n  /**\n   * Regular expression patterns which will be matched against content.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MemberProfile}.\n   *\n   * Can have up to 10 elements in the array and each string can have up to 260 characters\n   */\n  regex_patterns: string[]\n  /**\n   * The pre-defined lists of words to match from.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.KeywordPreset}.\n   */\n  presets?: DiscordAutoModerationRuleTriggerMetadataPresets[]\n  /**\n   * The substrings which will exempt from triggering the preset trigger type.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.Keyword}, {@link AutoModerationTriggerTypes.KeywordPreset} and {@link AutoModerationTriggerTypes.MemberProfile}.\n   *\n   * When used with {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MemberProfile} there can have up to 100 elements in the array and each string can have up to 60 characters.\n   * When used with {@link AutoModerationTriggerTypes.KeywordPreset} there can have up to 1000 elements in the array and each string can have up to 60 characters.\n   */\n  allow_list?: string[]\n  /**\n   * Total number of mentions (role & user) allowed per message.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.MentionSpam}.\n   *\n   * Maximum of 50\n   */\n  mention_total_limit?: number\n  /**\n   * Whether to automatically detect mention raids.\n   *\n   * @remarks\n   * Only present with {@link AutoModerationTriggerTypes.MentionSpam}.\n   */\n  mention_raid_protection_enabled?: boolean\n}\n\nexport enum DiscordAutoModerationRuleTriggerMetadataPresets {\n  /** Words that may be considered forms of swearing or cursing */\n  Profanity = 1,\n  /** Words that refer to sexually explicit behavior or activity */\n  SexualContent,\n  /** Personal insults or words that may be considered hate speech */\n  Slurs,\n}\n\nexport interface DiscordAutoModerationAction {\n  /** The type of action to take when a rule is triggered */\n  type: AutoModerationActionType\n  /** additional metadata needed during execution for this specific action type */\n  metadata: DiscordAutoModerationActionMetadata\n}\n\nexport enum AutoModerationActionType {\n  /** Blocks the content of a message according to the rule */\n  BlockMessage = 1,\n  /** Logs user content to a specified channel */\n  SendAlertMessage,\n  /**\n   * Times out user for specified duration\n   *\n   * @remarks\n   * A timeout action can only be set up for {@link AutoModerationTriggerTypes.Keyword} and {@link AutoModerationTriggerTypes.MentionSpam} rules.\n   *\n   * The `MODERATE_MEMBERS` permission is required to use the timeout action type.\n   */\n  Timeout,\n  /** prevents a member from using text, voice, or other interactions */\n  BlockMemberInteraction,\n}\n\nexport interface DiscordAutoModerationActionMetadata {\n  /** The id of channel to which user content should be logged. Only in ActionType.SendAlertMessage */\n  channel_id?: string\n  /** Additional explanation that will be shown to members whenever their message is blocked. Maximum of 150 characters. Only supported for AutoModerationActionType.BlockMessage */\n  custom_message?: string\n  /** Timeout duration in seconds maximum of 2419200 seconds (4 weeks). Only supported for TriggerType.Keyword && Only in ActionType.Timeout */\n  duration_seconds?: number\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#auto-moderation-action-execution-auto-moderation-action-execution-event-fields */\nexport interface DiscordAutoModerationActionExecution {\n  /** The id of the guild */\n  guild_id: string\n  /** The id of the rule that was executed */\n  rule_id: string\n  /** The id of the user which generated the content which triggered the rule */\n  user_id: string\n  /** The content from the user */\n  content: string\n  /** Action which was executed */\n  action: DiscordAutoModerationAction\n  /** The trigger type of the rule that was executed. */\n  rule_trigger_type: AutoModerationTriggerTypes\n  /** The id of the channel in which user content was posted */\n  channel_id?: string | null\n  /** The id of the message. Will not exist if message was blocked by automod or content was not part of any message */\n  message_id?: string | null\n  /** The id of any system auto moderation messages posted as a result of this action */\n  alert_system_message_id?: string | null\n  /** The word or phrase that triggerred the rule. */\n  matched_keyword: string | null\n  /** The substring in content that triggered the rule */\n  matched_content: string | null\n}\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-entry-object-audit-log-entry-structure */\nexport interface DiscordAuditLogEntry {\n  /** ID of the affected entity (webhook, user, role, etc.) */\n  target_id: string | null\n  /** Changes made to the `target_id` */\n  changes?: DiscordAuditLogChange[]\n  /** User or app that made the changes */\n  user_id: string | null\n  /** ID of the entry */\n  id: string\n  /** Type of action that occurred */\n  action_type: AuditLogEvents\n  /** Additional info for certain event types */\n  options?: DiscordOptionalAuditEntryInfo\n  /** Reason for the change (1-512 characters) */\n  reason?: string\n}\n\nexport type DiscordAuditLogChangeObject<T> = {\n  [K in keyof T]: {\n    new_value?: T[K]\n    old_value?: T[K]\n    key: K\n  }\n}[keyof T]\n\n// Done manually as it is clearer in this way\n/** Partial role audit log entry change exception */\nexport type DiscordAuditLogChangePartialRole = { new_value: { id: string; name: string }[]; key: '$add' | '$remove' }\n\n/**\n * Invite audit log entry change exception\n *\n * @remarks\n * While the docs say that 'channel.id' will never exist, we keep it as it is very complex to remove, the user should not use it and use the provided 'channel_id' value instead\n */\nexport type DiscordAuditLogChangeInvite = DiscordAuditLogChangeObject<DiscordInvite> | DiscordAuditLogChangeObject<{ channel_id: string }>\n\n/**\n * Invite Metadata audit log entry change exception\n *\n * @remarks\n * While the docs say that 'channel.id' will never exist, we keep it as it is very complex to remove, the user should not use it and use the provided 'channel_id' value instead\n */\nexport type DiscordAuditLogChangeInviteMetadata =\n  | DiscordAuditLogChangeObject<DiscordInviteMetadata>\n  | DiscordAuditLogChangeObject<{ channel_id: string }>\n\n/** Webhook audit log entry change exception */\nexport type DiscordAuditLogChangeWebhook =\n  | DiscordAuditLogChangeObject<Omit<DiscordWebhook, 'avatar'>>\n  | DiscordAuditLogChangeObject<{ avatar_hash: DiscordWebhook['avatar'] }>\n\n// Done manually as it is clearer in this way\n/** Command Permission audit log entry change exception */\nexport type DiscordAuditLogChangeApplicationCommandPermissions = {\n  new_value?: DiscordApplicationCommandPermissions\n  old_value?: DiscordApplicationCommandPermissions\n  key: `${number}`\n}\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-change-object-audit-log-change-structure */\nexport type DiscordAuditLogChange =\n  | DiscordAuditLogChangeObject<DiscordGuild>\n  | DiscordAuditLogChangeObject<DiscordChannel>\n  | DiscordAuditLogChangeObject<DiscordOverwrite>\n  | DiscordAuditLogChangeObject<DiscordMember>\n  | DiscordAuditLogChangePartialRole\n  | DiscordAuditLogChangeObject<DiscordRole>\n  | DiscordAuditLogChangeInvite\n  | DiscordAuditLogChangeInviteMetadata\n  | DiscordAuditLogChangeWebhook\n  | DiscordAuditLogChangeObject<DiscordEmoji>\n  | DiscordAuditLogChangeObject<DiscordIntegration>\n  | DiscordAuditLogChangeObject<DiscordStageInstance>\n  | DiscordAuditLogChangeObject<DiscordSticker>\n  | DiscordAuditLogChangeObject<DiscordThreadMetadata>\n  | DiscordAuditLogChangeApplicationCommandPermissions\n  | DiscordAuditLogChangeObject<DiscordAutoModerationRule>\n  | DiscordAuditLogChangeObject<DiscordGuildOnboardingPrompt>\n  | DiscordAuditLogChangeObject<DiscordGuildOnboarding>\n\n/** https://discord.com/developers/docs/resources/audit-log#audit-log-entry-object-optional-audit-entry-info */\nexport interface DiscordOptionalAuditEntryInfo {\n  /**\n   * ID of the app whose permissions were targeted.\n   *\n   * Event types: `APPLICATION_COMMAND_PERMISSION_UPDATE`\n   */\n  application_id?: string\n  /**\n   * Name of the Auto Moderation rule that was triggered.\n   *\n   * Event types: `AUTO_MODERATION_BLOCK_MESSAGE`, `AUTO_MODERATION_FLAG_TO_CHANNEL`, `AUTO_MODERATION_USER_COMMUNICATION_DISABLED`\n   */\n  auto_moderation_rule_name?: string\n  /**\n   * Trigger type of the Auto Moderation rule that was triggered.\n   *\n   * Event types: `AUTO_MODERATION_BLOCK_MESSAGE`, `AUTO_MODERATION_FLAG_TO_CHANNEL`, `AUTO_MODERATION_USER_COMMUNICATION_DISABLED`\n   */\n  auto_moderation_rule_trigger_type?: string\n  /**\n   * Channel in which the entities were targeted.\n   *\n   * Event types: `MEMBER_MOVE`, `MESSAGE_PIN`, `MESSAGE_UNPIN`, `MESSAGE_DELETE`, `STAGE_INSTANCE_CREATE`, `STAGE_INSTANCE_UPDATE`, `STAGE_INSTANCE_DELETE`\n   */\n  channel_id?: string\n  /**\n   * Number of entities that were targeted.\n   *\n   * Event types: `MESSAGE_DELETE`, `MESSAGE_BULK_DELETE`, `MEMBER_DISCONNECT`, `MEMBER_MOVE`\n   */\n  count?: string\n  /**\n   * Number of days after which inactive members were kicked.\n   *\n   * Event types: `MEMBER_PRUNE`\n   */\n  delete_member_days?: string\n  /**\n   * ID of the overwritten entity.\n   *\n   * Event types: `CHANNEL_OVERWRITE_CREATE`, `CHANNEL_OVERWRITE_UPDATE`, `CHANNEL_OVERWRITE_DELETE`\n   */\n  id?: string\n  /**\n   * Number of members removed by the prune.\n   *\n   * Event types: `MEMBER_PRUNE`\n   */\n  members_removed?: string\n  /**\n   * ID of the message that was targeted.\n   *\n   * Event types: `MESSAGE_PIN`, `MESSAGE_UNPIN`, `STAGE_INSTANCE_CREATE`, `STAGE_INSTANCE_UPDATE`, `STAGE_INSTANCE_DELETE`\n   */\n  message_id?: string\n  /**\n   * Name of the role if type is \"0\" (not present if type is \"1\").\n   *\n   * Event types: `CHANNEL_OVERWRITE_CREATE`, `CHANNEL_OVERWRITE_UPDATE`, `CHANNEL_OVERWRITE_DELETE`\n   */\n  role_name?: string\n  /**\n   * Type of overwritten entity - \"0\", for \"role\", or \"1\" for \"member\".\n   *\n   * Event types: `CHANNEL_OVERWRITE_CREATE`, `CHANNEL_OVERWRITE_UPDATE`, `CHANNEL_OVERWRITE_DELETE`\n   */\n  type?: string\n  /**\n   * The type of integration which performed the action\n   *\n   * Event types: `MEMBER_KICK`, `MEMBER_ROLE_UPDATE`\n   */\n  integration_type?: string\n}\n\nexport interface DiscordScheduledEvent {\n  /** the id of the scheduled event */\n  id: string\n  /** the guild id which the scheduled event belongs to */\n  guild_id: string\n  /** the channel id in which the scheduled event will be hosted if specified */\n  channel_id: string | null\n  /** the id of the user that created the scheduled event */\n  creator_id?: string | null\n  /** the name of the scheduled event */\n  name: string\n  /** the description of the scheduled event */\n  description?: string\n  /** the time the scheduled event will start */\n  scheduled_start_time: string\n  /** the time the scheduled event will end if it does end. */\n  scheduled_end_time: string | null\n  /** the privacy level of the scheduled event */\n  privacy_level: ScheduledEventPrivacyLevel\n  /** the status of the scheduled event */\n  status: ScheduledEventStatus\n  /** the type of hosting entity associated with a scheduled event */\n  entity_type: ScheduledEventEntityType\n  /** any additional id of the hosting entity associated with event */\n  entity_id: string | null\n  /** the entity metadata for the scheduled event */\n  entity_metadata: DiscordScheduledEventEntityMetadata | null\n  /** the user that created the scheduled event */\n  creator?: DiscordUser\n  /** the number of users subscribed to the scheduled event */\n  user_count?: number\n  /** the cover image hash of the scheduled event */\n  image?: string | null\n  /** the definition for how often this event should recur */\n  recurrence_rule: DiscordScheduledEventRecurrenceRule | null\n}\n\nexport interface DiscordScheduledEventEntityMetadata {\n  /** location of the event */\n  location?: string\n}\n\nexport interface DiscordScheduledEventRecurrenceRule {\n  /** Starting time of the recurrence interval */\n  start: string\n  /** Ending time of the recurrence interval */\n  end: string | null\n  /** How often the event occurs */\n  frequency: DiscordScheduledEventRecurrenceRuleFrequency\n  /** The spacing between the events, defined by `frequency`. For example, `frequency` of `Weekly` and an `interval` of `2` would be \"every-other week\" */\n  interval: number\n  /** Set of specific days within a week for the event to recur on */\n  by_weekday: DiscordScheduledEventRecurrenceRuleWeekday[] | null\n  /** List of specific days within a specific week (1-5) to recur on */\n  by_n_weekday: DiscordScheduledEventRecurrenceRuleNWeekday[] | null\n  /** Set of specific months to recur on */\n  by_month: DiscordScheduledEventRecurrenceRuleMonth[] | null\n  /** Set of specific dates within a month to recur on */\n  by_month_day: number[] | null\n  /** Set of days within a year to recur on (1-364) */\n  by_year_day: number[] | null\n  /** The total amount of times that the event is allowed to recur before stopping */\n  count: number | null\n}\n\nexport enum DiscordScheduledEventRecurrenceRuleFrequency {\n  Yearly,\n  Monthly,\n  Weekly,\n  Daily,\n}\n\nexport enum DiscordScheduledEventRecurrenceRuleWeekday {\n  Monday,\n  Tuesday,\n  Wednesday,\n  Thursday,\n  Friday,\n  Saturday,\n  Sunday,\n}\n\nexport interface DiscordScheduledEventRecurrenceRuleNWeekday {\n  /** The week to reoccur on. 1 - 5 */\n  n: number\n  /** The day within the week to reoccur on */\n  day: DiscordScheduledEventRecurrenceRuleWeekday\n}\n\nexport enum DiscordScheduledEventRecurrenceRuleMonth {\n  January = 1,\n  February,\n  March,\n  April,\n  May,\n  June,\n  July,\n  August,\n  September,\n  October,\n  November,\n  December,\n}\n\n/** https://discord.com/developers/docs/events/gateway#get-gateway-bot */\nexport interface DiscordGetGatewayBot {\n  /** The WSS URL that can be used for connecting to the gateway */\n  url: string\n  /** The recommended number of shards to use when connecting */\n  shards: number\n  /** Information on the current session start limit */\n  session_start_limit: DiscordSessionStartLimit\n}\n\n/** https://discord.com/developers/docs/events/gateway#session-start-limit-object */\nexport interface DiscordSessionStartLimit {\n  /** The total number of session starts the current user is allowed */\n  total: number\n  /** The remaining number of session starts the current user is allowed */\n  remaining: number\n  /** The number of milliseconds after which the limit resets */\n  reset_after: number\n  /** The number of identify requests allowed per 5 seconds */\n  max_concurrency: number\n}\n\n/** https://discord.com/developers/docs/resources/invite#invite-metadata-object */\nexport interface DiscordInviteMetadata extends DiscordInvite {\n  /** Number of times this invite has been used */\n  uses: number\n  /** Max number of times this invite can be used */\n  max_uses: number\n  /** Duration (in seconds) after which the invite expires */\n  max_age: number\n  /** Whether this invite only grants temporary membership */\n  temporary: boolean\n  /** When this invite was created */\n  created_at: string\n}\n\n/** https://discord.com/developers/docs/resources/invite#invite-object */\nexport interface DiscordInvite {\n  /** The type of invite */\n  type: DiscordInviteType\n  /** The invite code (unique Id) */\n  code: string\n  /** The guild this invite is for */\n  guild?: Partial<DiscordGuild>\n  /** The channel this invite is for */\n  channel: Partial<DiscordChannel> | null\n  /** The user who created the invite */\n  inviter?: DiscordUser\n  /** The type of target for this voice channel invite */\n  target_type?: TargetTypes\n  /** The target user for this invite */\n  target_user?: DiscordUser\n  /** The embedded application to open for this voice channel embedded application invite */\n  target_application?: Partial<DiscordApplication>\n  /** Approximate count of online members (only present when target_user is set) */\n  approximate_presence_count?: number\n  /** Approximate count of total members */\n  approximate_member_count?: number\n  /** The expiration date of this invite, returned from the `GET /invites/<code>` endpoint when `with_expiration` is `true` */\n  expires_at?: string | null\n  /** Stage instance data if there is a public Stage instance in the Stage channel this invite is for */\n  stage_instance?: DiscordInviteStageInstance\n  /** guild scheduled event data */\n  guild_scheduled_event?: DiscordScheduledEvent\n}\n\nexport enum DiscordInviteType {\n  Guild,\n  GroupDm,\n  Friend,\n}\n\nexport interface DiscordInviteStageInstance {\n  /** The members speaking in the Stage */\n  members: Partial<DiscordMember>[]\n  /** The number of users in the Stage */\n  participant_count: number\n  /** The number of users speaking in the Stage */\n  speaker_count: number\n  /** The topic of the Stage instance (1-120 characters) */\n  topic: string\n}\n\n/** https://discord.com/developers/docs/interactions/application-commands#application-command-object-application-command-structure */\nexport interface DiscordApplicationCommand extends DiscordCreateApplicationCommand {\n  /** Unique ID of command */\n  id: string\n  /** ID of the parent application */\n  application_id: string\n  /** Guild id of the command, if not global */\n  guild_id?: string\n}\n\nexport interface DiscordCreateApplicationCommand {\n  /** Type of command, defaults to `ApplicationCommandTypes.ChatInput` */\n  type?: ApplicationCommandTypes\n  /**\n   * Name of command, 1-32 characters.\n   * `ApplicationCommandTypes.ChatInput` command names must match the following regex `^[-_\\p{L}\\p{N}\\p{sc=Deva}\\p{sc=Thai}]{1,32}$` with the unicode flag set.\n   * If there is a lowercase variant of any letters used, you must use those.\n   * Characters with no lowercase variants and/or uncased letters are still allowed.\n   * ApplicationCommandTypes.User` and `ApplicationCommandTypes.Message` commands may be mixed case and can include spaces.\n   */\n  name: string\n  /** Localization object for `name` field. Values follow the same restrictions as `name` */\n  name_localizations?: Localization | null\n  /** Description for `ApplicationCommandTypes.ChatInput` commands, 1-100 characters. */\n  description?: string\n  /** Localization object for `description` field. Values follow the same restrictions as `description` */\n  description_localizations?: Localization | null\n  /** Parameters for the command, max of 25 */\n  options?: DiscordApplicationCommandOption[]\n  /** Set of permissions represented as a bit set */\n  default_member_permissions?: string | null\n  /**\n   * Installation contexts where the command is available\n   *\n   * @remarks\n   * This value is available only for globally-scoped commands\n   * Defaults to the application configured contexts\n   */\n  integration_types?: DiscordApplicationIntegrationType[]\n  /**\n   * Interaction context(s) where the command can be used\n   *\n   * @remarks\n   * This value is available only for globally-scoped commands\n   * By default, all interaction context types included for new commands.\n   */\n  contexts?: DiscordInteractionContextType[] | null\n  /**\n   * Indicates whether the command is available in DMs with the app, only for globally-scoped commands. By default, commands are visible.\n   *\n   * @deprecated use {@link contexts} instead\n   */\n  dm_permission?: boolean\n  /** Indicates whether the command is age-restricted, defaults to false */\n  nsfw?: boolean\n  /** Auto incrementing version identifier updated during substantial record changes */\n  version?: string\n  /**\n   * Determines whether the interaction is handled by the app's interactions handler or by Discord\n   *\n   * @remarks\n   * This can only be set for application commands of type `PRIMARY_ENTRY_POINT` for applications with the `EMBEDDED` flag (i.e. applications that have an Activity).\n   */\n  handler?: DiscordInteractionEntryPointCommandHandlerType\n}\n\nexport enum DiscordInteractionEntryPointCommandHandlerType {\n  /** The app handles the interaction using an interaction token */\n  AppHandler = 1,\n  /** Discord handles the interaction by launching an Activity and sending a follow-up message without coordinating with the app */\n  DiscordLaunchActivity = 2,\n}\n\n/** https://discord.com/developers/docs/interactions/application-commands#application-command-object-application-command-option-structure */\nexport interface DiscordApplicationCommandOption {\n  /** Type of option */\n  type: ApplicationCommandOptionTypes\n  /**\n   * Name of command, 1-32 characters.\n   *\n   * @remarks\n   * This value should be unique within an array of {@link DiscordApplicationCommandOption}\n   *\n   * {@link ApplicationCommandTypes.ChatInput | ChatInput} command names must match the following regex `^[-_\\p{L}\\p{N}\\p{sc=Deva}\\p{sc=Thai}]{1,32}$` with the unicode flag set.\n   * If there is a lowercase variant of any letters used, you must use those.\n   * Characters with no lowercase variants and/or uncased letters are still allowed.\n   *\n   * {@link ApplicationCommandTypes.User | User} and {@link ApplicationCommandTypes.Message | Message} commands may be mixed case and can include spaces.\n   */\n  name: string\n  /** Localization object for the `name` field. Values follow the same restrictions as `name` */\n  name_localizations?: Localization | null\n  /** 1-100 character description */\n  description: string\n  /** Localization object for the `description` field. Values follow the same restrictions as `description` */\n  description_localizations?: Localization | null\n  /**\n   * If the parameter is required or optional. default `false`\n   *\n   * @remarks\n   * Valid in all option types except {@link ApplicationCommandOptionTypes.SubCommand | SubCommand} and {@link ApplicationCommandOptionTypes.SubCommandGroup | SubCommandGroup}\n   */\n  required?: boolean\n  /**\n   * Choices for the option from which the user can choose, max 25\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}, {@link ApplicationCommandOptionTypes.Integer | Integer}, or {@link ApplicationCommandOptionTypes.Number | Number}\n   *\n   * If you provide an array of choices, they will be the ONLY accepted values for this option\n   */\n  choices?: DiscordApplicationCommandOptionChoice[]\n  /**\n   * If the option is a subcommand or subcommand group type, these nested options will be the parameters\n   *\n   * @remarks\n   * Only valid in option of type {@link ApplicationCommandOptionTypes.SubCommand | SubCommand} or {@link ApplicationCommandOptionTypes.SubCommandGroup | SubCommandGroup}\n   */\n  options?: DiscordApplicationCommandOption[]\n  /**\n   * If autocomplete interactions are enabled for this option.\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}, {@link ApplicationCommandOptionTypes.Integer | Integer}, or {@link ApplicationCommandOptionTypes.Number | Number}\n   *\n   * When {@link DiscordApplicationCommandOption.choices | choices} are provided, this may not be set to true\n   */\n  autocomplete?: boolean\n  /**\n   * The channels shown will be restricted to these types\n   *\n   * @remarks\n   * Only valid in option of type {@link ApplicationCommandOptionTypes.Channel | Channel}\n   */\n  channel_types?: ChannelTypes[]\n  /**\n   * The minimum permitted value\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.Integer | Integer} or {@link ApplicationCommandOptionTypes.Number | Number}\n   */\n  min_value?: number\n  /**\n   * The maximum permitted value\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.Integer | Integer} or {@link ApplicationCommandOptionTypes.Number | Number}\n   */\n  max_value?: number\n  /**\n   * The minimum permitted length, should be in the range of from 0 to 600\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}\n   */\n  min_length?: number\n  /**\n   * The maximum permitted length, should be in the range of from 0 to 600\n   *\n   * @remarks\n   * Only valid in options of type {@link ApplicationCommandOptionTypes.String | String}\n   */\n  max_length?: number\n}\n\n/** https://discord.com/developers/docs/interactions/application-commands#application-command-permissions-object */\nexport interface DiscordApplicationCommandOptionChoice {\n  /** 1-100 character choice name */\n  name: string\n  /** Localization object for the `name` field. Values follow the same restrictions as `name` */\n  name_localizations?: Localization | null\n  /** Value for the choice, up to 100 characters if string */\n  value: string | number\n}\n\n/** https://discord.com/developers/docs/interactions/slash-commands#guildapplicationcommandpermissions */\nexport interface DiscordGuildApplicationCommandPermissions {\n  /** ID of the command or the application ID. When the `id` field is the application ID instead of a command ID, the permissions apply to all commands that do not contain explicit overwrites. */\n  id: string\n  /** ID of the application the command belongs to */\n  application_id: string\n  /** ID of the guild */\n  guild_id: string\n  /** Permissions for the command in the guild, max of 100 */\n  permissions: DiscordApplicationCommandPermissions[]\n}\n\n/** https://discord.com/developers/docs/interactions/slash-commands#applicationcommandpermissions */\nexport interface DiscordApplicationCommandPermissions {\n  /** ID of the role, user, or channel. It can also be a permission constant */\n  id: string\n  /** ApplicationCommandPermissionTypes.Role, ApplicationCommandPermissionTypes.User, or ApplicationCommandPermissionTypes.Channel */\n  type: ApplicationCommandPermissionTypes\n  /** `true` to allow, `false`, to disallow */\n  permission: boolean\n}\n\n/** https://discord.com/developers/docs/resources/guild#get-guild-widget-example-get-guild-widget */\nexport interface DiscordGuildWidget {\n  id: string\n  name: string\n  instant_invite: string\n  channels: Array<{\n    id: string\n    name: string\n    position: number\n  }>\n  members: Array<{\n    id: string\n    username: string\n    discriminator: string\n    avatar?: string | null\n    status: string\n    avatar_url: string\n  }>\n  presence_count: number\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-preview-object */\nexport interface DiscordGuildPreview {\n  /** Guild id */\n  id: string\n  /** Guild name (2-100 characters) */\n  name: string\n  /** Icon hash */\n  icon: string | null\n  /** Splash hash */\n  splash: string | null\n  /** Discovery splash hash */\n  discovery_splash: string | null\n  /** Custom guild emojis */\n  emojis: DiscordEmoji[]\n  /** Enabled guild features */\n  features: GuildFeatures[]\n  /** Approximate number of members in this guild */\n  approximate_member_count: number\n  /** Approximate number of online members in this guild */\n  approximate_presence_count: number\n  /** The description for the guild, if the guild is discoverable */\n  description: string | null\n  /** Custom guild stickers */\n  stickers: DiscordSticker[]\n}\n\n/** https://discord.com/developers/docs/resources/channel#followed-channel-object */\nexport interface DiscordFollowedChannel {\n  /** Source message id */\n  channel_id: string\n  /** Created target webhook id */\n  webhook_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#payloads-gateway-payload-structure */\nexport interface DiscordGatewayPayload {\n  /** opcode for the payload */\n  op: number\n  /** Event data */\n  d: unknown | null\n  /** Sequence number, used for resuming sessions and heartbeats */\n  s: number | null\n  /** The event name for this payload */\n  t: GatewayEventNames | null\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-members-chunk */\nexport interface DiscordGuildMembersChunk {\n  /** The id of the guild */\n  guild_id: string\n  /** Set of guild members */\n  members: DiscordMemberWithUser[]\n  /** The chunk index in the expected chunks for this response (0 <= chunk_index < chunk_count) */\n  chunk_index: number\n  /** The total number of expected chunks for this response */\n  chunk_count: number\n  /** If passing an invalid id to `REQUEST_GUILD_MEMBERS`, it will be returned here */\n  not_found?: string[]\n  /** If passing true to `REQUEST_GUILD_MEMBERS`, presences of the returned members will be here */\n  presences?: DiscordPresenceUpdate[]\n  /** The nonce used in the Guild Members Request */\n  nonce?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#channel-pins-update */\nexport interface DiscordChannelPinsUpdate {\n  /** The id of the guild */\n  guild_id?: string\n  /** The id of the channel */\n  channel_id: string\n  /** The time at which the most recent pinned message was pinned */\n  last_pin_timestamp?: string | null\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-role-delete */\nexport interface DiscordGuildRoleDelete {\n  /** id of the guild */\n  guild_id: string\n  /** id of the role */\n  role_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-ban-add */\nexport interface DiscordGuildBanAddRemove {\n  /** id of the guild */\n  guild_id: string\n  /** The banned user */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/events/gateway#message-reaction-remove */\nexport interface DiscordMessageReactionRemove extends Omit<DiscordMessageReactionAdd, 'member' | 'burst_colors'> {}\n\n/** https://discord.com/developers/docs/events/gateway#message-reaction-add */\nexport interface DiscordMessageReactionAdd {\n  /** The id of the user */\n  user_id: string\n  /** The id of the channel */\n  channel_id: string\n  /** The id of the message */\n  message_id: string\n  /** The id of the guild */\n  guild_id?: string\n  /** The member who reacted if this happened in a guild */\n  member?: DiscordMemberWithUser\n  /** The emoji used to react */\n  emoji: Partial<DiscordEmoji>\n  /** The id of the author of this message */\n  message_author_id?: string\n  /** true if this is a super-reaction */\n  burst: boolean\n  /** Colors used for super-reaction animation in \"#rrggbb\" format */\n  burst_colors?: string[]\n  /** The type of reaction */\n  type: DiscordReactionType\n}\n\n/** https://discord.com/developers/docs/events/gateway#voice-server-update */\nexport interface DiscordVoiceServerUpdate {\n  /** Voice connection token */\n  token: string\n  /** The guild this voice server update is for */\n  guild_id: string\n  /** The voice server host */\n  endpoint: string | null\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#voice-channel-effect-send-voice-channel-effect-send-event-fields */\nexport interface DiscordVoiceChannelEffectSend {\n  /** ID of the channel the effect was sent in */\n  channel_id: string\n  /** ID of the guild the effect was sent in */\n  guild_id: string\n  /** ID of the user who sent the effect */\n  user_id: string\n  /** The emoji sent, for emoji reaction and soundboard effects */\n  emoji?: DiscordEmoji | null\n  /** The type of emoji animation, for emoji reaction and soundboard effects */\n  animation_type?: DiscordVoiceChannelEffectAnimationType | null\n  /** The ID of the emoji animation, for emoji reaction and soundboard effects */\n  animation_id?: number | null\n  /** The ID of the soundboard sound, for soundboard effects */\n  sound_id?: string | number\n  /** The volume of the soundboard sound, from 0 to 1, for soundboard effects */\n  sound_volume?: number\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#voice-channel-effect-send-animation-types */\nexport enum DiscordVoiceChannelEffectAnimationType {\n  /** A fun animation, sent by a Nitro subscriber */\n  Premium = 0,\n  /** The standard animation */\n  Basic = 1,\n}\n\n/** https://discord.com/developers/docs/events/gateway#invite-create */\nexport interface DiscordInviteCreate {\n  /** The channel the invite is for */\n  channel_id: string\n  /** The unique invite code */\n  code: string\n  /** The time at which the invite was created */\n  created_at: string\n  /** The guild of the invite */\n  guild_id?: string\n  /** The user that created the invite */\n  inviter?: DiscordUser\n  /** How long the invite is valid for (in seconds) */\n  max_age: number\n  /** The maximum number of times the invite can be used */\n  max_uses: number\n  /** The type of target for this voice channel invite */\n  target_type: TargetTypes\n  /** The target user for this invite */\n  target_user?: DiscordUser\n  /** The embedded application to open for this voice channel embedded application invite */\n  target_application?: Partial<DiscordApplication>\n  /** Whether or not the invite is temporary (invited users will be kicked on disconnect unless they're assigned a role) */\n  temporary: boolean\n  /** How many times the invite has been used (always will be 0) */\n  uses: number\n}\n\n/** https://discord.com/developers/docs/events/gateway#hello */\nexport interface DiscordHello {\n  /** The interval (in milliseconds) the client should heartbeat with */\n  heartbeat_interval: number\n}\n\n/** https://discord.com/developers/docs/events/gateway#ready */\nexport interface DiscordReady {\n  /** Gateway version */\n  v: number\n  /** Information about the user including email */\n  user: DiscordUser\n  /** The guilds the user is in */\n  guilds: DiscordUnavailableGuild[]\n  /** Used for resuming connections */\n  session_id: string\n  /** Gateway url for resuming connections */\n  resume_gateway_url: string\n  /** The shard information associated with this session, if sent when identifying */\n  shard?: [number, number]\n  /** Contains id and flags */\n  application: Partial<DiscordApplication> & Pick<DiscordApplication, 'id' | 'flags'>\n}\n\n/** https://discord.com/developers/docs/resources/guild#unavailable-guild-object */\nexport interface DiscordUnavailableGuild extends Pick<DiscordGuild, 'id' | 'unavailable'> {}\n\n/** https://discord.com/developers/docs/events/gateway#message-delete-bulk */\nexport interface DiscordMessageDeleteBulk {\n  /** The ids of the messages */\n  ids: string[]\n  /** The id of the channel */\n  channel_id: string\n  /** The id of the guild */\n  guild_id?: string\n}\n\n/** https://discord.com/developers/docs/resources/template#template-object-template-structure */\nexport interface DiscordTemplate {\n  /** The template code (unique Id) */\n  code: string\n  /** Template name */\n  name: string\n  /** The description for the template */\n  description: string | null\n  /** Number of times this template has been used */\n  usage_count: number\n  /** The Id of the user who created the template */\n  creator_id: string\n  /** The user who created the template */\n  creator: DiscordUser\n  /** When this template was created */\n  created_at: string\n  /** When this template was last synced to the source guild */\n  updated_at: string\n  /** The Id of the guild this template is based on */\n  source_guild_id: string\n  /** The guild snapshot this template contains */\n  serialized_source_guild: DiscordTemplateSerializedSourceGuild\n  is_dirty: boolean | null\n}\n\nexport type DiscordTemplateSerializedSourceGuild = Omit<\n  PickPartial<\n    DiscordGuild,\n    | 'name'\n    | 'description'\n    | 'verification_level'\n    | 'default_message_notifications'\n    | 'explicit_content_filter'\n    | 'preferred_locale'\n    | 'afk_timeout'\n    | 'system_channel_flags'\n  >,\n  'roles' | 'channels' | 'afk_channel_id' | 'system_channel_id'\n> & {\n  afk_channel_id: number | null\n  system_channel_id: number | null\n  roles: Array<\n    Omit<PickPartial<DiscordRole, 'name' | 'color' | 'hoist' | 'mentionable' | 'permissions' | 'icon' | 'unicode_emoji'>, 'id'> & {\n      id: number\n    }\n  >\n  channels: Array<\n    Omit<\n      PickPartial<\n        DiscordChannel,\n        | 'name'\n        | 'type'\n        | 'position'\n        | 'topic'\n        | 'bitrate'\n        | 'user_limit'\n        | 'nsfw'\n        | 'rate_limit_per_user'\n        | 'default_auto_archive_duration'\n        | 'available_tags'\n        | 'default_reaction_emoji'\n        | 'default_thread_rate_limit_per_user'\n        | 'default_sort_order'\n        | 'default_forum_layout'\n      >,\n      'id' | 'permission_overwrites' | 'parent_id'\n    > & {\n      id: number\n      permission_overwrites: DiscordOverwrite & { id: number }\n      parent_id: number | null\n    }\n  >\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-member-add */\nexport interface DiscordGuildMemberAdd extends DiscordMemberWithUser {\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#message-delete */\nexport interface DiscordMessageDelete {\n  /** The id of the message */\n  id: string\n  /** The id of the channel */\n  channel_id: string\n  /** The id of the guild */\n  guild_id?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#thread-members-update-thread-members-update-event-fields */\nexport interface DiscordThreadMembersUpdate {\n  /** The id of the thread */\n  id: string\n  /** The id of the guild */\n  guild_id: string\n  /** The users who were added to the thread */\n  added_members?: DiscordThreadMember[]\n  /** The id of the users who were removed from the thread */\n  removed_member_ids?: string[]\n  /** the approximate number of members in the thread, capped at 50 */\n  member_count: number\n}\n\n/** https://discord.com/developers/docs/events/gateway#thread-member-update */\nexport interface DiscordThreadMemberUpdate {\n  /** The id of the thread */\n  id: string\n  /** The id of the guild */\n  guild_id: string\n  /** The timestamp when the bot joined this thread. */\n  joined_at: string\n  /** The flags this user has for this thread. Not useful for bots. */\n  flags: number\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-role-create */\nexport interface DiscordGuildRoleCreate {\n  /** The id of the guild */\n  guild_id: string\n  /** The role created */\n  role: DiscordRole\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-emojis-update */\nexport interface DiscordGuildEmojisUpdate {\n  /** id of the guild */\n  guild_id: string\n  /** Array of emojis */\n  emojis: DiscordEmoji[]\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-stickers-update */\nexport interface DiscordGuildStickersUpdate {\n  /** id of the guild */\n  guild_id: string\n  /** Array of sticker */\n  stickers: DiscordSticker[]\n}\n\n/** https://discord.com/developers/docs/events/gateway#guild-member-update */\nexport interface DiscordGuildMemberUpdate {\n  /** The id of the guild */\n  guild_id: string\n  /** User role ids */\n  roles: string[]\n  /** The user */\n  user: DiscordUser\n  /** Nickname of the user in the guild */\n  nick?: string | null\n  /** the member's [guild avatar hash](https://discord.com/developers/docs/reference#image-formatting) */\n  avatar: string\n  /** the member's guild banner hash */\n  banner: string\n  /** When the user joined the guild */\n  joined_at: string\n  /** When the user starting boosting the guild */\n  premium_since?: string | null\n  /** whether the user is deafened in voice channels */\n  deaf?: boolean\n  /** whether the user is muted in voice channels */\n  mute?: boolean\n  /** Whether the user has not yet passed the guild's Membership Screening requirements */\n  pending?: boolean\n  /** when the user's [timeout](https://support.discord.com/hc/en-us/articles/4413305239191-Time-Out-FAQ) will expire and the user will be able to communicate in the guild again, null or a time in the past if the user is not timed out. Will throw a 403 error if the user has the ADMINISTRATOR permission or is the owner of the guild */\n  communication_disabled_until?: string\n  /** Data for the member's guild avatar decoration */\n  avatar_decoration_data?: DiscordAvatarDecorationData\n  /** Guild member flags */\n  flags?: number\n}\n\n/** https://discord.com/developers/docs/events/gateway#message-reaction-remove-all */\nexport interface DiscordMessageReactionRemoveAll extends Pick<DiscordMessageReactionAdd, 'channel_id' | 'message_id' | 'guild_id'> {}\n\n/** https://discord.com/developers/docs/events/gateway#guild-role-update */\nexport interface DiscordGuildRoleUpdate {\n  /** The id of the guild */\n  guild_id: string\n  /** The role updated */\n  role: DiscordRole\n}\n\nexport interface DiscordScheduledEventUserAdd {\n  /** id of the guild scheduled event  */\n  guild_scheduled_event_id: string\n  /** id of the user                   */\n  user_id: string\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#message-reaction-remove-emoji */\nexport type DiscordMessageReactionRemoveEmoji = Pick<DiscordMessageReactionAdd, 'channel_id' | 'guild_id' | 'message_id' | 'emoji'>\n\n/** https://discord.com/developers/docs/events/gateway#guild-member-remove */\nexport interface DiscordGuildMemberRemove {\n  /** The id of the guild */\n  guild_id: string\n  /** The user who was removed */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/resources/guild#ban-object */\nexport interface DiscordBan {\n  /** The reason for the ban */\n  reason: string | null\n  /** The banned user */\n  user: DiscordUser\n}\n\nexport interface DiscordScheduledEventUserRemove {\n  /** id of the guild scheduled event */\n  guild_scheduled_event_id: string\n  /** id of the user */\n  user_id: string\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway#invite-delete */\nexport interface DiscordInviteDelete {\n  /** The channel of the invite */\n  channel_id: string\n  /** The guild of the invite */\n  guild_id?: string\n  /** The unique invite code */\n  code: string\n}\n\n/** https://discord.com/developers/docs/resources/voice#voice-region-object-voice-region-structure */\nexport interface DiscordVoiceRegion {\n  /** Unique Id for the region */\n  id: string\n  /** Name of the region */\n  name: string\n  /** true for a single server that is closest to the current user's client */\n  optimal: boolean\n  /** Whether this is a deprecated voice region (avoid switching to these) */\n  deprecated: boolean\n  /** Whether this is a custom voice region (used for events/etc) */\n  custom: boolean\n}\n\nexport interface DiscordGuildWidgetSettings {\n  /** whether the widget is enabled */\n  enabled: boolean\n  /** the widget channel id */\n  channel_id: string | null\n}\n\nexport interface DiscordInstallParams {\n  /** Scopes to add the application to the server with */\n  scopes: OAuth2Scope[]\n  /** Permissions to request for the bot role */\n  permissions: string\n}\n\nexport interface DiscordForumTag {\n  /** The id of the tag */\n  id: string\n  /** The name of the tag (0-20 characters) */\n  name: string\n  /** Whether this tag can only be added to or removed from threads by a member with the MANAGE_THREADS permission */\n  moderated: boolean\n  /** The id of a guild's custom emoji At most one of emoji_id and emoji_name may be set. */\n  emoji_id: string\n  /** The unicode character of the emoji */\n  emoji_name: string | null\n}\n\nexport interface DiscordDefaultReactionEmoji {\n  /** The id of a guild's custom emoji */\n  emoji_id: string\n  /** The unicode character of the emoji */\n  emoji_name: string | null\n}\n\nexport interface DiscordModifyChannel {\n  /** 1-100 character channel name */\n  name?: string\n  /** The type of channel; only conversion between text and news is supported and only in guilds with the \"NEWS\" feature */\n  type?: ChannelTypes\n  /** The position of the channel in the left-hand listing */\n  position?: number | null\n  /** 0-1024 character channel topic */\n  topic?: string | null\n  /** Whether the channel is nsfw */\n  nsfw?: boolean | null\n  /** Amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission `manage_messages` or `manage_channel`, are unaffected */\n  rate_limit_per_user?: number | null\n  /** The bitrate (in bits) of the voice channel; 8000 to 96000 (128000 for VIP servers) */\n  bitrate?: number | null\n  /** The user limit of the voice channel; 0 refers to no limit, 1 to 99 refers to a user limit */\n  user_limit?: number | null\n  /** Channel or category-specific permissions */\n  permission_overwrites?: DiscordOverwrite[] | null\n  /** Id of the new parent category for a channel */\n  parent_id?: string | null\n  /** Voice region id for the voice channel, automatic when set to null */\n  rtc_region?: string | null\n  /** The camera video quality mode of the voice channel */\n  video_quality_mode?: VideoQualityModes\n  /** Whether the thread is archived */\n  archived?: boolean\n  /** Duration in minutes to automatically archive the thread after recent activity */\n  auto_archive_duration?: 60 | 1440 | 4320 | 10080\n  /** When a thread is locked, only users with `MANAGE_THREADS` can unarchive it */\n  locked?: boolean\n  /** whether non-moderators can add other non-moderators to a thread; only available on private threads */\n  invitable?: boolean\n  /** The set of tags that can be used in a GUILD_FORUM channel */\n  available_tags?: Array<{\n    /** The id of the tag */\n    id: string\n    /** The name of the tag (0-20 characters) */\n    name: string\n    /** Whether this tag can only be added to or removed from threads by a member with the MANAGE_THREADS permission */\n    moderated: boolean\n    /** The id of a guild's custom emoji At most one of emoji_id and emoji_name may be set. */\n    emoji_id: string\n    /** The unicode character of the emoji */\n    emoji_name: string\n  }>\n  /** The IDs of the set of tags that have been applied to a thread in a GUILD_FORUM channel; limited to 5 */\n  applied_tags?: string[]\n  /** the emoji to show in the add reaction button on a thread in a GUILD_FORUM channel */\n  default_reaction_emoji?: {\n    /** The id of a guild's custom emoji */\n    emoji_id: string\n    /** The unicode character of the emoji */\n    emoji_name: string | null\n  }\n  /** the initial rate_limit_per_user to set on newly created threads in a channel. this field is copied to the thread at creation time and does not live update. */\n  default_thread_rate_limit_per_user?: number\n  /** the default sort order type used to order posts in forum channels */\n  default_sort_order?: SortOrderTypes | null\n  /** the default forum layout view used to display posts in `GUILD_FORUM` channels. Defaults to `0`, which indicates a layout view has not been set by a channel admin */\n  default_forum_layout?: ForumLayout\n}\n\n/** https://discord.com/developers/docs/resources/emoji#create-guild-emoji */\nexport interface DiscordCreateGuildEmoji {\n  /** Name of the emoji */\n  name: string\n  /** The 128x128 emoji image. Emojis and animated emojis have a maximum file size of 256kb. Attempting to upload an emoji larger than this limit will fail and return 400 Bad Request and an error message, but not a JSON status code. If a URL is provided to the image parameter, Discordeno will automatically convert it to a base64 string internally. */\n  image: string\n  /** Roles allowed to use this emoji */\n  roles?: string[]\n}\n\n/** https://discord.com/developers/docs/resources/emoji#modify-guild-emoji */\nexport interface DiscordModifyGuildEmoji {\n  /** Name of the emoji */\n  name?: string\n  /** Roles allowed to use this emoji */\n  roles?: string[] | null\n}\n\nexport interface DiscordCreateGuildChannel {\n  /** Channel name (1-100 characters) */\n  name: string\n  /** The type of channel */\n  type?: ChannelTypes\n  /** Channel topic (0-1024 characters) */\n  topic?: string\n  /** The bitrate (in bits) of the voice channel (voice only) */\n  bitrate?: number\n  /** The user limit of the voice channel (voice only) */\n  user_limit?: number\n  /** Amount of seconds a user has to wait before sending another message (0-21600); bots, as well as users with the permission `manage_messages` or `manage_channel`, are unaffected */\n  rate_limit_per_user?: number\n  /** Sorting position of the channel */\n  position?: number\n  /** The channel's permission overwrites */\n  permission_overwrites?: DiscordOverwrite[]\n  /** Id of the parent category for a channel */\n  parent_id?: string\n  /** Whether the channel is nsfw */\n  nsfw?: boolean\n  /** Default duration (in minutes) that clients (not the API) use for newly created threads in this channel, to determine when to automatically archive the thread after the last activity */\n  default_auto_archive_duration?: number\n  /** Emoji to show in the add reaction button on a thread in a forum channel */\n  default_reaction_emoji?: {\n    /** The id of a guild's custom emoji. Exactly one of `emojiId` and `emojiName` must be set. */\n    emoji_id?: string | null\n    /** The unicode character of the emoji. Exactly one of `emojiId` and `emojiName` must be set. */\n    emoji_name?: string | null\n  }\n  /** Set of tags that can be used in a forum channel */\n  available_tags?: Array<{\n    /** The id of the tag */\n    id: string\n    /** The name of the tag (0-20 characters) */\n    name: string\n    /** whether this tag can only be added to or removed from threads by a member with the MANAGE_THREADS permission */\n    moderated: boolean\n    /** The id of a guild's custom emoji */\n    emoji_id: string\n    /** The unicode character of the emoji */\n    emoji_name?: string\n  }>\n  /** the default sort order type used to order posts in forum channels */\n  default_sort_order?: SortOrderTypes | null\n}\n\nexport interface DiscordCreateMessage {\n  /** The message contents (up to 2000 characters) */\n  content?: string\n  /** Can be used to verify a message was sent (up to 25 characters). Value will appear in the Message Create event. */\n  nonce?: string | number\n  /** true if this is a TTS message */\n  tts?: boolean\n  /** Embedded `rich` content (up to 6000 characters) */\n  embeds?: DiscordEmbed[]\n  /** Allowed mentions for the message */\n  allowed_mentions?: DiscordAllowedMentions\n  /** Include to make your message a reply */\n  message_reference?: {\n    /** id of the originating message */\n    message_id?: string\n    /**\n     * id of the originating message's channel\n     * Note: `channel_id` is optional when creating a reply, but will always be present when receiving an event/response that includes this data model.\n     */\n    channel_id?: string\n    /** id of the originating message's guild */\n    guild_id?: string\n    /** When sending, whether to error if the referenced message doesn't exist instead of sending as a normal (non-reply) message, default true */\n    fail_if_not_exists: boolean\n  }\n  /** The components you would like to have sent in this message */\n  components?: DiscordMessageComponents\n  /** IDs of up to 3 stickers in the server to send in the message */\n  stickerIds?: [string] | [string, string] | [string, string, string]\n}\n\n/** https://discord.com/developers/docs/resources/guild#modify-guild-welcome-screen */\nexport interface DiscordModifyGuildWelcomeScreen {\n  /** Whether the welcome screen is enabled */\n  enabled?: boolean | null\n  /** Channels linked in the welcome screen and their display options */\n  welcome_screen?: DiscordWelcomeScreenChannel[] | null\n  /** The server description to show in the welcome screen */\n  description?: string | null\n}\n\nexport interface DiscordFollowAnnouncementChannel {\n  /** The id of the channel to send announcements to. */\n  webhook_channel_id: string\n}\n\nexport interface DiscordEditChannelPermissionOverridesOptions {\n  /** Permission bit set */\n  allow: string\n  /** Permission bit set */\n  deny: string\n  /** Either 0 (role) or 1 (member) */\n  type: OverwriteTypes\n}\n\n/** https://discord.com/developers/docs/resources/guild#modify-guild-channel-positions */\nexport interface DiscordModifyGuildChannelPositions {\n  /** Channel id */\n  id: string\n  /** Sorting position of the channel */\n  position?: number | null\n  /** Syncs the permission overwrites with the new parent, if moving to a new category */\n  lock_positions?: boolean | null\n  /** The new parent ID for the channel that is moved */\n  parent_id?: string | null\n}\n\nexport interface DiscordCreateWebhook {\n  /** Name of the webhook (1-80 characters) */\n  name: string\n  /** Image url for the default webhook avatar */\n  avatar?: string | null\n}\n\n/** https://discord.com/developers/docs/resources/channel#start-thread-in-forum-channel */\nexport interface DiscordCreateForumPostWithMessage {\n  /** 1-100 character channel name */\n  name: string\n  /** duration in minutes to automatically archive the thread after recent activity, can be set to: 60, 1440, 4320, 10080 */\n  auto_archive_duration?: 60 | 1440 | 4320 | 10080\n  /** amount of seconds a user has to wait before sending another message (0-21600) */\n  rate_limit_per_user?: number\n  /** contents of the first message in the forum thread */\n  message: {\n    /** Message contents (up to 2000 characters) */\n    content?: string\n    /** Embedded rich content (up to 6000 characters) */\n    embeds?: DiscordEmbed[]\n    /** Allowed mentions for the message */\n    allowed_mentions?: DiscordAllowedMentions[]\n    /** Components to include with the message */\n    components?: DiscordMessageComponents[]\n    /** IDs of up to 3 stickers in the server to send in the message */\n    sticker_ids?: string[]\n    /** JSON-encoded body of non-file params, only for multipart/form-data requests. See {@link https://discord.com/developers/docs/reference#uploading-files Uploading Files} */\n    payload_json?: string\n    /** Attachment objects with filename and description. See {@link https://discord.com/developers/docs/reference#uploading-files Uploading Files} */\n    attachments?: DiscordAttachment[]\n    /** Message flags combined as a bitfield, only SUPPRESS_EMBEDS can be set */\n    flags?: MessageFlags\n  }\n  /** the IDs of the set of tags that have been applied to a thread in a GUILD_FORUM channel */\n  applied_tags?: string[]\n}\n\nexport type DiscordArchivedThreads = DiscordActiveThreads & {\n  hasMore: boolean\n}\n\nexport interface DiscordActiveThreads {\n  threads: DiscordChannel[]\n  members: DiscordThreadMember[]\n}\n\nexport interface DiscordVanityUrl {\n  code: string | null\n  uses: number\n}\n\nexport interface DiscordPrunedCount {\n  pruned: number\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-guild-onboarding-structure */\nexport interface DiscordGuildOnboarding {\n  /** ID of the guild this onboarding is part of */\n  guild_id: string\n  /** Prompts shown during onboarding and in customize community */\n  prompts: DiscordGuildOnboardingPrompt[]\n  /** Channel IDs that members get opted into automatically */\n  default_channel_ids: string[]\n  /** Whether onboarding is enabled in the guild */\n  enabled: boolean\n  /** Current mode of onboarding */\n  mode: DiscordGuildOnboardingMode\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-onboarding-prompt-structure */\nexport interface DiscordGuildOnboardingPrompt {\n  /** ID of the prompt */\n  id: string\n  /** Type of prompt */\n  type: DiscordGuildOnboardingPromptType\n  /** Options available within the prompt */\n  options: DiscordGuildOnboardingPromptOption[]\n  /** Title of the prompt */\n  title: string\n  /** Indicates whether users are limited to selecting one option for the prompt */\n  single_select: boolean\n  /** Indicates whether the prompt is required before a user completes the onboarding flow */\n  required: boolean\n  /** Indicates whether the prompt is present in the onboarding flow. If `false`, the prompt will only appear in the Channels & Roles tab */\n  in_onboarding: boolean\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-prompt-option-structure */\nexport interface DiscordGuildOnboardingPromptOption {\n  /** ID of the prompt option */\n  id: string\n  /** IDs for channels a member is added to when the option is selected */\n  channel_ids: string[]\n  /** IDs for roles assigned to a member when the option is selected */\n  role_ids: string[]\n  /**\n   * Emoji of the option\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji?: DiscordEmoji\n  /**\n   * Emoji ID of the option\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji_id?: string\n  /**\n   * Emoji name of the option\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji_name?: string\n  /**\n   * Whether the emoji is animated\n   *\n   * @remarks\n   * When creating or updating a prompt option, the `emoji_id`, `emoji_name`, and `emoji_animated` fields must be used instead of the emoji object.\n   */\n  emoji_animated?: boolean\n  /** Title of the option */\n  title: string\n  /** Description of the option */\n  description: string | null\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-prompt-types */\nexport enum DiscordGuildOnboardingPromptType {\n  MultipleChoice,\n  DropDown,\n}\n\n/** https://discord.com/developers/docs/resources/guild#guild-onboarding-object-onboarding-mode */\nexport enum DiscordGuildOnboardingMode {\n  /** Counts only Default Channels towards constraints */\n  OnboardingDefault,\n  /** Counts Default Channels and Questions towards constraints */\n  OnboardingAdvanced,\n}\n\n/** https://discord.com/developers/docs/topics/teams#team-member-roles-team-member-role-types */\nexport enum DiscordTeamMemberRole {\n  /** Owners are the most permissiable role, and can take destructive, irreversible actions like deleting the team itself. Teams are limited to 1 owner. */\n  Owner = 'owner',\n  /** Admins have similar access as owners, except they cannot take destructive actions on the team or team-owned apps. */\n  Admin = 'admin',\n  /**\n   * Developers can access information about team-owned apps, like the client secret or public key.\n   * They can also take limited actions on team-owned apps, like configuring interaction endpoints or resetting the bot token.\n   * Members with the Developer role *cannot* manage the team or its members, or take destructive actions on team-owned apps.\n   */\n  Developer = 'developer',\n  /** Read-only members can access information about a team and any team-owned apps. Some examples include getting the IDs of applications and exporting payout records. */\n  ReadOnly = 'read_only',\n}\n\n/** https://discord.com/developers/docs/monetization/entitlements#entitlement-object-entitlement-structure */\nexport interface DiscordEntitlement {\n  /** ID of the entitlement */\n  id: string\n  /** ID of the SKU */\n  sku_id: string\n  /** ID of the user that is granted access to the entitlement's sku */\n  user_id?: string\n  /** ID of the guild that is granted access to the entitlement's sku */\n  guild_id?: string\n  /** ID of the parent application */\n  application_id: string\n  /** Type of entitlement */\n  type: DiscordEntitlementType\n  /** Entitlement was deleted */\n  deleted: boolean\n  /** Start date at which the entitlement is valid. Not present when using test entitlements */\n  starts_at?: string\n  /** Date at which the entitlement is no longer valid. Not present when using test entitlements */\n  ends_at?: string\n  /** For consumable items, whether or not the entitlement has been consumed */\n  consumed?: boolean\n}\n\n/** https://discord.com/developers/docs/monetization/entitlements#entitlement-object-entitlement-types */\nexport enum DiscordEntitlementType {\n  /** Entitlement was purchased by user */\n  Purchase = 1,\n  /** Entitlement for Discord Nitro subscription */\n  PremiumSubscription = 2,\n  /** Entitlement was gifted by developer */\n  DeveloperGift = 3,\n  /** Entitlement was purchased by a dev in application test mode */\n  TestModePurchase = 4,\n  /** Entitlement was granted when the SKU was free */\n  FreePurchase = 5,\n  /** Entitlement was gifted by another user */\n  UserGift = 6,\n  /** Entitlement was claimed by user for free as a Nitro Subscriber */\n  PremiumPurchase = 7,\n  /** Entitlement was purchased as an app subscription */\n  ApplicationSubscription = 8,\n}\n\n/** https://discord.com/developers/docs/monetization/skus#sku-object-sku-structure */\nexport interface DiscordSku {\n  /** ID of SKU */\n  id: string\n  /** Type of SKU */\n  type: DiscordSkuType\n  /** ID of the parent application */\n  application_id: string\n  /** Customer-facing name of your premium offering */\n  name: string\n  /** System-generated URL slug based on the SKU's name */\n  slug: string\n  /** SKU flags combined as a bitfield */\n  flags: SkuFlags\n}\n\n/** https://discord.com/developers/docs/monetization/skus#sku-object-sku-types */\nexport enum DiscordSkuType {\n  /** Durable one-time purchase */\n  Durable = 2,\n  /** Consumable one-time purchase */\n  Consumable = 3,\n  /** Represents a recurring subscription */\n  Subscription = 5,\n  /** System-generated group for each SUBSCRIPTION SKU created */\n  SubscriptionGroup = 6,\n}\n\n/** https://discord.com/developers/docs/resources/subscription#subscription-object */\nexport interface DiscordSubscription {\n  /** ID of the subscription */\n  id: string\n  /** ID of the user who is subscribed */\n  user_id: string\n  /** List of SKUs subscribed to */\n  sku_ids: string[]\n  /** List of entitlements granted for this subscription */\n  entitlement_ids: string[]\n  /** Start of the current subscription period */\n  current_period_start: string\n  /** End of the current subscription period */\n  current_period_end: string\n  /** Current status of the subscription */\n  status: DiscordSubscriptionStatus\n  /** When the subscription was canceled */\n  canceled_at: string | null\n  /** ISO3166-1 alpha-2 country code of the payment source used to purchase the subscription. Missing unless queried with a private OAuth scope. */\n  country?: string\n}\n\n/** https://discord.com/developers/docs/resources/subscription#subscription-statuses */\nexport enum DiscordSubscriptionStatus {\n  /** Subscription is active and scheduled to renew. */\n  Active,\n  /** Subscription is active but will not renew. */\n  Ending,\n  /** Subscription is inactive and not being charged. */\n  Inactive,\n}\n\n/** https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-object-interaction-context-types */\nexport enum DiscordInteractionContextType {\n  /** Interaction can be used within servers */\n  Guild = 0,\n  /** Interaction can be used within DMs with the app's bot user */\n  BotDm = 1,\n  /** Interaction can be used within Group DMs and DMs other than the app's bot user */\n  PrivateChannel = 2,\n}\n\n/** https://discord.com/developers/docs/resources/guild#bulk-guild-ban */\nexport interface DiscordBulkBan {\n  /** list of user ids, that were successfully banned */\n  banned_users: string[]\n  /** list of user ids, that were not banned */\n  failed_users: string[]\n}\n\n/** https://discord.com/developers/docs/resources/soundboard#soundboard-sound-object-soundboard-sound-structure */\nexport interface DiscordSoundboardSound {\n  /** The name of this sound */\n  name: string\n  /** The id of this sound */\n  sound_id: string\n  /** The volume of this sound, from 0 to 1 */\n  volume: number\n  /** The id of this sound's custom emoji */\n  emoji_id: string | null\n  /** The unicode character of this sound's standard emoji */\n  emoji_name: string | null\n  /** The id of the guild this sound is in */\n  guild_id?: string\n  /** Whether this sound can be used, may be false due to loss of Server Boosts */\n  available: boolean\n  /** The user who created this sound */\n  user?: DiscordUser\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#guild-soundboard-sound-delete-guild-soundboard-sound-delete-event-fields */\nexport interface DiscordSoundboardSoundDelete {\n  /** ID of the sound that was deleted */\n  sound_id: string\n  /** ID of the guild the sound was in */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#guild-soundboard-sounds-update-guild-soundboard-sounds-update-event-fields */\nexport interface DiscordSoundboardSoundsUpdate {\n  /** The guild's soundboard sounds */\n  soundboard_sounds: DiscordSoundboardSound[]\n  /** ID of the guild the sound was in */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/topics/gateway-events#soundboard-sounds-soundboard-sounds-event-fields */\nexport interface DiscordSoundboardSounds {\n  /** The guild's soundboard sounds */\n  soundboard_sounds: DiscordSoundboardSound[]\n  /** ID of the guild the sound was in */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#payload-structure */\nexport interface DiscordEventWebhookEvent {\n  /** Version scheme for the webhook event. Currently always 1 */\n  version: 1\n  /** ID of your app */\n  application_id: string\n  /** Type of webhook, either 0 for PING or 1 for webhook events */\n  type: DiscordEventWebhookType\n  /** Event data payload */\n  event?: DiscordEventWebhookEventBody\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#webhook-types */\nexport enum DiscordEventWebhookType {\n  /** PING event sent to verify your Webhook Event URL is active */\n  Ping = 0,\n  /** Webhook event (details for event in event body object) */\n  Event = 1,\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#event-body-object */\nexport interface DiscordEventWebhookEventBody {\n  /** Event type */\n  type: DiscordWebhookEventType\n  /** Timestamp of when the event occurred in ISO8601 format */\n  timestamp: string\n  /** Data for the event. The shape depends on the event type */\n  data?: DiscordEventWebhookApplicationAuthorizedBody | DiscordEntitlement\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#event-types */\nexport enum DiscordWebhookEventType {\n  /** Sent when an app was authorized by a user to a server or their account */\n  ApplicationAuthorized = 'APPLICATION_AUTHORIZED',\n  /** Entitlement was created */\n  EntitlementCreate = 'ENTITLEMENT_CREATE',\n  /** User was added to a Quest (currently unavailable) */\n  QuestUserEnrollment = 'QUEST_USER_ENROLLMENT',\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#application-authorized-application-authorized-structure */\nexport interface DiscordEventWebhookApplicationAuthorizedBody {\n  /** Installation context for the authorization. Either guild (0) if installed to a server or user (1) if installed to a user's account */\n  integration_type?: DiscordApplicationIntegrationType\n  /** User who authorized the app */\n  user: DiscordUser\n  /** List of scopes the user authorized */\n  scopes: OAuth2Scope[]\n  /** Server which app was authorized for (when integration type is 0) */\n  guild?: DiscordGuild\n}\n"],"names":["OAuth2Scope","DiscordApplicationIntegrationType","DiscordApplicationEventWebhookStatus","DiscordConnectionServiceType","DiscordConnectionVisibility","DiscordActivityLocationKind","DiscordReactionType","DiscordMessageReferenceType","DiscordPollLayoutType","AutoModerationEventTypes","AutoModerationTriggerTypes","DiscordAutoModerationRuleTriggerMetadataPresets","AutoModerationActionType","DiscordScheduledEventRecurrenceRuleFrequency","DiscordScheduledEventRecurrenceRuleWeekday","DiscordScheduledEventRecurrenceRuleMonth","DiscordInviteType","DiscordInteractionEntryPointCommandHandlerType","DiscordVoiceChannelEffectAnimationType","DiscordGuildOnboardingPromptType","DiscordGuildOnboardingMode","DiscordTeamMemberRole","DiscordEntitlementType","DiscordSkuType","DiscordSubscriptionStatus","DiscordInteractionContextType","DiscordEventWebhookType","DiscordWebhookEventType"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAwFYA;IACV;;;;;GAKC;IAED;;;;;GAKC;IAED,iEAAiE;IAEjE;;;;;GAKC;IAED,0FAA0F;IAE1F;;;;;GAKC;IAED,gGAAgG;IAEhG,mEAAmE;IAEnE,uHAAuH;IAEvH,+EAA+E;IAE/E,yHAAyH;IAEzH;;;;;GAKC;IAED,gHAAgH;IAEhH,gDAAgD;IAEhD,uHAAuH;IAEvH,oIAAoI;IAEpI,+IAA+I;IAE/I;;;;;;GAMC;IAED;;;GAGC;IAED;;;;;GAKC;IAED,2EAA2E;IAE3E;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED,kGAAkG;GA5HxFA,gBAAAA;;UAkVAC;IACV,kCAAkC;IAElC,gCAAgC;GAHtBA,sCAAAA;;UAQAC;IACV,6CAA6C;IAE7C,4CAA4C;IAE5C,sEAAsE;GAL5DA,yCAAAA;;UAkGAC;;;;;;;;;;;;;;;;;;;;;;;;GAAAA,iCAAAA;;UA2BAC;IACV,qDAAqD;IAErD,wBAAwB;GAHdA,gCAAAA;;UAuqBAC;IACV,oCAAoC;IAEpC,2DAA2D;GAHjDA,gCAAAA;;UAmOAC;;;GAAAA,wBAAAA;;UAuCAC;IACV;;;;;GAKC;IAED;;;;;;;;;GASC;GAjBSA,gCAAAA;;UAqEAC;IACV,uBAAuB;GADbA,0BAAAA;;UAukBAC;IACV,gCAAgC;IAEhC,qCAAqC;GAH3BA,6BAAAA;;UAOAC;IACV,0FAA0F;IAE1F,8DAA8D;IAE9D,yFAAyF;IAEzF,iFAAiF;IAEjF,iGAAiG;GATvFA,+BAAAA;;UAmEAC;IACV,8DAA8D;IAE9D,+DAA+D;IAE/D,iEAAiE;GALvDA,oDAAAA;;UAgBAC;IACV,0DAA0D;IAE1D,6CAA6C;IAE7C;;;;;;;GAOC;IAED,oEAAoE;GAd1DA,6BAAAA;;UAoRAC;;;;;GAAAA,iDAAAA;;UAOAC;;;;;;;;GAAAA,+CAAAA;;UAiBAC;;;;;;;;;;;;;GAAAA,6CAAAA;;UAiFAC;;;;GAAAA,sBAAAA;;UAmFAC;IACV,+DAA+D;IAE/D,+HAA+H;GAHrHA,mDAAAA;;UA4SAC;IACV,gDAAgD;IAEhD,2BAA2B;GAHjBA,2CAAAA;;UAoqBAC;;;GAAAA,qCAAAA;;UAMAC;IACV,qDAAqD;IAErD,8DAA8D;GAHpDA,+BAAAA;;UAQAC;IACV,uJAAuJ;IAEvJ,sHAAsH;IAEtH;;;;GAIC;IAED,uKAAuK;GAX7JA,0BAAAA;;UAwCAC;IACV,sCAAsC;IAEtC,+CAA+C;IAE/C,wCAAwC;IAExC,gEAAgE;IAEhE,kDAAkD;IAElD,2CAA2C;IAE3C,mEAAmE;IAEnE,qDAAqD;GAf3CA,2BAAAA;;UAoCAC;IACV,8BAA8B;IAE9B,iCAAiC;IAEjC,wCAAwC;IAExC,6DAA6D;GAPnDA,mBAAAA;;UAkCAC;IACV,mDAAmD;IAEnD,+CAA+C;IAE/C,oDAAoD;GAL1CA,8BAAAA;;UAUAC;IACV,2CAA2C;IAE3C,+DAA+D;IAE/D,mFAAmF;GALzEA,kCAAAA;;UA0EAC;IACV,+DAA+D;IAE/D,2DAA2D;GAHjDA,4BAAAA;;UAkBAC;IACV,2EAA2E;IAE3E,4BAA4B;IAE5B,sDAAsD;GAL5CA,4BAAAA"}
|