@discordeno/types 21.0.1-next.068ecf8 → 21.0.1-next.12d2cff

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.
@@ -20,4 +20,4 @@ var DiscordEntitlementType = /*#__PURE__*/ function(DiscordEntitlementType) {
20
20
  return DiscordEntitlementType;
21
21
  }({});
22
22
 
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2VudGl0bGVtZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9lbnRpdGxlbWVudCAqL1xuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2VudGl0bGVtZW50I2VudGl0bGVtZW50LW9iamVjdC1lbnRpdGxlbWVudC1zdHJ1Y3R1cmUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzY29yZEVudGl0bGVtZW50IHtcbiAgLyoqIElEIG9mIHRoZSBlbnRpdGxlbWVudCAqL1xuICBpZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgU0tVICovXG4gIHNrdV9pZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgdXNlciB0aGF0IGlzIGdyYW50ZWQgYWNjZXNzIHRvIHRoZSBlbnRpdGxlbWVudCdzIHNrdSAqL1xuICB1c2VyX2lkPzogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgZ3VpbGQgdGhhdCBpcyBncmFudGVkIGFjY2VzcyB0byB0aGUgZW50aXRsZW1lbnQncyBza3UgKi9cbiAgZ3VpbGRfaWQ/OiBzdHJpbmdcbiAgLyoqIElEIG9mIHRoZSBwYXJlbnQgYXBwbGljYXRpb24gKi9cbiAgYXBwbGljYXRpb25faWQ6IHN0cmluZ1xuICAvKiogVHlwZSBvZiBlbnRpdGxlbWVudCAqL1xuICB0eXBlOiBEaXNjb3JkRW50aXRsZW1lbnRUeXBlXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZGVsZXRlZCAqL1xuICBkZWxldGVkOiBib29sZWFuXG4gIC8qKiBTdGFydCBkYXRlIGF0IHdoaWNoIHRoZSBlbnRpdGxlbWVudCBpcyB2YWxpZC4gKi9cbiAgc3RhcnRzX2F0OiBzdHJpbmcgfCBudWxsXG4gIC8qKiBEYXRlIGF0IHdoaWNoIHRoZSBlbnRpdGxlbWVudCBpcyBubyBsb25nZXIgdmFsaWQuICovXG4gIGVuZHNfYXQ6IHN0cmluZyB8IG51bGxcbiAgLyoqIEZvciBjb25zdW1hYmxlIGl0ZW1zLCB3aGV0aGVyIG9yIG5vdCB0aGUgZW50aXRsZW1lbnQgaGFzIGJlZW4gY29uc3VtZWQgKi9cbiAgY29uc3VtZWQ/OiBib29sZWFuXG59XG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvZW50aXRsZW1lbnQjZW50aXRsZW1lbnQtb2JqZWN0LWVudGl0bGVtZW50LXR5cGVzICovXG5leHBvcnQgZW51bSBEaXNjb3JkRW50aXRsZW1lbnRUeXBlIHtcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgdXNlciAqL1xuICBQdXJjaGFzZSA9IDEsXG4gIC8qKiBFbnRpdGxlbWVudCBmb3IgRGlzY29yZCBOaXRybyBzdWJzY3JpcHRpb24gKi9cbiAgUHJlbWl1bVN1YnNjcmlwdGlvbiA9IDIsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGRldmVsb3BlciAqL1xuICBEZXZlbG9wZXJHaWZ0ID0gMyxcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgYSBkZXYgaW4gYXBwbGljYXRpb24gdGVzdCBtb2RlICovXG4gIFRlc3RNb2RlUHVyY2hhc2UgPSA0LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIGdyYW50ZWQgd2hlbiB0aGUgU0tVIHdhcyBmcmVlICovXG4gIEZyZWVQdXJjaGFzZSA9IDUsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGFub3RoZXIgdXNlciAqL1xuICBVc2VyR2lmdCA9IDYsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgY2xhaW1lZCBieSB1c2VyIGZvciBmcmVlIGFzIGEgTml0cm8gU3Vic2NyaWJlciAqL1xuICBQcmVtaXVtUHVyY2hhc2UgPSA3LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIHB1cmNoYXNlZCBhcyBhbiBhcHAgc3Vic2NyaXB0aW9uICovXG4gIEFwcGxpY2F0aW9uU3Vic2NyaXB0aW9uID0gOCxcbn1cbiJdLCJuYW1lcyI6WyJEaXNjb3JkRW50aXRsZW1lbnRUeXBlIl0sIm1hcHBpbmdzIjoiQUFBQSx5RUFBeUUsR0FFekUsdUdBQXVHOzs7OytCQXlCM0ZBOzs7ZUFBQUE7OztBQUFMLElBQUEsQUFBS0EsZ0RBQUFBO0lBQ1Ysc0NBQXNDO0lBRXRDLCtDQUErQztJQUUvQyx3Q0FBd0M7SUFFeEMsZ0VBQWdFO0lBRWhFLGtEQUFrRDtJQUVsRCwyQ0FBMkM7SUFFM0MsbUVBQW1FO0lBRW5FLHFEQUFxRDtXQWYzQ0EifQ==
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2VudGl0bGVtZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9lbnRpdGxlbWVudCAqL1xuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2VudGl0bGVtZW50I2VudGl0bGVtZW50LW9iamVjdC1lbnRpdGxlbWVudC1zdHJ1Y3R1cmUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzY29yZEVudGl0bGVtZW50IHtcbiAgLyoqIElEIG9mIHRoZSBlbnRpdGxlbWVudCAqL1xuICBpZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgU0tVICovXG4gIHNrdV9pZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgcGFyZW50IGFwcGxpY2F0aW9uICovXG4gIGFwcGxpY2F0aW9uX2lkOiBzdHJpbmdcbiAgLyoqIElEIG9mIHRoZSB1c2VyIHRoYXQgaXMgZ3JhbnRlZCBhY2Nlc3MgdG8gdGhlIGVudGl0bGVtZW50J3Mgc2t1ICovXG4gIHVzZXJfaWQ/OiBzdHJpbmdcbiAgLyoqIFR5cGUgb2YgZW50aXRsZW1lbnQgKi9cbiAgdHlwZTogRGlzY29yZEVudGl0bGVtZW50VHlwZVxuICAvKiogRW50aXRsZW1lbnQgd2FzIGRlbGV0ZWQgKi9cbiAgZGVsZXRlZDogYm9vbGVhblxuICAvKiogU3RhcnQgZGF0ZSBhdCB3aGljaCB0aGUgZW50aXRsZW1lbnQgaXMgdmFsaWQuICovXG4gIHN0YXJ0c19hdDogc3RyaW5nIHwgbnVsbFxuICAvKiogRGF0ZSBhdCB3aGljaCB0aGUgZW50aXRsZW1lbnQgaXMgbm8gbG9uZ2VyIHZhbGlkLiAqL1xuICBlbmRzX2F0OiBzdHJpbmcgfCBudWxsXG4gIC8qKiBJRCBvZiB0aGUgZ3VpbGQgdGhhdCBpcyBncmFudGVkIGFjY2VzcyB0byB0aGUgZW50aXRsZW1lbnQncyBza3UgKi9cbiAgZ3VpbGRfaWQ/OiBzdHJpbmdcbiAgLyoqIEZvciBjb25zdW1hYmxlIGl0ZW1zLCB3aGV0aGVyIG9yIG5vdCB0aGUgZW50aXRsZW1lbnQgaGFzIGJlZW4gY29uc3VtZWQgKi9cbiAgY29uc3VtZWQ/OiBib29sZWFuXG59XG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvZW50aXRsZW1lbnQjZW50aXRsZW1lbnQtb2JqZWN0LWVudGl0bGVtZW50LXR5cGVzICovXG5leHBvcnQgZW51bSBEaXNjb3JkRW50aXRsZW1lbnRUeXBlIHtcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgdXNlciAqL1xuICBQdXJjaGFzZSA9IDEsXG4gIC8qKiBFbnRpdGxlbWVudCBmb3IgRGlzY29yZCBOaXRybyBzdWJzY3JpcHRpb24gKi9cbiAgUHJlbWl1bVN1YnNjcmlwdGlvbiA9IDIsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGRldmVsb3BlciAqL1xuICBEZXZlbG9wZXJHaWZ0ID0gMyxcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgYSBkZXYgaW4gYXBwbGljYXRpb24gdGVzdCBtb2RlICovXG4gIFRlc3RNb2RlUHVyY2hhc2UgPSA0LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIGdyYW50ZWQgd2hlbiB0aGUgU0tVIHdhcyBmcmVlICovXG4gIEZyZWVQdXJjaGFzZSA9IDUsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGFub3RoZXIgdXNlciAqL1xuICBVc2VyR2lmdCA9IDYsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgY2xhaW1lZCBieSB1c2VyIGZvciBmcmVlIGFzIGEgTml0cm8gU3Vic2NyaWJlciAqL1xuICBQcmVtaXVtUHVyY2hhc2UgPSA3LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIHB1cmNoYXNlZCBhcyBhbiBhcHAgc3Vic2NyaXB0aW9uICovXG4gIEFwcGxpY2F0aW9uU3Vic2NyaXB0aW9uID0gOCxcbn1cbiJdLCJuYW1lcyI6WyJEaXNjb3JkRW50aXRsZW1lbnRUeXBlIl0sIm1hcHBpbmdzIjoiQUFBQSx5RUFBeUUsR0FFekUsdUdBQXVHOzs7OytCQXlCM0ZBOzs7ZUFBQUE7OztBQUFMLElBQUEsQUFBS0EsZ0RBQUFBO0lBQ1Ysc0NBQXNDO0lBRXRDLCtDQUErQztJQUUvQyx3Q0FBd0M7SUFFeEMsZ0VBQWdFO0lBRWhFLGtEQUFrRDtJQUVsRCwyQ0FBMkM7SUFFM0MsbUVBQW1FO0lBRW5FLHFEQUFxRDtXQWYzQ0EifQ==
@@ -204,4 +204,4 @@ var DiscordVoiceChannelEffectAnimationType = /*#__PURE__*/ function(DiscordVoice
204
204
  return DiscordVoiceChannelEffectAnimationType;
205
205
  }({});
206
206
 
207
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/discord/gateway.ts"],"sourcesContent":["/**\n * Types for:\n *  - https://discord.com/developers/docs/events/gateway\n *  - https://discord.com/developers/docs/events/gateway-events\n */\n\nimport type { DiscordApplication } from './application.js'\nimport type { AutoModerationTriggerTypes, DiscordAutoModerationAction } from './autoModeration.js'\nimport type { DiscordChannel, DiscordThreadMember } from './channel.js'\nimport type { DiscordEmoji } from './emoji.js'\nimport type { DiscordIntegration, DiscordMember, DiscordMemberWithUser, DiscordUnavailableGuild } from './guild.js'\nimport type { DiscordScheduledEvent } from './guildScheduledEvent.js'\nimport type { TargetTypes } from './invite.js'\nimport type { DiscordReactionType } from './message.js'\nimport type { DiscordRole } from './permissions.js'\nimport type { DiscordSoundboardSound } from './soundboard.js'\nimport type { DiscordStageInstance } from './stageInstance.js'\nimport type { DiscordSticker } from './sticker.js'\nimport type { DiscordAvatarDecorationData, DiscordUser } from './user.js'\nimport type { DiscordVoiceState } from './voice.js'\n\n/** https://discord.com/developers/docs/events/gateway#list-of-intents */\nexport enum GatewayIntents {\n  /**\n   * - GUILD_CREATE\n   * - GUILD_UPDATE\n   * - GUILD_DELETE\n   * - GUILD_ROLE_CREATE\n   * - GUILD_ROLE_UPDATE\n   * - GUILD_ROLE_DELETE\n   * - CHANNEL_CREATE\n   * - CHANNEL_UPDATE\n   * - CHANNEL_DELETE\n   * - CHANNEL_PINS_UPDATE\n   * - THREAD_CREATE\n   * - THREAD_UPDATE\n   * - THREAD_DELETE\n   * - THREAD_LIST_SYNC\n   * - THREAD_MEMBER_UPDATE\n   * - THREAD_MEMBERS_UPDATE\n   * - STAGE_INSTANCE_CREATE\n   * - STAGE_INSTANCE_UPDATE\n   * - STAGE_INSTANCE_DELETE\n   */\n  Guilds = 1 << 0,\n  /**\n   * - GUILD_MEMBER_ADD\n   * - GUILD_MEMBER_UPDATE\n   * - GUILD_MEMBER_REMOVE\n   * - THREAD_MEMBERS_UPDATE\n   *\n   * This is a privileged intent.\n   */\n  GuildMembers = 1 << 1,\n  /**\n   * - GUILD_AUDIT_LOG_ENTRY_CREATE\n   * - GUILD_BAN_ADD\n   * - GUILD_BAN_REMOVE\n   */\n  GuildModeration = 1 << 2,\n  /**\n   * - GUILD_EMOJIS_UPDATE\n   * - GUILD_STICKERS_UPDATE\n   * - GUILD_SOUNDBOARD_SOUND_CREATE\n   * - GUILD_SOUNDBOARD_SOUND_UPDATE\n   * - GUILD_SOUNDBOARD_SOUND_DELETE\n   * - GUILD_SOUNDBOARD_SOUNDS_UPDATE\n   */\n  GuildExpressions = 1 << 3,\n  /**\n   * - GUILD_INTEGRATIONS_UPDATE\n   * - INTEGRATION_CREATE\n   * - INTEGRATION_UPDATE\n   * - INTEGRATION_DELETE\n   */\n  GuildIntegrations = 1 << 4,\n  /**\n   * - WEBHOOKS_UPDATE\n   */\n  GuildWebhooks = 1 << 5,\n  /**\n   * - INVITE_CREATE\n   * - INVITE_DELETE\n   */\n  GuildInvites = 1 << 6,\n  /**\n   * - VOICE_STATE_UPDATE\n   * - VOICE_CHANNEL_EFFECT_SEND\n   */\n  GuildVoiceStates = 1 << 7,\n  /**\n   * - PRESENCE_UPDATE\n   *\n   * This is a privileged intent.\n   */\n  GuildPresences = 1 << 8,\n  /**\n   * - MESSAGE_CREATE\n   * - MESSAGE_UPDATE\n   * - MESSAGE_DELETE\n   * - MESSAGE_DELETE_BULK\n   *\n   * The messages do not contain content by default.\n   * If you want to receive their content too, you need to turn on the privileged `MESSAGE_CONTENT` intent. */\n  GuildMessages = 1 << 9,\n  /**\n   * - MESSAGE_REACTION_ADD\n   * - MESSAGE_REACTION_REMOVE\n   * - MESSAGE_REACTION_REMOVE_ALL\n   * - MESSAGE_REACTION_REMOVE_EMOJI\n   */\n  GuildMessageReactions = 1 << 10,\n  /**\n   * - TYPING_START\n   */\n  GuildMessageTyping = 1 << 11,\n  /**\n   * - CHANNEL_CREATE\n   * - MESSAGE_CREATE\n   * - MESSAGE_UPDATE\n   * - MESSAGE_DELETE\n   * - CHANNEL_PINS_UPDATE\n   */\n  DirectMessages = 1 << 12,\n  /**\n   * - MESSAGE_REACTION_ADD\n   * - MESSAGE_REACTION_REMOVE\n   * - MESSAGE_REACTION_REMOVE_ALL\n   * - MESSAGE_REACTION_REMOVE_EMOJI\n   */\n  DirectMessageReactions = 1 << 13,\n  /**\n   * - TYPING_START\n   */\n  DirectMessageTyping = 1 << 14,\n  /**\n   * This intent will add all content related values to message events.\n   *\n   * This is a privileged intent.\n   */\n  MessageContent = 1 << 15,\n  /**\n   * - GUILD_SCHEDULED_EVENT_CREATE\n   * - GUILD_SCHEDULED_EVENT_UPDATE\n   * - GUILD_SCHEDULED_EVENT_DELETE\n   * - GUILD_SCHEDULED_EVENT_USER_ADD this is experimental and unstable.\n   * - GUILD_SCHEDULED_EVENT_USER_REMOVE this is experimental and unstable.\n   */\n  GuildScheduledEvents = 1 << 16,\n  /**\n   * - AUTO_MODERATION_RULE_CREATE\n   * - AUTO_MODERATION_RULE_UPDATE\n   * - AUTO_MODERATION_RULE_DELETE\n   */\n  AutoModerationConfiguration = 1 << 20,\n  /**\n   * - AUTO_MODERATION_ACTION_EXECUTION\n   */\n  AutoModerationExecution = 1 << 21,\n  /**\n   * - MESSAGE_POLL_VOTE_ADD\n   * - MESSAGE_POLL_VOTE_REMOVE\n   */\n  GuildMessagePolls = 1 << 24,\n  /**\n   * - MESSAGE_POLL_VOTE_ADD\n   * - MESSAGE_POLL_VOTE_REMOVE\n   */\n  DirectMessagePolls = 1 << 25,\n}\n\nexport { GatewayIntents as Intents }\n\n// TODO: Add TransportCompression: https://discord.com/developers/docs/events/gateway#transport-compression\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/events/gateway-events#receive-events */\nexport type GatewayDispatchEventNames =\n  | 'READY'\n  | 'RESUMED'\n  | 'APPLICATION_COMMAND_PERMISSIONS_UPDATE'\n  | 'AUTO_MODERATION_RULE_CREATE'\n  | 'AUTO_MODERATION_RULE_UPDATE'\n  | 'AUTO_MODERATION_RULE_DELETE'\n  | 'AUTO_MODERATION_ACTION_EXECUTION'\n  | 'CHANNEL_CREATE'\n  | 'CHANNEL_UPDATE'\n  | 'CHANNEL_DELETE'\n  | 'CHANNEL_PINS_UPDATE'\n  | 'THREAD_CREATE'\n  | 'THREAD_UPDATE'\n  | 'THREAD_DELETE'\n  | 'THREAD_LIST_SYNC'\n  | 'THREAD_MEMBER_UPDATE'\n  | 'THREAD_MEMBERS_UPDATE'\n  | 'GUILD_AUDIT_LOG_ENTRY_CREATE'\n  | 'GUILD_CREATE'\n  | 'GUILD_UPDATE'\n  | 'GUILD_DELETE'\n  | 'GUILD_BAN_ADD'\n  | 'GUILD_BAN_REMOVE'\n  | 'GUILD_EMOJIS_UPDATE'\n  | 'GUILD_STICKERS_UPDATE'\n  | 'GUILD_INTEGRATIONS_UPDATE'\n  | 'GUILD_MEMBER_ADD'\n  | 'GUILD_MEMBER_REMOVE'\n  | 'GUILD_MEMBER_UPDATE'\n  | 'GUILD_MEMBERS_CHUNK'\n  | 'GUILD_ROLE_CREATE'\n  | 'GUILD_ROLE_UPDATE'\n  | 'GUILD_ROLE_DELETE'\n  | 'GUILD_SCHEDULED_EVENT_CREATE'\n  | 'GUILD_SCHEDULED_EVENT_UPDATE'\n  | 'GUILD_SCHEDULED_EVENT_DELETE'\n  | 'GUILD_SCHEDULED_EVENT_USER_ADD'\n  | 'GUILD_SCHEDULED_EVENT_USER_REMOVE'\n  | 'GUILD_SOUNDBOARD_SOUND_CREATE'\n  | 'GUILD_SOUNDBOARD_SOUND_UPDATE'\n  | 'GUILD_SOUNDBOARD_SOUND_DELETE'\n  | 'GUILD_SOUNDBOARD_SOUNDS_UPDATE'\n  | 'SOUNDBOARD_SOUNDS'\n  | 'INTEGRATION_CREATE'\n  | 'INTEGRATION_UPDATE'\n  | 'INTEGRATION_DELETE'\n  | 'INTERACTION_CREATE'\n  | 'INVITE_CREATE'\n  | 'INVITE_DELETE'\n  | 'MESSAGE_CREATE'\n  | 'MESSAGE_UPDATE'\n  | 'MESSAGE_DELETE'\n  | 'MESSAGE_DELETE_BULK'\n  | 'MESSAGE_REACTION_ADD'\n  | 'MESSAGE_REACTION_REMOVE'\n  | 'MESSAGE_REACTION_REMOVE_ALL'\n  | 'MESSAGE_REACTION_REMOVE_EMOJI'\n  | 'PRESENCE_UPDATE'\n  | 'STAGE_INSTANCE_CREATE'\n  | 'STAGE_INSTANCE_UPDATE'\n  | 'STAGE_INSTANCE_DELETE'\n  | 'TYPING_START'\n  | 'USER_UPDATE'\n  | 'VOICE_CHANNEL_EFFECT_SEND'\n  | 'VOICE_STATE_UPDATE'\n  | 'VOICE_SERVER_UPDATE'\n  | 'WEBHOOKS_UPDATE'\n  | 'ENTITLEMENT_CREATE'\n  | 'ENTITLEMENT_UPDATE'\n  | 'ENTITLEMENT_DELETE'\n  | 'SUBSCRIPTION_CREATE'\n  | 'SUBSCRIPTION_UPDATE'\n  | 'SUBSCRIPTION_DELETE'\n  | 'MESSAGE_POLL_VOTE_ADD'\n  | 'MESSAGE_POLL_VOTE_REMOVE'\n\n/** https://discord.com/developers/docs/events/gateway-events#receive-events */\nexport type GatewayEventNames = GatewayDispatchEventNames\n\n/** https://discord.com/developers/docs/events/gateway-events#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// TODO: Add Identify: https://discord.com/developers/docs/events/gateway-events#identify-identify-structure\n// TODO: Add Identify Connection Properties: https://discord.com/developers/docs/events/gateway-events#identify-identify-connection-properties\n// TODO: Add Resume: https://discord.com/developers/docs/events/gateway-events#resume-resume-structure\n// TODO: Add Request Guild Members: https://discord.com/developers/docs/events/gateway-events#request-guild-members-request-guild-members-structure\n// TODO: Add Request Soundboard Sounds: https://discord.com/developers/docs/events/gateway-events#request-soundboard-sounds-request-soundboard-sounds-structure\n// TODO: Add Voice State Update: https://discord.com/developers/docs/events/gateway-events#update-voice-state-gateway-voice-state-update-structure\n\n/** https://discord.com/developers/docs/events/gateway-events#update-presence-gateway-presence-update-structure */\nexport interface DiscordUpdatePresence {\n  /** Unix time (in milliseconds) of when the client went idle, or null if the client is not idle */\n  since: number | null\n  /** The user's activities */\n  activities: DiscordBotActivity[]\n  /** The user's new status */\n  status: Exclude<keyof typeof PresenceStatus, 'offline'>\n  /** Whether or not the client is afk */\n  afk: boolean\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#update-presence-status-types */\nexport enum PresenceStatus {\n  online,\n  dnd,\n  idle,\n  invisible,\n  offline,\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#hello-hello-structure */\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-events#ready-ready-event-fields */\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/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/events/gateway-events#thread-create */\nexport interface DiscordThreadCreateExtra {\n  /**\n   * When a thread is created this will be true on that channel payload for the thread.\n   *\n   * @remarks\n   * The Thread Create event may fire for a few reasons, however this fields only exists when it is fired because a thread was created.\n   */\n  newly_created?: boolean\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#thread-list-sync-thread-list-sync-event-fields */\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/events/gateway-events#thread-member-update-thread-member-update-event-extra-fields */\nexport interface DiscordThreadMemberUpdateExtra {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#thread-member-update-thread-member-update-event-extra-fields */\nexport interface DiscordThreadMemberUpdate extends DiscordThreadMember, DiscordThreadMemberUpdateExtra {}\n\n/** https://discord.com/developers/docs/events/gateway-events#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#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-events#guild-create-guild-create-extra-fields */\nexport interface DiscordGuildCreateExtra {\n  /** When this guild was joined at */\n  joined_at: string\n  /** If this is considered a large guild */\n  large: boolean\n  /** If the guild is unavailable due to an outage */\n  unavailable?: boolean\n  /** Total number of member in this guild */\n  member_count: number\n  /**\n   * States of members currently in voice channels\n   *\n   * @remarks\n   * Lacks the `guild_id` key\n   */\n  voice_states: Omit<DiscordVoiceState, \"guild_id\">[]\n  /** Users in the guild */\n  members: DiscordMemberWithUser[]\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  /**\n   * Presences of the members in the guild\n   *\n   * @remarks\n   * Will only include non-offline members if the size is greater than the large threshold.\n   */\n  presences?: Partial<DiscordPresenceUpdate>[]\n  /** Stage instances in the guild */\n  stage_instances?: DiscordStageInstance[]\n  /** Scheduled events in the guild */\n  guild_scheduled_events: DiscordScheduledEvent[]\n  /** Soundboard sounds in the guild */\n  soundboard_sounds: DiscordSoundboardSound[]\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-audit-log-entry-create-guild-audit-log-entry-create-event-extra-fields */\nexport interface DiscordGuildAuditLogEntryCreateExtra {\n  /** The id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-ban-add-guild-ban-add-event-fields */\nexport interface DiscordGuildBanAdd {\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-events#guild-ban-remove-guild-ban-remove-event-fields */\nexport interface DiscordGuildBanRemove {\n  /** id of the guild */\n  guild_id: string\n  /** The banned user */\n  user: DiscordUser\n}\n\n/**\n * https://discord.com/developers/docs/events/gateway-events#guild-ban-add-guild-ban-add-event-fields\n * https://discord.com/developers/docs/events/gateway-events#guild-ban-remove-guild-ban-remove-event-fields\n *\n * @deprecated\n * Use {@link DiscordGuildBanAdd} and {@link DiscordGuildBanRemove} instead.\n */\nexport interface DiscordGuildBanAddRemove extends DiscordGuildBanAdd {}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-emojis-update-guild-emojis-update-event-fields */\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-guild-stickers-update-event-fields */\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-events#guild-integrations-update-guild-integrations-update-event-fields */\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-events#guild-member-add-guild-member-add-extra-fields */\nexport interface DiscordGuildMemberAddExtra {\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-member-add-guild-member-add-extra-fields */\nexport interface DiscordGuildMemberAdd extends DiscordMemberWithUser, DiscordGuildMemberAddExtra {}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-member-remove-guild-member-remove-event-fields */\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/events/gateway-events#guild-member-update-guild-member-update-event-fields */\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-events#guild-members-chunk-guild-members-chunk-event-fields */\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-events#guild-role-create-guild-role-create-event-fields */\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-events#guild-role-update-guild-role-update-event-fields */\nexport interface DiscordGuildRoleUpdate {\n  /** The id of the guild */\n  guild_id: string\n  /** The role updated */\n  role: DiscordRole\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-role-delete-guild-role-delete-event-fields */\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-events#guild-scheduled-event-user-add-guild-scheduled-event-user-add-event-fields */\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-events#guild-scheduled-event-user-remove-guild-scheduled-event-user-remove-event-fields */\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-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/events/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/gateway-events#integration-create-integration-create-event-additional-fields */\nexport interface DiscordIntegrationCreateExtra {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#integration-update-integration-update-event-additional-fields */\nexport interface DiscordIntegrationUpdateExtra {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/**\n * https://discord.com/developers/docs/events/gateway-events#integration-create-integration-create-event-additional-fields\n * https://discord.com/developers/docs/events/gateway-events#integration-update-integration-update-event-additional-fields\n */\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-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/events/gateway-events#invite-create-invite-create-event-fields */\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-events#invite-delete-invite-delete-event-fields */\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/events/gateway-events#message-create-message-create-extra-fields */\nexport interface DiscordMessageCreateExtra {\n  /** ID of the guild the message was sent in - unless it is an ephemeral message */\n  guild_id?: string\n  /** Member properties for this message's author. Missing for ephemeral messages and messages from webhooks */\n  member?: Partial<DiscordMemberWithUser>\n  /** Users specifically mentioned in the message */\n  mentions: Array<DiscordUser & { member?: Partial<DiscordMember> }>\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-update */\nexport type DiscordMessageUpdateExtra = DiscordMessageCreateExtra\n\n/** https://discord.com/developers/docs/events/gateway-events#message-delete-message-delete-event-fields */\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-events#message-delete-bulk-message-delete-bulk-event-fields */\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/events/gateway-events#message-reaction-add-message-reaction-add-event-fields */\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-events#message-reaction-remove-message-reaction-remove-event-fields */\nexport interface DiscordMessageReactionRemove {\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 emoji used to react */\n  emoji: Partial<DiscordEmoji>\n  /** true if this is a super-reaction */\n  burst: boolean\n  /** The type of reaction */\n  type: DiscordReactionType\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-reaction-remove-all-message-reaction-remove-all-event-fields */\nexport interface DiscordMessageReactionRemoveAll {\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}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-reaction-remove-emoji-message-reaction-remove-emoji-event-fields */\nexport interface DiscordMessageReactionRemoveEmoji {\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 emoji used to react */\n  emoji: Partial<DiscordEmoji>\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#presence-update-presence-update-event-fields */\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/events/gateway-events#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-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  /** Unix timestamps for start and/or end of the game */\n  timestamps?: DiscordActivityTimestamps\n  /** Application id for the game */\n  application_id?: string\n  /** Controls which field is displayed in the user's status text in the member list */\n  status_display_type?: DiscordStatusDisplayType | null\n  /** What the player is currently doing */\n  details?: string | null\n  /** URL that is linked when clicking on the details text */\n  details_url?: string | null\n  /** The user's current party status */\n  state?: string | null\n  /** URL that is linked when clicking on the state text */\n  state_url?: string | null\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  /** 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  /** The custom buttons shown in the Rich Presence (max 2) */\n  buttons?: DiscordActivityButton[]\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#activity-object - Note at the bottom */\nexport type DiscordBotActivity = Pick<DiscordActivity, 'name' | 'state' | 'type' | 'url'>\n\n/** https://discord.com/developers/docs/events/gateway-events#activity-object-activity-types */\nexport enum ActivityTypes {\n  Playing = 0,\n  Streaming = 1,\n  Listening = 2,\n  Watching = 3,\n  Custom = 4,\n  Competing = 5,\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#activity-object-status-display-types */\nexport enum DiscordStatusDisplayType {\n  /** Example: \"Listening to Spotify\" */\n  Name = 0,\n  /** Example: \"Listening to Rick Astley\" */\n  State = 1,\n  /** Example: \"Listening to Never Gonna Give You Up\" */\n  Details = 2,\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#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-events#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-events#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-events#activity-object-activity-assets */\nexport interface DiscordActivityAssets {\n  /** The id for a large asset of the activity, usually a snowflake */\n  large_image?: string\n  /** Text displayed when hovering over the large image of the activity */\n  large_text?: string\n  /** URL that is opened when clicking on the large image */\n  large_url?: string\n  /** The id for a small asset of the activity, usually a snowflake */\n  small_image?: string\n  /** Text displayed when hovering over the small image of the activity */\n  small_text?: string\n  /** URL that is opened when clicking on the small image */\n  small_url?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#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-events#activity-object-activity-flags */\nexport enum ActivityFlags {\n  Instance = 1 << 0,\n  Join = 1 << 1,\n  Spectate = 1 << 2,\n  JoinRequest = 1 << 3,\n  Sync = 1 << 4,\n  Play = 1 << 5,\n  PartyPrivacyFriends = 1 << 6,\n  PartyPrivacyVoiceChannel = 1 << 7,\n  Embedded = 1 << 8,\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\n/** https://discord.com/developers/docs/events/gateway-events#typing-start-typing-start-event-fields */\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/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-events#voice-server-update-voice-server-update-event-fields */\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#webhooks-update-webhooks-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/events/gateway-events#message-poll-vote-add-message-poll-vote-add-fields */\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-message-poll-vote-remove-fields */\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"],"names":["ActivityFlags","ActivityTypes","DiscordStatusDisplayType","DiscordVoiceChannelEffectAnimationType","GatewayIntents","Intents","PresenceStatus"],"mappings":"AAAA;;;;CAIC;;;;;;;;;;;QAw7BWA;eAAAA;;QAxEAC;eAAAA;;QAUAC;eAAAA;;QAqHAC;eAAAA;;QA79BAC;eAAAA;;QAqJeC;eAAlBD;;QA2IGE;eAAAA;;;AAhSL,IAAA,AAAKF,wCAAAA;IACV;;;;;;;;;;;;;;;;;;;;GAoBC;IAED;;;;;;;GAOC;IAED;;;;GAIC;IAED;;;;;;;GAOC;IAED;;;;;GAKC;IAED;;GAEC;IAED;;;GAGC;IAED;;;GAGC;IAED;;;;GAIC;IAED;;;;;;;4GAO0G;IAE1G;;;;;GAKC;IAED;;GAEC;IAED;;;;;;GAMC;IAED;;;;;GAKC;IAED;;GAEC;IAED;;;;GAIC;IAED;;;;;;GAMC;IAED;;;;GAIC;IAED;;GAEC;IAED;;;GAGC;IAED;;;GAGC;WAjJSA;;AAgSL,IAAA,AAAKE,wCAAAA;;;;;;WAAAA;;AA8jBL,IAAA,AAAKL,uCAAAA;;;;;;;WAAAA;;AAUL,IAAA,AAAKC,kDAAAA;IACV,oCAAoC;IAEpC,wCAAwC;IAExC,oDAAoD;WAL1CA;;AA8DL,IAAA,AAAKF,uCAAAA;;;;;;;;;;WAAAA;;AAuDL,IAAA,AAAKG,gEAAAA;IACV,gDAAgD;IAEhD,2BAA2B;WAHjBA"}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/discord/gateway.ts"],"sourcesContent":["/**\n * Types for:\n *  - https://discord.com/developers/docs/events/gateway\n *  - https://discord.com/developers/docs/events/gateway-events\n */\n\nimport type { DiscordApplication } from './application.js'\nimport type { AutoModerationTriggerTypes, DiscordAutoModerationAction } from './autoModeration.js'\nimport type { DiscordChannel, DiscordThreadMember } from './channel.js'\nimport type { DiscordEmoji } from './emoji.js'\nimport type { DiscordIntegration, DiscordMember, DiscordMemberWithUser, DiscordUnavailableGuild } from './guild.js'\nimport type { DiscordScheduledEvent } from './guildScheduledEvent.js'\nimport type { TargetTypes } from './invite.js'\nimport type { DiscordReactionType } from './message.js'\nimport type { DiscordRole } from './permissions.js'\nimport type { DiscordSoundboardSound } from './soundboard.js'\nimport type { DiscordStageInstance } from './stageInstance.js'\nimport type { DiscordSticker } from './sticker.js'\nimport type { DiscordAvatarDecorationData, DiscordUser } from './user.js'\nimport type { DiscordVoiceState } from './voice.js'\n\n/** https://discord.com/developers/docs/events/gateway#list-of-intents */\nexport enum GatewayIntents {\n  /**\n   * - GUILD_CREATE\n   * - GUILD_UPDATE\n   * - GUILD_DELETE\n   * - GUILD_ROLE_CREATE\n   * - GUILD_ROLE_UPDATE\n   * - GUILD_ROLE_DELETE\n   * - CHANNEL_CREATE\n   * - CHANNEL_UPDATE\n   * - CHANNEL_DELETE\n   * - CHANNEL_PINS_UPDATE\n   * - THREAD_CREATE\n   * - THREAD_UPDATE\n   * - THREAD_DELETE\n   * - THREAD_LIST_SYNC\n   * - THREAD_MEMBER_UPDATE\n   * - THREAD_MEMBERS_UPDATE\n   * - STAGE_INSTANCE_CREATE\n   * - STAGE_INSTANCE_UPDATE\n   * - STAGE_INSTANCE_DELETE\n   */\n  Guilds = 1 << 0,\n  /**\n   * - GUILD_MEMBER_ADD\n   * - GUILD_MEMBER_UPDATE\n   * - GUILD_MEMBER_REMOVE\n   * - THREAD_MEMBERS_UPDATE\n   *\n   * This is a privileged intent.\n   */\n  GuildMembers = 1 << 1,\n  /**\n   * - GUILD_AUDIT_LOG_ENTRY_CREATE\n   * - GUILD_BAN_ADD\n   * - GUILD_BAN_REMOVE\n   */\n  GuildModeration = 1 << 2,\n  /**\n   * - GUILD_EMOJIS_UPDATE\n   * - GUILD_STICKERS_UPDATE\n   * - GUILD_SOUNDBOARD_SOUND_CREATE\n   * - GUILD_SOUNDBOARD_SOUND_UPDATE\n   * - GUILD_SOUNDBOARD_SOUND_DELETE\n   * - GUILD_SOUNDBOARD_SOUNDS_UPDATE\n   */\n  GuildExpressions = 1 << 3,\n  /**\n   * - GUILD_INTEGRATIONS_UPDATE\n   * - INTEGRATION_CREATE\n   * - INTEGRATION_UPDATE\n   * - INTEGRATION_DELETE\n   */\n  GuildIntegrations = 1 << 4,\n  /**\n   * - WEBHOOKS_UPDATE\n   */\n  GuildWebhooks = 1 << 5,\n  /**\n   * - INVITE_CREATE\n   * - INVITE_DELETE\n   */\n  GuildInvites = 1 << 6,\n  /**\n   * - VOICE_STATE_UPDATE\n   * - VOICE_CHANNEL_EFFECT_SEND\n   */\n  GuildVoiceStates = 1 << 7,\n  /**\n   * - PRESENCE_UPDATE\n   *\n   * This is a privileged intent.\n   */\n  GuildPresences = 1 << 8,\n  /**\n   * - MESSAGE_CREATE\n   * - MESSAGE_UPDATE\n   * - MESSAGE_DELETE\n   * - MESSAGE_DELETE_BULK\n   *\n   * The messages do not contain content by default.\n   * If you want to receive their content too, you need to turn on the privileged `MESSAGE_CONTENT` intent. */\n  GuildMessages = 1 << 9,\n  /**\n   * - MESSAGE_REACTION_ADD\n   * - MESSAGE_REACTION_REMOVE\n   * - MESSAGE_REACTION_REMOVE_ALL\n   * - MESSAGE_REACTION_REMOVE_EMOJI\n   */\n  GuildMessageReactions = 1 << 10,\n  /**\n   * - TYPING_START\n   */\n  GuildMessageTyping = 1 << 11,\n  /**\n   * - CHANNEL_CREATE\n   * - MESSAGE_CREATE\n   * - MESSAGE_UPDATE\n   * - MESSAGE_DELETE\n   * - CHANNEL_PINS_UPDATE\n   */\n  DirectMessages = 1 << 12,\n  /**\n   * - MESSAGE_REACTION_ADD\n   * - MESSAGE_REACTION_REMOVE\n   * - MESSAGE_REACTION_REMOVE_ALL\n   * - MESSAGE_REACTION_REMOVE_EMOJI\n   */\n  DirectMessageReactions = 1 << 13,\n  /**\n   * - TYPING_START\n   */\n  DirectMessageTyping = 1 << 14,\n  /**\n   * This intent will add all content related values to message events.\n   *\n   * This is a privileged intent.\n   */\n  MessageContent = 1 << 15,\n  /**\n   * - GUILD_SCHEDULED_EVENT_CREATE\n   * - GUILD_SCHEDULED_EVENT_UPDATE\n   * - GUILD_SCHEDULED_EVENT_DELETE\n   * - GUILD_SCHEDULED_EVENT_USER_ADD this is experimental and unstable.\n   * - GUILD_SCHEDULED_EVENT_USER_REMOVE this is experimental and unstable.\n   */\n  GuildScheduledEvents = 1 << 16,\n  /**\n   * - AUTO_MODERATION_RULE_CREATE\n   * - AUTO_MODERATION_RULE_UPDATE\n   * - AUTO_MODERATION_RULE_DELETE\n   */\n  AutoModerationConfiguration = 1 << 20,\n  /**\n   * - AUTO_MODERATION_ACTION_EXECUTION\n   */\n  AutoModerationExecution = 1 << 21,\n  /**\n   * - MESSAGE_POLL_VOTE_ADD\n   * - MESSAGE_POLL_VOTE_REMOVE\n   */\n  GuildMessagePolls = 1 << 24,\n  /**\n   * - MESSAGE_POLL_VOTE_ADD\n   * - MESSAGE_POLL_VOTE_REMOVE\n   */\n  DirectMessagePolls = 1 << 25,\n}\n\nexport { GatewayIntents as Intents }\n\n// TODO: Add TransportCompression: https://discord.com/developers/docs/events/gateway#transport-compression\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/events/gateway-events#receive-events */\nexport type GatewayDispatchEventNames =\n  | 'READY'\n  | 'RESUMED'\n  | 'APPLICATION_COMMAND_PERMISSIONS_UPDATE'\n  | 'AUTO_MODERATION_RULE_CREATE'\n  | 'AUTO_MODERATION_RULE_UPDATE'\n  | 'AUTO_MODERATION_RULE_DELETE'\n  | 'AUTO_MODERATION_ACTION_EXECUTION'\n  | 'CHANNEL_CREATE'\n  | 'CHANNEL_UPDATE'\n  | 'CHANNEL_DELETE'\n  | 'CHANNEL_PINS_UPDATE'\n  | 'THREAD_CREATE'\n  | 'THREAD_UPDATE'\n  | 'THREAD_DELETE'\n  | 'THREAD_LIST_SYNC'\n  | 'THREAD_MEMBER_UPDATE'\n  | 'THREAD_MEMBERS_UPDATE'\n  | 'GUILD_AUDIT_LOG_ENTRY_CREATE'\n  | 'GUILD_CREATE'\n  | 'GUILD_UPDATE'\n  | 'GUILD_DELETE'\n  | 'GUILD_BAN_ADD'\n  | 'GUILD_BAN_REMOVE'\n  | 'GUILD_EMOJIS_UPDATE'\n  | 'GUILD_STICKERS_UPDATE'\n  | 'GUILD_INTEGRATIONS_UPDATE'\n  | 'GUILD_MEMBER_ADD'\n  | 'GUILD_MEMBER_REMOVE'\n  | 'GUILD_MEMBER_UPDATE'\n  | 'GUILD_MEMBERS_CHUNK'\n  | 'GUILD_ROLE_CREATE'\n  | 'GUILD_ROLE_UPDATE'\n  | 'GUILD_ROLE_DELETE'\n  | 'GUILD_SCHEDULED_EVENT_CREATE'\n  | 'GUILD_SCHEDULED_EVENT_UPDATE'\n  | 'GUILD_SCHEDULED_EVENT_DELETE'\n  | 'GUILD_SCHEDULED_EVENT_USER_ADD'\n  | 'GUILD_SCHEDULED_EVENT_USER_REMOVE'\n  | 'GUILD_SOUNDBOARD_SOUND_CREATE'\n  | 'GUILD_SOUNDBOARD_SOUND_UPDATE'\n  | 'GUILD_SOUNDBOARD_SOUND_DELETE'\n  | 'GUILD_SOUNDBOARD_SOUNDS_UPDATE'\n  | 'SOUNDBOARD_SOUNDS'\n  | 'INTEGRATION_CREATE'\n  | 'INTEGRATION_UPDATE'\n  | 'INTEGRATION_DELETE'\n  | 'INTERACTION_CREATE'\n  | 'INVITE_CREATE'\n  | 'INVITE_DELETE'\n  | 'MESSAGE_CREATE'\n  | 'MESSAGE_UPDATE'\n  | 'MESSAGE_DELETE'\n  | 'MESSAGE_DELETE_BULK'\n  | 'MESSAGE_REACTION_ADD'\n  | 'MESSAGE_REACTION_REMOVE'\n  | 'MESSAGE_REACTION_REMOVE_ALL'\n  | 'MESSAGE_REACTION_REMOVE_EMOJI'\n  | 'PRESENCE_UPDATE'\n  | 'STAGE_INSTANCE_CREATE'\n  | 'STAGE_INSTANCE_UPDATE'\n  | 'STAGE_INSTANCE_DELETE'\n  | 'TYPING_START'\n  | 'USER_UPDATE'\n  | 'VOICE_CHANNEL_EFFECT_SEND'\n  | 'VOICE_STATE_UPDATE'\n  | 'VOICE_SERVER_UPDATE'\n  | 'WEBHOOKS_UPDATE'\n  | 'ENTITLEMENT_CREATE'\n  | 'ENTITLEMENT_UPDATE'\n  | 'ENTITLEMENT_DELETE'\n  | 'SUBSCRIPTION_CREATE'\n  | 'SUBSCRIPTION_UPDATE'\n  | 'SUBSCRIPTION_DELETE'\n  | 'MESSAGE_POLL_VOTE_ADD'\n  | 'MESSAGE_POLL_VOTE_REMOVE'\n\n/** https://discord.com/developers/docs/events/gateway-events#receive-events */\nexport type GatewayEventNames = GatewayDispatchEventNames\n\n/** https://discord.com/developers/docs/events/gateway-events#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// TODO: Add Identify: https://discord.com/developers/docs/events/gateway-events#identify-identify-structure\n// TODO: Add Identify Connection Properties: https://discord.com/developers/docs/events/gateway-events#identify-identify-connection-properties\n// TODO: Add Resume: https://discord.com/developers/docs/events/gateway-events#resume-resume-structure\n// TODO: Add Request Guild Members: https://discord.com/developers/docs/events/gateway-events#request-guild-members-request-guild-members-structure\n// TODO: Add Request Soundboard Sounds: https://discord.com/developers/docs/events/gateway-events#request-soundboard-sounds-request-soundboard-sounds-structure\n// TODO: Add Voice State Update: https://discord.com/developers/docs/events/gateway-events#update-voice-state-gateway-voice-state-update-structure\n\n/** https://discord.com/developers/docs/events/gateway-events#update-presence-gateway-presence-update-structure */\nexport interface DiscordUpdatePresence {\n  /** Unix time (in milliseconds) of when the client went idle, or null if the client is not idle */\n  since: number | null\n  /** The user's activities */\n  activities: DiscordBotActivity[]\n  /** The user's new status */\n  status: Exclude<keyof typeof PresenceStatus, 'offline'>\n  /** Whether or not the client is afk */\n  afk: boolean\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#update-presence-status-types */\nexport enum PresenceStatus {\n  online,\n  dnd,\n  idle,\n  invisible,\n  offline,\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#hello-hello-structure */\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-events#ready-ready-event-fields */\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/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/events/gateway-events#thread-create */\nexport interface DiscordThreadCreateExtra {\n  /**\n   * When a thread is created this will be true on that channel payload for the thread.\n   *\n   * @remarks\n   * The Thread Create event may fire for a few reasons, however this fields only exists when it is fired because a thread was created.\n   */\n  newly_created?: boolean\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#thread-list-sync-thread-list-sync-event-fields */\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/events/gateway-events#thread-member-update-thread-member-update-event-extra-fields */\nexport interface DiscordThreadMemberUpdateExtra {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#thread-member-update-thread-member-update-event-extra-fields */\nexport interface DiscordThreadMemberUpdate extends DiscordThreadMember, DiscordThreadMemberUpdateExtra {}\n\n/** https://discord.com/developers/docs/events/gateway-events#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#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-events#guild-create-guild-create-extra-fields */\nexport interface DiscordGuildCreateExtra {\n  /** When this guild was joined at */\n  joined_at: string\n  /** If this is considered a large guild */\n  large: boolean\n  /** If the guild is unavailable due to an outage */\n  unavailable?: boolean\n  /** Total number of member in this guild */\n  member_count: number\n  /**\n   * States of members currently in voice channels\n   *\n   * @remarks\n   * Lacks the `guild_id` key\n   */\n  voice_states: Omit<DiscordVoiceState, 'guild_id'>[]\n  /** Users in the guild */\n  members: DiscordMemberWithUser[]\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  /**\n   * Presences of the members in the guild\n   *\n   * @remarks\n   * Will only include non-offline members if the size is greater than the large threshold.\n   */\n  presences?: Partial<DiscordPresenceUpdate>[]\n  /** Stage instances in the guild */\n  stage_instances?: DiscordStageInstance[]\n  /** Scheduled events in the guild */\n  guild_scheduled_events: DiscordScheduledEvent[]\n  /** Soundboard sounds in the guild */\n  soundboard_sounds: DiscordSoundboardSound[]\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-audit-log-entry-create-guild-audit-log-entry-create-event-extra-fields */\nexport interface DiscordGuildAuditLogEntryCreateExtra {\n  /** The id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-ban-add-guild-ban-add-event-fields */\nexport interface DiscordGuildBanAdd {\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-events#guild-ban-remove-guild-ban-remove-event-fields */\nexport interface DiscordGuildBanRemove {\n  /** id of the guild */\n  guild_id: string\n  /** The banned user */\n  user: DiscordUser\n}\n\n/**\n * https://discord.com/developers/docs/events/gateway-events#guild-ban-add-guild-ban-add-event-fields\n * https://discord.com/developers/docs/events/gateway-events#guild-ban-remove-guild-ban-remove-event-fields\n *\n * @deprecated\n * Use {@link DiscordGuildBanAdd} and {@link DiscordGuildBanRemove} instead.\n */\nexport interface DiscordGuildBanAddRemove extends DiscordGuildBanAdd {}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-emojis-update-guild-emojis-update-event-fields */\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-guild-stickers-update-event-fields */\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-events#guild-integrations-update-guild-integrations-update-event-fields */\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-events#guild-member-add-guild-member-add-extra-fields */\nexport interface DiscordGuildMemberAddExtra {\n  /** id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-member-add-guild-member-add-extra-fields */\nexport interface DiscordGuildMemberAdd extends DiscordMemberWithUser, DiscordGuildMemberAddExtra {}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-member-remove-guild-member-remove-event-fields */\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/events/gateway-events#guild-member-update-guild-member-update-event-fields */\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-events#guild-members-chunk-guild-members-chunk-event-fields */\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-events#guild-role-create-guild-role-create-event-fields */\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-events#guild-role-update-guild-role-update-event-fields */\nexport interface DiscordGuildRoleUpdate {\n  /** The id of the guild */\n  guild_id: string\n  /** The role updated */\n  role: DiscordRole\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#guild-role-delete-guild-role-delete-event-fields */\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-events#guild-scheduled-event-user-add-guild-scheduled-event-user-add-event-fields */\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-events#guild-scheduled-event-user-remove-guild-scheduled-event-user-remove-event-fields */\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-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/events/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/gateway-events#integration-create-integration-create-event-additional-fields */\nexport interface DiscordIntegrationCreateExtra {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#integration-update-integration-update-event-additional-fields */\nexport interface DiscordIntegrationUpdateExtra {\n  /** Id of the guild */\n  guild_id: string\n}\n\n/**\n * https://discord.com/developers/docs/events/gateway-events#integration-create-integration-create-event-additional-fields\n * https://discord.com/developers/docs/events/gateway-events#integration-update-integration-update-event-additional-fields\n */\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-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/events/gateway-events#invite-create-invite-create-event-fields */\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-events#invite-delete-invite-delete-event-fields */\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/events/gateway-events#message-create-message-create-extra-fields */\nexport interface DiscordMessageCreateExtra {\n  /** ID of the guild the message was sent in - unless it is an ephemeral message */\n  guild_id?: string\n  /** Member properties for this message's author. Missing for ephemeral messages and messages from webhooks */\n  member?: Partial<DiscordMemberWithUser>\n  /** Users specifically mentioned in the message */\n  mentions: Array<DiscordUser & { member?: Partial<DiscordMember> }>\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-update */\nexport type DiscordMessageUpdateExtra = DiscordMessageCreateExtra\n\n/** https://discord.com/developers/docs/events/gateway-events#message-delete-message-delete-event-fields */\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-events#message-delete-bulk-message-delete-bulk-event-fields */\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/events/gateway-events#message-reaction-add-message-reaction-add-event-fields */\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-events#message-reaction-remove-message-reaction-remove-event-fields */\nexport interface DiscordMessageReactionRemove {\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 emoji used to react */\n  emoji: Partial<DiscordEmoji>\n  /** true if this is a super-reaction */\n  burst: boolean\n  /** The type of reaction */\n  type: DiscordReactionType\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-reaction-remove-all-message-reaction-remove-all-event-fields */\nexport interface DiscordMessageReactionRemoveAll {\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}\n\n/** https://discord.com/developers/docs/events/gateway-events#message-reaction-remove-emoji-message-reaction-remove-emoji-event-fields */\nexport interface DiscordMessageReactionRemoveEmoji {\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 emoji used to react */\n  emoji: Partial<DiscordEmoji>\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#presence-update-presence-update-event-fields */\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/events/gateway-events#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-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  /** Unix timestamps for start and/or end of the game */\n  timestamps?: DiscordActivityTimestamps\n  /** Application id for the game */\n  application_id?: string\n  /** Controls which field is displayed in the user's status text in the member list */\n  status_display_type?: DiscordStatusDisplayType | null\n  /** What the player is currently doing */\n  details?: string | null\n  /** URL that is linked when clicking on the details text */\n  details_url?: string | null\n  /** The user's current party status */\n  state?: string | null\n  /** URL that is linked when clicking on the state text */\n  state_url?: string | null\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  /** 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  /** The custom buttons shown in the Rich Presence (max 2) */\n  buttons?: DiscordActivityButton[]\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#activity-object - Note at the bottom */\nexport type DiscordBotActivity = Pick<DiscordActivity, 'name' | 'state' | 'type' | 'url'>\n\n/** https://discord.com/developers/docs/events/gateway-events#activity-object-activity-types */\nexport enum ActivityTypes {\n  Playing = 0,\n  Streaming = 1,\n  Listening = 2,\n  Watching = 3,\n  Custom = 4,\n  Competing = 5,\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#activity-object-status-display-types */\nexport enum DiscordStatusDisplayType {\n  /** Example: \"Listening to Spotify\" */\n  Name = 0,\n  /** Example: \"Listening to Rick Astley\" */\n  State = 1,\n  /** Example: \"Listening to Never Gonna Give You Up\" */\n  Details = 2,\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#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-events#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-events#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-events#activity-object-activity-assets */\nexport interface DiscordActivityAssets {\n  /** The id for a large asset of the activity, usually a snowflake */\n  large_image?: string\n  /** Text displayed when hovering over the large image of the activity */\n  large_text?: string\n  /** URL that is opened when clicking on the large image */\n  large_url?: string\n  /** The id for a small asset of the activity, usually a snowflake */\n  small_image?: string\n  /** Text displayed when hovering over the small image of the activity */\n  small_text?: string\n  /** URL that is opened when clicking on the small image */\n  small_url?: string\n}\n\n/** https://discord.com/developers/docs/events/gateway-events#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-events#activity-object-activity-flags */\nexport enum ActivityFlags {\n  Instance = 1 << 0,\n  Join = 1 << 1,\n  Spectate = 1 << 2,\n  JoinRequest = 1 << 3,\n  Sync = 1 << 4,\n  Play = 1 << 5,\n  PartyPrivacyFriends = 1 << 6,\n  PartyPrivacyVoiceChannel = 1 << 7,\n  Embedded = 1 << 8,\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\n/** https://discord.com/developers/docs/events/gateway-events#typing-start-typing-start-event-fields */\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/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-events#voice-server-update-voice-server-update-event-fields */\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#webhooks-update-webhooks-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/events/gateway-events#message-poll-vote-add-message-poll-vote-add-fields */\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-message-poll-vote-remove-fields */\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"],"names":["ActivityFlags","ActivityTypes","DiscordStatusDisplayType","DiscordVoiceChannelEffectAnimationType","GatewayIntents","Intents","PresenceStatus"],"mappings":"AAAA;;;;CAIC;;;;;;;;;;;QAw7BWA;eAAAA;;QAxEAC;eAAAA;;QAUAC;eAAAA;;QAqHAC;eAAAA;;QA79BAC;eAAAA;;QAqJeC;eAAlBD;;QA2IGE;eAAAA;;;AAhSL,IAAA,AAAKF,wCAAAA;IACV;;;;;;;;;;;;;;;;;;;;GAoBC;IAED;;;;;;;GAOC;IAED;;;;GAIC;IAED;;;;;;;GAOC;IAED;;;;;GAKC;IAED;;GAEC;IAED;;;GAGC;IAED;;;GAGC;IAED;;;;GAIC;IAED;;;;;;;4GAO0G;IAE1G;;;;;GAKC;IAED;;GAEC;IAED;;;;;;GAMC;IAED;;;;;GAKC;IAED;;GAEC;IAED;;;;GAIC;IAED;;;;;;GAMC;IAED;;;;GAIC;IAED;;GAEC;IAED;;;GAGC;IAED;;;GAGC;WAjJSA;;AAgSL,IAAA,AAAKE,wCAAAA;;;;;;WAAAA;;AA8jBL,IAAA,AAAKL,uCAAAA;;;;;;;WAAAA;;AAUL,IAAA,AAAKC,kDAAAA;IACV,oCAAoC;IAEpC,wCAAwC;IAExC,oDAAoD;WAL1CA;;AA8DL,IAAA,AAAKF,uCAAAA;;;;;;;;;;WAAAA;;AAuDL,IAAA,AAAKG,gEAAAA;IACV,gDAAgD;IAEhD,2BAA2B;WAHjBA"}
@@ -78,4 +78,4 @@ var DiscordScheduledEventRecurrenceRuleMonth = /*#__PURE__*/ function(DiscordSch
78
78
  return DiscordScheduledEventRecurrenceRuleMonth;
79
79
  }({});
80
80
 
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/discord/guildScheduledEvent.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/resources/guild-scheduled-event */\n\nimport type { DiscordUser } from './user.js'\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-structure */\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\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-privacy-level */\nexport enum ScheduledEventPrivacyLevel {\n  /** the scheduled event is only accessible to guild members */\n  GuildOnly = 2,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-entity-types */\nexport enum ScheduledEventEntityType {\n  StageInstance = 1,\n  Voice,\n  External,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-status */\nexport enum ScheduledEventStatus {\n  Scheduled = 1,\n  Active,\n  Completed,\n  Canceled,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-entity-metadata */\nexport interface DiscordScheduledEventEntityMetadata {\n  /** location of the event */\n  location?: string\n}\n\n// TODO: missing ScheduledEventUser: https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-user-object-guild-scheduled-event-user-structure\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-structure */\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\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-frequency */\nexport enum DiscordScheduledEventRecurrenceRuleFrequency {\n  Yearly,\n  Monthly,\n  Weekly,\n  Daily,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-weekday */\nexport enum DiscordScheduledEventRecurrenceRuleWeekday {\n  Monday,\n  Tuesday,\n  Wednesday,\n  Thursday,\n  Friday,\n  Saturday,\n  Sunday,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-nweekday-structure */\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\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-month */\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"],"names":["DiscordScheduledEventRecurrenceRuleFrequency","DiscordScheduledEventRecurrenceRuleMonth","DiscordScheduledEventRecurrenceRuleWeekday","ScheduledEventEntityType","ScheduledEventPrivacyLevel","ScheduledEventStatus"],"mappings":"AAAA,mFAAmF;;;;;;;;;;;QAgGvEA;eAAAA;;QA2BAC;eAAAA;;QAnBAC;eAAAA;;QAvDAC;eAAAA;;QANAC;eAAAA;;QAaAC;eAAAA;;;AAbL,IAAA,AAAKD,oDAAAA;IACV,4DAA4D;WADlDA;;AAML,IAAA,AAAKD,kDAAAA;;;;WAAAA;;AAOL,IAAA,AAAKE,8CAAAA;;;;;WAAAA;;AAwCL,IAAA,AAAKL,sEAAAA;;;;;WAAAA;;AAQL,IAAA,AAAKE,oEAAAA;;;;;;;;WAAAA;;AAmBL,IAAA,AAAKD,kEAAAA;;;;;;;;;;;;;WAAAA"}
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/discord/guildScheduledEvent.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/resources/guild-scheduled-event */\n\nimport type { DiscordMember } from './guild.js'\nimport type { DiscordUser } from './user.js'\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-structure */\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 | null\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\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-privacy-level */\nexport enum ScheduledEventPrivacyLevel {\n  /** the scheduled event is only accessible to guild members */\n  GuildOnly = 2,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-entity-types */\nexport enum ScheduledEventEntityType {\n  StageInstance = 1,\n  Voice,\n  External,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-status */\nexport enum ScheduledEventStatus {\n  Scheduled = 1,\n  Active,\n  Completed,\n  Canceled,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-entity-metadata */\nexport interface DiscordScheduledEventEntityMetadata {\n  /** location of the event */\n  location?: string\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-user-object-guild-scheduled-event-user-structure */\nexport interface DiscordScheduledEventUser {\n  /** The scheduled event id which the user subscribed to */\n  guild_scheduled_event_id: string\n  /** User which subscribed to an event */\n  user: DiscordUser\n  /** Guild member data for this user for the guild which this event belongs to, if any */\n  member?: DiscordMember\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-structure */\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\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-frequency */\nexport enum DiscordScheduledEventRecurrenceRuleFrequency {\n  Yearly,\n  Monthly,\n  Weekly,\n  Daily,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-weekday */\nexport enum DiscordScheduledEventRecurrenceRuleWeekday {\n  Monday,\n  Tuesday,\n  Wednesday,\n  Thursday,\n  Friday,\n  Saturday,\n  Sunday,\n}\n\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-nweekday-structure */\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\n/** https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-recurrence-rule-object-guild-scheduled-event-recurrence-rule-month */\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"],"names":["DiscordScheduledEventRecurrenceRuleFrequency","DiscordScheduledEventRecurrenceRuleMonth","DiscordScheduledEventRecurrenceRuleWeekday","ScheduledEventEntityType","ScheduledEventPrivacyLevel","ScheduledEventStatus"],"mappings":"AAAA,mFAAmF;;;;;;;;;;;QAyGvEA;eAAAA;;QA2BAC;eAAAA;;QAnBAC;eAAAA;;QA/DAC;eAAAA;;QANAC;eAAAA;;QAaAC;eAAAA;;;AAbL,IAAA,AAAKD,oDAAAA;IACV,4DAA4D;WADlDA;;AAML,IAAA,AAAKD,kDAAAA;;;;WAAAA;;AAOL,IAAA,AAAKE,8CAAAA;;;;;WAAAA;;AAgDL,IAAA,AAAKL,sEAAAA;;;;;WAAAA;;AAQL,IAAA,AAAKE,oEAAAA;;;;;;;;WAAAA;;AAmBL,IAAA,AAAKD,kEAAAA;;;;;;;;;;;;;WAAAA"}
@@ -35,4 +35,4 @@ var DiscordGuildInviteFlags = /*#__PURE__*/ function(DiscordGuildInviteFlags) {
35
35
  return DiscordGuildInviteFlags;
36
36
  }({});
37
37
 
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2ludml0ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogVHlwZXMgZm9yOiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvaW52aXRlICovXG5cbmltcG9ydCB0eXBlIHsgRGlzY29yZEFwcGxpY2F0aW9uIH0gZnJvbSAnLi9hcHBsaWNhdGlvbi5qcydcbmltcG9ydCB0eXBlIHsgRGlzY29yZENoYW5uZWwgfSBmcm9tICcuL2NoYW5uZWwuanMnXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRHdWlsZCwgRGlzY29yZE1lbWJlciB9IGZyb20gJy4vZ3VpbGQuanMnXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRTY2hlZHVsZWRFdmVudCB9IGZyb20gJy4vZ3VpbGRTY2hlZHVsZWRFdmVudC5qcydcbmltcG9ydCB0eXBlIHsgRGlzY29yZFVzZXIgfSBmcm9tICcuL3VzZXIuanMnXG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvaW52aXRlI2ludml0ZS1vYmplY3QtaW52aXRlLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkSW52aXRlIHtcbiAgLyoqIFRoZSB0eXBlIG9mIGludml0ZSAqL1xuICB0eXBlOiBEaXNjb3JkSW52aXRlVHlwZVxuICAvKiogVGhlIGludml0ZSBjb2RlICh1bmlxdWUgSWQpICovXG4gIGNvZGU6IHN0cmluZ1xuICAvKiogVGhlIGd1aWxkIHRoaXMgaW52aXRlIGlzIGZvciAqL1xuICBndWlsZD86IFBhcnRpYWw8RGlzY29yZEd1aWxkPlxuICAvKiogVGhlIGNoYW5uZWwgdGhpcyBpbnZpdGUgaXMgZm9yICovXG4gIGNoYW5uZWw6IFBhcnRpYWw8RGlzY29yZENoYW5uZWw+IHwgbnVsbFxuICAvKiogVGhlIHVzZXIgd2hvIGNyZWF0ZWQgdGhlIGludml0ZSAqL1xuICBpbnZpdGVyPzogRGlzY29yZFVzZXJcbiAgLyoqIFRoZSB0eXBlIG9mIHRhcmdldCBmb3IgdGhpcyB2b2ljZSBjaGFubmVsIGludml0ZSAqL1xuICB0YXJnZXRfdHlwZT86IFRhcmdldFR5cGVzXG4gIC8qKiBUaGUgdGFyZ2V0IHVzZXIgZm9yIHRoaXMgaW52aXRlICovXG4gIHRhcmdldF91c2VyPzogRGlzY29yZFVzZXJcbiAgLyoqIFRoZSBlbWJlZGRlZCBhcHBsaWNhdGlvbiB0byBvcGVuIGZvciB0aGlzIHZvaWNlIGNoYW5uZWwgZW1iZWRkZWQgYXBwbGljYXRpb24gaW52aXRlICovXG4gIHRhcmdldF9hcHBsaWNhdGlvbj86IFBhcnRpYWw8RGlzY29yZEFwcGxpY2F0aW9uPlxuICAvKiogQXBwcm94aW1hdGUgY291bnQgb2Ygb25saW5lIG1lbWJlcnMgKG9ubHkgcHJlc2VudCB3aGVuIHRhcmdldF91c2VyIGlzIHNldCkgKi9cbiAgYXBwcm94aW1hdGVfcHJlc2VuY2VfY291bnQ/OiBudW1iZXJcbiAgLyoqIEFwcHJveGltYXRlIGNvdW50IG9mIHRvdGFsIG1lbWJlcnMgKi9cbiAgYXBwcm94aW1hdGVfbWVtYmVyX2NvdW50PzogbnVtYmVyXG4gIC8qKiBUaGUgZXhwaXJhdGlvbiBkYXRlIG9mIHRoaXMgaW52aXRlLCByZXR1cm5lZCBmcm9tIHRoZSBgR0VUIC9pbnZpdGVzLzxjb2RlPmAgZW5kcG9pbnQgd2hlbiBgd2l0aF9leHBpcmF0aW9uYCBpcyBgdHJ1ZWAgKi9cbiAgZXhwaXJlc19hdD86IHN0cmluZyB8IG51bGxcbiAgLyoqIFN0YWdlIGluc3RhbmNlIGRhdGEgaWYgdGhlcmUgaXMgYSBwdWJsaWMgU3RhZ2UgaW5zdGFuY2UgaW4gdGhlIFN0YWdlIGNoYW5uZWwgdGhpcyBpbnZpdGUgaXMgZm9yICovXG4gIHN0YWdlX2luc3RhbmNlPzogRGlzY29yZEludml0ZVN0YWdlSW5zdGFuY2VcbiAgLyoqIGd1aWxkIHNjaGVkdWxlZCBldmVudCBkYXRhICovXG4gIGd1aWxkX3NjaGVkdWxlZF9ldmVudD86IERpc2NvcmRTY2hlZHVsZWRFdmVudFxuICAvKipcbiAgICogR3VpbGQgaW52aXRlIGZsYWdzIGZvciBndWlsZCBpbnZpdGVzLlxuICAgKlxuICAgKiBAc2VlIHtAbGluayBEaXNjb3JkR3VpbGRJbnZpdGVGbGFnc31cbiAgICovXG4gIGZsYWdzPzogbnVtYmVyXG59XG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvaW52aXRlI2ludml0ZS1vYmplY3QtaW52aXRlLXR5cGVzICovXG5leHBvcnQgZW51bSBEaXNjb3JkSW52aXRlVHlwZSB7XG4gIEd1aWxkLFxuICBHcm91cERtLFxuICBGcmllbmQsXG59XG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvaW52aXRlI2ludml0ZS1vYmplY3QtaW52aXRlLXRhcmdldC10eXBlcyAqL1xuZXhwb3J0IGVudW0gVGFyZ2V0VHlwZXMge1xuICBTdHJlYW0gPSAxLFxuICBFbWJlZGRlZEFwcGxpY2F0aW9uLFxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2ludml0ZSNpbnZpdGUtb2JqZWN0LWd1aWxkLWludml0ZS1mbGFncyAqL1xuZXhwb3J0IGVudW0gRGlzY29yZEd1aWxkSW52aXRlRmxhZ3Mge1xuICAvKiogVGhpcyBpbnZpdGUgaXMgYSBndWVzdCBpbnZpdGUgZm9yIGEgdm9pY2UgY2hhbm5lbCAqL1xuICBpc0d1ZXN0SW52aXRlID0gMSA8PCAwLFxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2ludml0ZSNpbnZpdGUtbWV0YWRhdGEtb2JqZWN0LWludml0ZS1tZXRhZGF0YS1zdHJ1Y3R1cmUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzY29yZEludml0ZU1ldGFkYXRhIGV4dGVuZHMgRGlzY29yZEludml0ZSB7XG4gIC8qKiBOdW1iZXIgb2YgdGltZXMgdGhpcyBpbnZpdGUgaGFzIGJlZW4gdXNlZCAqL1xuICB1c2VzOiBudW1iZXJcbiAgLyoqIE1heCBudW1iZXIgb2YgdGltZXMgdGhpcyBpbnZpdGUgY2FuIGJlIHVzZWQgKi9cbiAgbWF4X3VzZXM6IG51bWJlclxuICAvKiogRHVyYXRpb24gKGluIHNlY29uZHMpIGFmdGVyIHdoaWNoIHRoZSBpbnZpdGUgZXhwaXJlcyAqL1xuICBtYXhfYWdlOiBudW1iZXJcbiAgLyoqIFdoZXRoZXIgdGhpcyBpbnZpdGUgb25seSBncmFudHMgdGVtcG9yYXJ5IG1lbWJlcnNoaXAgKi9cbiAgdGVtcG9yYXJ5OiBib29sZWFuXG4gIC8qKiBXaGVuIHRoaXMgaW52aXRlIHdhcyBjcmVhdGVkICovXG4gIGNyZWF0ZWRfYXQ6IHN0cmluZ1xufVxuXG4vKipcbiAqIGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9pbnZpdGUjaW52aXRlLXN0YWdlLWluc3RhbmNlLW9iamVjdC1pbnZpdGUtc3RhZ2UtaW5zdGFuY2Utc3RydWN0dXJlXG4gKiBAZGVwcmVjYXRlZFxuICovXG5leHBvcnQgaW50ZXJmYWNlIERpc2NvcmRJbnZpdGVTdGFnZUluc3RhbmNlIHtcbiAgLyoqIFRoZSBtZW1iZXJzIHNwZWFraW5nIGluIHRoZSBTdGFnZSAqL1xuICBtZW1iZXJzOiBQYXJ0aWFsPERpc2NvcmRNZW1iZXI+W11cbiAgLyoqIFRoZSBudW1iZXIgb2YgdXNlcnMgaW4gdGhlIFN0YWdlICovXG4gIHBhcnRpY2lwYW50X2NvdW50OiBudW1iZXJcbiAgLyoqIFRoZSBudW1iZXIgb2YgdXNlcnMgc3BlYWtpbmcgaW4gdGhlIFN0YWdlICovXG4gIHNwZWFrZXJfY291bnQ6IG51bWJlclxuICAvKiogVGhlIHRvcGljIG9mIHRoZSBTdGFnZSBpbnN0YW5jZSAoMS0xMjAgY2hhcmFjdGVycykgKi9cbiAgdG9waWM6IHN0cmluZ1xufVxuIl0sIm5hbWVzIjpbIkRpc2NvcmRHdWlsZEludml0ZUZsYWdzIiwiRGlzY29yZEludml0ZVR5cGUiLCJUYXJnZXRUeXBlcyJdLCJtYXBwaW5ncyI6IkFBQUEsb0VBQW9FOzs7Ozs7Ozs7OztRQTBEeERBO2VBQUFBOztRQWJBQztlQUFBQTs7UUFPQUM7ZUFBQUE7OztBQVBMLElBQUEsQUFBS0QsMkNBQUFBOzs7O1dBQUFBOztBQU9MLElBQUEsQUFBS0MscUNBQUFBOzs7V0FBQUE7O0FBTUwsSUFBQSxBQUFLRixpREFBQUE7SUFDVixzREFBc0Q7V0FENUNBIn0=
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2ludml0ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogVHlwZXMgZm9yOiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvaW52aXRlICovXG5cbmltcG9ydCB0eXBlIHsgRGlzY29yZEFwcGxpY2F0aW9uIH0gZnJvbSAnLi9hcHBsaWNhdGlvbi5qcydcbmltcG9ydCB0eXBlIHsgRGlzY29yZENoYW5uZWwgfSBmcm9tICcuL2NoYW5uZWwuanMnXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRHdWlsZCwgRGlzY29yZE1lbWJlciB9IGZyb20gJy4vZ3VpbGQuanMnXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRTY2hlZHVsZWRFdmVudCB9IGZyb20gJy4vZ3VpbGRTY2hlZHVsZWRFdmVudC5qcydcbmltcG9ydCB0eXBlIHsgRGlzY29yZFVzZXIgfSBmcm9tICcuL3VzZXIuanMnXG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvaW52aXRlI2ludml0ZS1vYmplY3QtaW52aXRlLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkSW52aXRlIHtcbiAgLyoqIFRoZSB0eXBlIG9mIGludml0ZSAqL1xuICB0eXBlOiBEaXNjb3JkSW52aXRlVHlwZVxuICAvKiogVGhlIGludml0ZSBjb2RlICh1bmlxdWUgSWQpICovXG4gIGNvZGU6IHN0cmluZ1xuICAvKiogVGhlIGd1aWxkIHRoaXMgaW52aXRlIGlzIGZvciAqL1xuICBndWlsZD86IFBhcnRpYWw8RGlzY29yZEd1aWxkPlxuICAvKiogVGhlIGNoYW5uZWwgdGhpcyBpbnZpdGUgaXMgZm9yICovXG4gIGNoYW5uZWw6IFBhcnRpYWw8RGlzY29yZENoYW5uZWw+IHwgbnVsbFxuICAvKiogVGhlIHVzZXIgd2hvIGNyZWF0ZWQgdGhlIGludml0ZSAqL1xuICBpbnZpdGVyPzogRGlzY29yZFVzZXJcbiAgLyoqIFRoZSB0eXBlIG9mIHRhcmdldCBmb3IgdGhpcyB2b2ljZSBjaGFubmVsIGludml0ZSAqL1xuICB0YXJnZXRfdHlwZT86IFRhcmdldFR5cGVzXG4gIC8qKiBUaGUgdGFyZ2V0IHVzZXIgZm9yIHRoaXMgaW52aXRlICovXG4gIHRhcmdldF91c2VyPzogRGlzY29yZFVzZXJcbiAgLyoqIFRoZSBlbWJlZGRlZCBhcHBsaWNhdGlvbiB0byBvcGVuIGZvciB0aGlzIHZvaWNlIGNoYW5uZWwgZW1iZWRkZWQgYXBwbGljYXRpb24gaW52aXRlICovXG4gIHRhcmdldF9hcHBsaWNhdGlvbj86IFBhcnRpYWw8RGlzY29yZEFwcGxpY2F0aW9uPlxuICAvKiogQXBwcm94aW1hdGUgY291bnQgb2Ygb25saW5lIG1lbWJlcnMgKG9ubHkgcHJlc2VudCB3aGVuIHRhcmdldF91c2VyIGlzIHNldCkgKi9cbiAgYXBwcm94aW1hdGVfcHJlc2VuY2VfY291bnQ/OiBudW1iZXJcbiAgLyoqIEFwcHJveGltYXRlIGNvdW50IG9mIHRvdGFsIG1lbWJlcnMgKi9cbiAgYXBwcm94aW1hdGVfbWVtYmVyX2NvdW50PzogbnVtYmVyXG4gIC8qKiBUaGUgZXhwaXJhdGlvbiBkYXRlIG9mIHRoaXMgaW52aXRlLCByZXR1cm5lZCBmcm9tIHRoZSBgR0VUIC9pbnZpdGVzLzxjb2RlPmAgZW5kcG9pbnQgd2hlbiBgd2l0aF9leHBpcmF0aW9uYCBpcyBgdHJ1ZWAgKi9cbiAgZXhwaXJlc19hdD86IHN0cmluZyB8IG51bGxcbiAgLyoqXG4gICAqIFN0YWdlIGluc3RhbmNlIGRhdGEgaWYgdGhlcmUgaXMgYSBwdWJsaWMgU3RhZ2UgaW5zdGFuY2UgaW4gdGhlIFN0YWdlIGNoYW5uZWwgdGhpcyBpbnZpdGUgaXMgZm9yXG4gICAqXG4gICAqIEBkZXByZWNhdGVkXG4gICAqL1xuICBzdGFnZV9pbnN0YW5jZT86IERpc2NvcmRJbnZpdGVTdGFnZUluc3RhbmNlXG4gIC8qKiBndWlsZCBzY2hlZHVsZWQgZXZlbnQgZGF0YSAqL1xuICBndWlsZF9zY2hlZHVsZWRfZXZlbnQ/OiBEaXNjb3JkU2NoZWR1bGVkRXZlbnRcbiAgLyoqXG4gICAqIEd1aWxkIGludml0ZSBmbGFncyBmb3IgZ3VpbGQgaW52aXRlcy5cbiAgICpcbiAgICogQHNlZSB7QGxpbmsgRGlzY29yZEd1aWxkSW52aXRlRmxhZ3N9XG4gICAqL1xuICBmbGFncz86IG51bWJlclxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2ludml0ZSNpbnZpdGUtb2JqZWN0LWludml0ZS10eXBlcyAqL1xuZXhwb3J0IGVudW0gRGlzY29yZEludml0ZVR5cGUge1xuICBHdWlsZCxcbiAgR3JvdXBEbSxcbiAgRnJpZW5kLFxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2ludml0ZSNpbnZpdGUtb2JqZWN0LWludml0ZS10YXJnZXQtdHlwZXMgKi9cbmV4cG9ydCBlbnVtIFRhcmdldFR5cGVzIHtcbiAgU3RyZWFtID0gMSxcbiAgRW1iZWRkZWRBcHBsaWNhdGlvbixcbn1cblxuLyoqIGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9pbnZpdGUjaW52aXRlLW9iamVjdC1ndWlsZC1pbnZpdGUtZmxhZ3MgKi9cbmV4cG9ydCBlbnVtIERpc2NvcmRHdWlsZEludml0ZUZsYWdzIHtcbiAgLyoqIFRoaXMgaW52aXRlIGlzIGEgZ3Vlc3QgaW52aXRlIGZvciBhIHZvaWNlIGNoYW5uZWwgKi9cbiAgaXNHdWVzdEludml0ZSA9IDEgPDwgMCxcbn1cblxuLyoqIGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9pbnZpdGUjaW52aXRlLW1ldGFkYXRhLW9iamVjdC1pbnZpdGUtbWV0YWRhdGEtc3RydWN0dXJlICovXG5leHBvcnQgaW50ZXJmYWNlIERpc2NvcmRJbnZpdGVNZXRhZGF0YSBleHRlbmRzIERpc2NvcmRJbnZpdGUge1xuICAvKiogTnVtYmVyIG9mIHRpbWVzIHRoaXMgaW52aXRlIGhhcyBiZWVuIHVzZWQgKi9cbiAgdXNlczogbnVtYmVyXG4gIC8qKiBNYXggbnVtYmVyIG9mIHRpbWVzIHRoaXMgaW52aXRlIGNhbiBiZSB1c2VkICovXG4gIG1heF91c2VzOiBudW1iZXJcbiAgLyoqIER1cmF0aW9uIChpbiBzZWNvbmRzKSBhZnRlciB3aGljaCB0aGUgaW52aXRlIGV4cGlyZXMgKi9cbiAgbWF4X2FnZTogbnVtYmVyXG4gIC8qKiBXaGV0aGVyIHRoaXMgaW52aXRlIG9ubHkgZ3JhbnRzIHRlbXBvcmFyeSBtZW1iZXJzaGlwICovXG4gIHRlbXBvcmFyeTogYm9vbGVhblxuICAvKiogV2hlbiB0aGlzIGludml0ZSB3YXMgY3JlYXRlZCAqL1xuICBjcmVhdGVkX2F0OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvaW52aXRlI2ludml0ZS1zdGFnZS1pbnN0YW5jZS1vYmplY3QtaW52aXRlLXN0YWdlLWluc3RhbmNlLXN0cnVjdHVyZVxuICogQGRlcHJlY2F0ZWRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkSW52aXRlU3RhZ2VJbnN0YW5jZSB7XG4gIC8qKiBUaGUgbWVtYmVycyBzcGVha2luZyBpbiB0aGUgU3RhZ2UgKi9cbiAgbWVtYmVyczogUGFydGlhbDxEaXNjb3JkTWVtYmVyPltdXG4gIC8qKiBUaGUgbnVtYmVyIG9mIHVzZXJzIGluIHRoZSBTdGFnZSAqL1xuICBwYXJ0aWNpcGFudF9jb3VudDogbnVtYmVyXG4gIC8qKiBUaGUgbnVtYmVyIG9mIHVzZXJzIHNwZWFraW5nIGluIHRoZSBTdGFnZSAqL1xuICBzcGVha2VyX2NvdW50OiBudW1iZXJcbiAgLyoqIFRoZSB0b3BpYyBvZiB0aGUgU3RhZ2UgaW5zdGFuY2UgKDEtMTIwIGNoYXJhY3RlcnMpICovXG4gIHRvcGljOiBzdHJpbmdcbn1cbiJdLCJuYW1lcyI6WyJEaXNjb3JkR3VpbGRJbnZpdGVGbGFncyIsIkRpc2NvcmRJbnZpdGVUeXBlIiwiVGFyZ2V0VHlwZXMiXSwibWFwcGluZ3MiOiJBQUFBLG9FQUFvRTs7Ozs7Ozs7Ozs7UUE4RHhEQTtlQUFBQTs7UUFiQUM7ZUFBQUE7O1FBT0FDO2VBQUFBOzs7QUFQTCxJQUFBLEFBQUtELDJDQUFBQTs7OztXQUFBQTs7QUFPTCxJQUFBLEFBQUtDLHFDQUFBQTs7O1dBQUFBOztBQU1MLElBQUEsQUFBS0YsaURBQUFBO0lBQ1Ysc0RBQXNEO1dBRDVDQSJ9
@@ -13,4 +13,4 @@ var DiscordLobbyMemberFlags = /*#__PURE__*/ function(DiscordLobbyMemberFlags) {
13
13
  return DiscordLobbyMemberFlags;
14
14
  }({});
15
15
 
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2xvYmJ5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9sb2JieSAqL1xuXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRDaGFubmVsIH0gZnJvbSAnLi9jaGFubmVsLmpzJ1xuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2xvYmJ5I2xvYmJ5LW9iamVjdC1sb2JieS1zdHJ1Y3R1cmUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzY29yZExvYmJ5IHtcbiAgLyoqIFRoZSBpZCBvZiB0aGlzIGNoYW5uZWwgKi9cbiAgaWQ6IHN0cmluZ1xuICAvKiogYXBwbGljYXRpb24gdGhhdCBjcmVhdGVkIHRoZSBsb2JieSAqL1xuICBhcHBsaWNhdGlvbl9pZDogc3RyaW5nXG4gIC8qKiBkaWN0aW9uYXJ5IG9mIHN0cmluZyBrZXkvdmFsdWUgcGFpcnMuIFRoZSBtYXggdG90YWwgbGVuZ3RoIGlzIDEwMDAuICovXG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPlxuICAvKiogbWVtYmVycyBvZiB0aGUgbG9iYnkgKi9cbiAgbWVtYmVyczogRGlzY29yZExvYmJ5TWVtYmVyW11cbiAgLyoqIHRoZSBndWlsZCBjaGFubmVsIGxpbmtlZCB0byB0aGUgbG9iYnkgKi9cbiAgbGlua2VkX2NoYW5uZWw/OiBEaXNjb3JkQ2hhbm5lbFxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2xvYmJ5I2xvYmJ5LW1lbWJlci1vYmplY3QtbG9iYnktbWVtYmVyLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkTG9iYnlNZW1iZXIge1xuICAvKiogVGhlIGlkIG9mIHRoZSB1c2VyICovXG4gIGlkOiBzdHJpbmdcbiAgLyoqIGRpY3Rpb25hcnkgb2Ygc3RyaW5nIGtleS92YWx1ZSBwYWlycy4gVGhlIG1heCB0b3RhbCBsZW5ndGggaXMgMTAwMC4gKi9cbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+XG4gIC8qKiBsb2JieSBtZW1iZXIgZmxhZ3MgY29tYmluZWQgYXMgYXMgYml0ZmllbGQgKi9cbiAgZmxhZ3M/OiBudW1iZXJcbn1cblxuLyoqIGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9sb2JieSNsb2JieS1tZW1iZXItb2JqZWN0LWxvYmJ5LW1lbWJlci1mbGFncyAqL1xuZXhwb3J0IGVudW0gRGlzY29yZExvYmJ5TWVtYmVyRmxhZ3Mge1xuICAvKiogVXNlciBjYW4gbGluayBhIHRleHQgY2hhbm5lbCB0byBhIGxvYmJ5ICovXG4gIENhbkxpbmtMb2JieSA9IDEgPDwgMCxcbn1cbiJdLCJuYW1lcyI6WyJEaXNjb3JkTG9iYnlNZW1iZXJGbGFncyJdLCJtYXBwaW5ncyI6IkFBQUEsbUVBQW1FOzs7OytCQTZCdkRBOzs7ZUFBQUE7OztBQUFMLElBQUEsQUFBS0EsaURBQUFBO0lBQ1YsNENBQTRDO1dBRGxDQSJ9
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2xvYmJ5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9sb2JieSAqL1xuXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRDaGFubmVsIH0gZnJvbSAnLi9jaGFubmVsLmpzJ1xuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2xvYmJ5I2xvYmJ5LW9iamVjdC1sb2JieS1zdHJ1Y3R1cmUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzY29yZExvYmJ5IHtcbiAgLyoqIFRoZSBpZCBvZiB0aGlzIGNoYW5uZWwgKi9cbiAgaWQ6IHN0cmluZ1xuICAvKiogYXBwbGljYXRpb24gdGhhdCBjcmVhdGVkIHRoZSBsb2JieSAqL1xuICBhcHBsaWNhdGlvbl9pZDogc3RyaW5nXG4gIC8qKiBkaWN0aW9uYXJ5IG9mIHN0cmluZyBrZXkvdmFsdWUgcGFpcnMuIFRoZSBtYXggdG90YWwgbGVuZ3RoIGlzIDEwMDAuICovXG4gIG1ldGFkYXRhOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+IHwgbnVsbFxuICAvKiogbWVtYmVycyBvZiB0aGUgbG9iYnkgKi9cbiAgbWVtYmVyczogRGlzY29yZExvYmJ5TWVtYmVyW11cbiAgLyoqIHRoZSBndWlsZCBjaGFubmVsIGxpbmtlZCB0byB0aGUgbG9iYnkgKi9cbiAgbGlua2VkX2NoYW5uZWw/OiBEaXNjb3JkQ2hhbm5lbFxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2xvYmJ5I2xvYmJ5LW1lbWJlci1vYmplY3QtbG9iYnktbWVtYmVyLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkTG9iYnlNZW1iZXIge1xuICAvKiogVGhlIGlkIG9mIHRoZSB1c2VyICovXG4gIGlkOiBzdHJpbmdcbiAgLyoqIGRpY3Rpb25hcnkgb2Ygc3RyaW5nIGtleS92YWx1ZSBwYWlycy4gVGhlIG1heCB0b3RhbCBsZW5ndGggaXMgMTAwMC4gKi9cbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+IHwgbnVsbFxuICAvKiogbG9iYnkgbWVtYmVyIGZsYWdzIGNvbWJpbmVkIGFzIGFzIGJpdGZpZWxkICovXG4gIGZsYWdzPzogbnVtYmVyXG59XG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvbG9iYnkjbG9iYnktbWVtYmVyLW9iamVjdC1sb2JieS1tZW1iZXItZmxhZ3MgKi9cbmV4cG9ydCBlbnVtIERpc2NvcmRMb2JieU1lbWJlckZsYWdzIHtcbiAgLyoqIFVzZXIgY2FuIGxpbmsgYSB0ZXh0IGNoYW5uZWwgdG8gYSBsb2JieSAqL1xuICBDYW5MaW5rTG9iYnkgPSAxIDw8IDAsXG59XG4iXSwibmFtZXMiOlsiRGlzY29yZExvYmJ5TWVtYmVyRmxhZ3MiXSwibWFwcGluZ3MiOiJBQUFBLG1FQUFtRTs7OzsrQkE2QnZEQTs7O2VBQUFBOzs7QUFBTCxJQUFBLEFBQUtBLGlEQUFBQTtJQUNWLDRDQUE0QztXQURsQ0EifQ==
@@ -135,4 +135,4 @@ var DiscordReactionType = /*#__PURE__*/ function(DiscordReactionType) {
135
135
  return DiscordReactionType;
136
136
  }({});
137
137
 
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/discord/message.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/resources/message */\n\nimport type { DiscordApplication } from './application.js'\nimport type { DiscordChannel, DiscordThreadMember } from './channel.js'\nimport type { DiscordMessageComponents } from './components.js'\nimport type { DiscordEmoji } from './emoji.js'\nimport type { DiscordMessageCreateExtra } from './gateway.js'\nimport type { DiscordAuthorizingIntegrationOwners, DiscordMessageInteraction, InteractionTypes } from './interactions.js'\nimport type { DiscordPoll } from './poll.js'\nimport type { DiscordSticker, DiscordStickerItem } from './sticker.js'\nimport type { DiscordUser } from './user.js'\n\n/** https://discord.com/developers/docs/resources/message#message-object-message-structure */\nexport interface DiscordMessage extends Partial<DiscordMessageCreateExtra> {\n  /** id of the message */\n  id: string\n  /** id of the channel the message was sent in */\n  channel_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  /** 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  // TODO: When we separate the types between with extra fields from gateway and non, we should add back the mentions field below\n  //       For now it can remain from the gateway extra fields to avoid breaking changes for now.\n  // /** Users specifically mentioned in the message */\n  // mentions: DiscordUser[]\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/message#message-object-message-types */\nexport enum MessageTypes {\n  Default,\n  RecipientAdd,\n  RecipientRemove,\n  Call,\n  ChannelNameChange,\n  ChannelIconChange,\n  ChannelPinnedMessage,\n  UserJoin,\n  GuildBoost,\n  GuildBoostTier1,\n  GuildBoostTier2,\n  GuildBoostTier3,\n  ChannelFollowAdd,\n  GuildDiscoveryDisqualified = 14,\n  GuildDiscoveryRequalified,\n  GuildDiscoveryGracePeriodInitialWarning,\n  GuildDiscoveryGracePeriodFinalWarning,\n  ThreadCreated,\n  Reply,\n  ChatInputCommand,\n  ThreadStarterMessage,\n  GuildInviteReminder,\n  ContextMenuCommand,\n  AutoModerationAction,\n  RoleSubscriptionPurchase,\n  InteractionPremiumUpsell,\n  StageStart,\n  StageEnd,\n  StageSpeaker,\n  StageTopic = 31,\n  GuildApplicationPremiumSubscription,\n  GuildIncidentAlertModeEnabled = 36,\n  GuildIncidentAlertModeDisabled,\n  GuildIncidentReportRaid,\n  GuildIncidentReportFalseAlarm,\n  PurchaseNotification = 44,\n  PollResult = 46,\n}\n\n/** https://discord.com/developers/docs/resources/message#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/message#message-object-message-activity-types */\nexport enum MessageActivityTypes {\n  Join = 1,\n  Spectate = 2,\n  Listen = 3,\n  JoinRequest = 5,\n}\n\n/** https://discord.com/developers/docs/resources/message#message-object-message-flags */\nexport enum MessageFlags {\n  /** This message has been published to subscribed channels (via Channel Following) */\n  Crossposted = 1 << 0,\n  /** This message originated from a message in another channel (via Channel Following) */\n  IsCrosspost = 1 << 1,\n  /** Do not include any embeds when serializing this message */\n  SuppressEmbeds = 1 << 2,\n  /** The source message for this crosspost has been deleted (via Channel Following) */\n  SourceMessageDeleted = 1 << 3,\n  /** This message came from the urgent message system */\n  Urgent = 1 << 4,\n  /** This message has an associated thread, with the same id as the message */\n  HasThread = 1 << 5,\n  /** This message is only visible to the user who invoked the Interaction */\n  Ephemeral = 1 << 6,\n  /** This message is an Interaction Response and the bot is \"thinking\" */\n  Loading = 1 << 7,\n  /** This message failed to mention some roles and add their members to the thread */\n  FailedToMentionSomeRolesInThread = 1 << 8,\n  /** This message will not trigger push and desktop notifications */\n  SuppressNotifications = 1 << 12,\n  /** This message is a voice message */\n  IsVoiceMessage = 1 << 13,\n  /** This message has a snapshot (via Message Forwarding) */\n  HasSnapshot = 1 << 14,\n  /**\n   * Allows you to create fully component driven messages\n   *\n   * @remarks\n   * Once a message has been sent with this flag, it can't be removed from that message.\n   */\n  IsComponentV2 = 1 << 15,\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: DiscordAuthorizingIntegrationOwners\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: DiscordAuthorizingIntegrationOwners\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: DiscordAuthorizingIntegrationOwners\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\n/** https://discord.com/developers/docs/resources/message#message-call-object-message-call-object-structure */\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/message#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/message#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/message#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/message#reaction-object-reaction-structure */\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/message#reaction-count-details-object-reaction-count-details-structure */\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/message#embed-object-embed-structure */\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/message#embed-object-embed-types */\nexport type EmbedTypes = 'rich' | 'image' | 'video' | 'gifv' | 'article' | 'link' | 'poll_result'\n\n/** https://discord.com/developers/docs/resources/message#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/message#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/message#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\n/** https://discord.com/developers/docs/resources/message#embed-object-embed-provider-structure */\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/message#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/message#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/message#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/message#attachment-object-attachment-structure */\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/message#attachment-object-attachment-flags */\nexport enum AttachmentFlags {\n  None,\n  /** This attachment has been edited using the remix feature on mobile */\n  IsRemix = 1 << 2,\n}\n\n/** https://discord.com/developers/docs/resources/message#channel-mention-object-channel-mention-structure */\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/message#allowed-mentions-object-allowed-mention-types */\nexport enum AllowedMentionsTypes {\n  /** Controls role mentions */\n  RoleMentions = 'roles',\n  /** Controls user mentions */\n  UserMentions = 'users',\n  /** Controls \\@everyone and \\@here mentions */\n  EveryoneMentions = 'everyone',\n}\n\n/** https://discord.com/developers/docs/resources/message#allowed-mentions-object-allowed-mentions-structure */\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// TODO: Implement RoleSubscriptionData https://discord.com/developers/docs/resources/message#role-subscription-data-object-role-subscription-data-object-structure\n\n/** https://discord.com/developers/docs/resources/message#message-pin-object-message-pin-object-struture */\nexport interface DiscordMessagePin {\n  /** the time the message was pinned */\n  pinned_at: string\n  /** the pinned message */\n  message: DiscordMessage\n}\n\n/** https://discord.com/developers/docs/resources/message#create-message-jsonform-params */\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/message#get-reactions-reaction-types */\nexport enum DiscordReactionType {\n  Normal,\n  Burst,\n}\n\n/** https://discord.com/developers/docs/resources/message#get-channel-pins-response-structure */\nexport interface DiscordGetChannelPins {\n  items: DiscordMessagePin\n  has_more: boolean\n}\n"],"names":["AllowedMentionsTypes","AttachmentFlags","DiscordMessageReferenceType","DiscordReactionType","MessageActivityTypes","MessageFlags","MessageTypes"],"mappings":"AAAA,qEAAqE;;;;;;;;;;;QAofzDA;eAAAA;;QAnBAC;eAAAA;;QA/MAC;eAAAA;;QAkSAC;eAAAA;;QA5ZAC;eAAAA;;QAQAC;eAAAA;;QAzDAC;eAAAA;;;AAAL,IAAA,AAAKA,sCAAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAAAA;;AAiDL,IAAA,AAAKF,8CAAAA;;;;;WAAAA;;AAQL,IAAA,AAAKC,sCAAAA;IACV,mFAAmF;IAEnF,sFAAsF;IAEtF,4DAA4D;IAE5D,mFAAmF;IAEnF,qDAAqD;IAErD,2EAA2E;IAE3E,yEAAyE;IAEzE,sEAAsE;IAEtE,kFAAkF;IAElF,iEAAiE;IAEjE,oCAAoC;IAEpC,yDAAyD;IAEzD;;;;;GAKC;WA9BSA;;AAkHL,IAAA,AAAKH,qDAAAA;IACV;;;;;GAKC;IAED;;;;;;;;;GASC;WAjBSA;;AA+ML,IAAA,AAAKD,yCAAAA;;IAEV,sEAAsE;WAF5DA;;AAmBL,IAAA,AAAKD,8CAAAA;IACV,2BAA2B;IAE3B,2BAA2B;IAE3B,4CAA4C;WALlCA;;AAgEL,IAAA,AAAKG,6CAAAA;;;WAAAA"}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/discord/message.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/resources/message */\n\nimport type { DiscordApplication } from './application.js'\nimport type { DiscordChannel, DiscordThreadMember } from './channel.js'\nimport type { DiscordMessageComponents } from './components.js'\nimport type { DiscordEmoji } from './emoji.js'\nimport type { DiscordMessageCreateExtra } from './gateway.js'\nimport type { DiscordAuthorizingIntegrationOwners, DiscordMessageInteraction, InteractionTypes } from './interactions.js'\nimport type { DiscordPoll } from './poll.js'\nimport type { DiscordSticker, DiscordStickerItem } from './sticker.js'\nimport type { DiscordUser } from './user.js'\n\n/** https://discord.com/developers/docs/resources/message#message-object-message-structure */\nexport interface DiscordMessage extends Partial<DiscordMessageCreateExtra> {\n  /** id of the message */\n  id: string\n  /** id of the channel the message was sent in */\n  channel_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  /** 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  // TODO: When we separate the types between with extra fields from gateway and non, we should add back the mentions field below\n  //       For now it can remain from the gateway extra fields to avoid breaking changes for now.\n  // /** Users specifically mentioned in the message */\n  // mentions: DiscordUser[]\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/message#message-object-message-types */\nexport enum MessageTypes {\n  Default,\n  RecipientAdd,\n  RecipientRemove,\n  Call,\n  ChannelNameChange,\n  ChannelIconChange,\n  ChannelPinnedMessage,\n  UserJoin,\n  GuildBoost,\n  GuildBoostTier1,\n  GuildBoostTier2,\n  GuildBoostTier3,\n  ChannelFollowAdd,\n  GuildDiscoveryDisqualified = 14,\n  GuildDiscoveryRequalified,\n  GuildDiscoveryGracePeriodInitialWarning,\n  GuildDiscoveryGracePeriodFinalWarning,\n  ThreadCreated,\n  Reply,\n  ChatInputCommand,\n  ThreadStarterMessage,\n  GuildInviteReminder,\n  ContextMenuCommand,\n  AutoModerationAction,\n  RoleSubscriptionPurchase,\n  InteractionPremiumUpsell,\n  StageStart,\n  StageEnd,\n  StageSpeaker,\n  StageTopic = 31,\n  GuildApplicationPremiumSubscription,\n  GuildIncidentAlertModeEnabled = 36,\n  GuildIncidentAlertModeDisabled,\n  GuildIncidentReportRaid,\n  GuildIncidentReportFalseAlarm,\n  PurchaseNotification = 44,\n  PollResult = 46,\n}\n\n/** https://discord.com/developers/docs/resources/message#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/message#message-object-message-activity-types */\nexport enum MessageActivityTypes {\n  Join = 1,\n  Spectate = 2,\n  Listen = 3,\n  JoinRequest = 5,\n}\n\n/** https://discord.com/developers/docs/resources/message#message-object-message-flags */\nexport enum MessageFlags {\n  /** This message has been published to subscribed channels (via Channel Following) */\n  Crossposted = 1 << 0,\n  /** This message originated from a message in another channel (via Channel Following) */\n  IsCrosspost = 1 << 1,\n  /** Do not include any embeds when serializing this message */\n  SuppressEmbeds = 1 << 2,\n  /** The source message for this crosspost has been deleted (via Channel Following) */\n  SourceMessageDeleted = 1 << 3,\n  /** This message came from the urgent message system */\n  Urgent = 1 << 4,\n  /** This message has an associated thread, with the same id as the message */\n  HasThread = 1 << 5,\n  /** This message is only visible to the user who invoked the Interaction */\n  Ephemeral = 1 << 6,\n  /** This message is an Interaction Response and the bot is \"thinking\" */\n  Loading = 1 << 7,\n  /** This message failed to mention some roles and add their members to the thread */\n  FailedToMentionSomeRolesInThread = 1 << 8,\n  /** This message will not trigger push and desktop notifications */\n  SuppressNotifications = 1 << 12,\n  /** This message is a voice message */\n  IsVoiceMessage = 1 << 13,\n  /** This message has a snapshot (via Message Forwarding) */\n  HasSnapshot = 1 << 14,\n  /**\n   * Allows you to create fully component driven messages\n   *\n   * @remarks\n   * Once a message has been sent with this flag, it can't be removed from that message.\n   */\n  IsComponentV2 = 1 << 15,\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: DiscordAuthorizingIntegrationOwners\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: DiscordAuthorizingIntegrationOwners\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: DiscordAuthorizingIntegrationOwners\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\n/** https://discord.com/developers/docs/resources/message#message-call-object-message-call-object-structure */\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/message#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/message#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/message#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/message#reaction-object-reaction-structure */\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/message#reaction-count-details-object-reaction-count-details-structure */\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/message#embed-object-embed-structure */\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/message#embed-object-embed-types */\nexport type EmbedTypes = 'rich' | 'image' | 'video' | 'gifv' | 'article' | 'link' | 'poll_result'\n\n/** https://discord.com/developers/docs/resources/message#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/message#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/message#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\n/** https://discord.com/developers/docs/resources/message#embed-object-embed-provider-structure */\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/message#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/message#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/message#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/message#attachment-object-attachment-structure */\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/message#attachment-object-attachment-flags */\nexport enum AttachmentFlags {\n  None,\n  /** This attachment has been edited using the remix feature on mobile */\n  IsRemix = 1 << 2,\n}\n\n/** https://discord.com/developers/docs/resources/message#channel-mention-object-channel-mention-structure */\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/message#allowed-mentions-object-allowed-mention-types */\nexport enum AllowedMentionsTypes {\n  /** Controls role mentions */\n  RoleMentions = 'roles',\n  /** Controls user mentions */\n  UserMentions = 'users',\n  /** Controls \\@everyone and \\@here mentions */\n  EveryoneMentions = 'everyone',\n}\n\n/** https://discord.com/developers/docs/resources/message#allowed-mentions-object-allowed-mentions-structure */\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// TODO: Implement RoleSubscriptionData https://discord.com/developers/docs/resources/message#role-subscription-data-object-role-subscription-data-object-structure\n\n/** https://discord.com/developers/docs/resources/message#message-pin-object-message-pin-object-struture */\nexport interface DiscordMessagePin {\n  /** the time the message was pinned */\n  pinned_at: string\n  /** the pinned message */\n  message: DiscordMessage\n}\n\n/** https://discord.com/developers/docs/resources/message#create-message-jsonform-params */\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/message#get-reactions-reaction-types */\nexport enum DiscordReactionType {\n  Normal,\n  Burst,\n}\n\n/** https://discord.com/developers/docs/resources/message#get-channel-pins-response-structure */\nexport interface DiscordGetChannelPins {\n  items: DiscordMessagePin[]\n  has_more: boolean\n}\n"],"names":["AllowedMentionsTypes","AttachmentFlags","DiscordMessageReferenceType","DiscordReactionType","MessageActivityTypes","MessageFlags","MessageTypes"],"mappings":"AAAA,qEAAqE;;;;;;;;;;;QAofzDA;eAAAA;;QAnBAC;eAAAA;;QA/MAC;eAAAA;;QAkSAC;eAAAA;;QA5ZAC;eAAAA;;QAQAC;eAAAA;;QAzDAC;eAAAA;;;AAAL,IAAA,AAAKA,sCAAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAAAA;;AAiDL,IAAA,AAAKF,8CAAAA;;;;;WAAAA;;AAQL,IAAA,AAAKC,sCAAAA;IACV,mFAAmF;IAEnF,sFAAsF;IAEtF,4DAA4D;IAE5D,mFAAmF;IAEnF,qDAAqD;IAErD,2EAA2E;IAE3E,yEAAyE;IAEzE,sEAAsE;IAEtE,kFAAkF;IAElF,iEAAiE;IAEjE,oCAAoC;IAEpC,yDAAyD;IAEzD;;;;;GAKC;WA9BSA;;AAkHL,IAAA,AAAKH,qDAAAA;IACV;;;;;GAKC;IAED;;;;;;;;;GASC;WAjBSA;;AA+ML,IAAA,AAAKD,yCAAAA;;IAEV,sEAAsE;WAF5DA;;AAmBL,IAAA,AAAKD,8CAAAA;IACV,2BAA2B;IAE3B,2BAA2B;IAE3B,4CAA4C;WALlCA;;AAgEL,IAAA,AAAKG,6CAAAA;;;WAAAA"}
@@ -3,4 +3,4 @@ Object.defineProperty(exports, "__esModule", {
3
3
  value: true
4
4
  });
5
5
 
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL3ZvaWNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy92b2ljZSAqL1xuXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRNZW1iZXJXaXRoVXNlciB9IGZyb20gJy4vZ3VpbGQuanMnXG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvdm9pY2Ujdm9pY2Utc3RhdGUtb2JqZWN0LXZvaWNlLXN0YXRlLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkVm9pY2VTdGF0ZSB7XG4gIC8qKiBUaGUgc2Vzc2lvbiBpZCBmb3IgdGhpcyB2b2ljZSBzdGF0ZSAqL1xuICBzZXNzaW9uX2lkOiBzdHJpbmdcbiAgLyoqIFRoZSBndWlsZCBpZCB0aGlzIHZvaWNlIHN0YXRlIGlzIGZvciAqL1xuICBndWlsZF9pZD86IHN0cmluZ1xuICAvKiogVGhlIGNoYW5uZWwgaWQgdGhpcyB1c2VyIGlzIGNvbm5lY3RlZCB0byAqL1xuICBjaGFubmVsX2lkOiBzdHJpbmcgfCBudWxsXG4gIC8qKiBUaGUgdXNlciBpZCB0aGlzIHZvaWNlIHN0YXRlIGlzIGZvciAqL1xuICB1c2VyX2lkOiBzdHJpbmdcbiAgLyoqIFRoZSBndWlsZCBtZW1iZXIgdGhpcyB2b2ljZSBzdGF0ZSBpcyBmb3IgKi9cbiAgbWVtYmVyPzogRGlzY29yZE1lbWJlcldpdGhVc2VyXG4gIC8qKiBXaGV0aGVyIHRoaXMgdXNlciBpcyBkZWFmZW5lZCBieSB0aGUgc2VydmVyICovXG4gIGRlYWY6IGJvb2xlYW5cbiAgLyoqIFdoZXRoZXIgdGhpcyB1c2VyIGlzIG11dGVkIGJ5IHRoZSBzZXJ2ZXIgKi9cbiAgbXV0ZTogYm9vbGVhblxuICAvKiogV2hldGhlciB0aGlzIHVzZXIgaXMgbG9jYWxseSBkZWFmZW5lZCAqL1xuICBzZWxmX2RlYWY6IGJvb2xlYW5cbiAgLyoqIFdoZXRoZXIgdGhpcyB1c2VyIGlzIGxvY2FsbHkgbXV0ZWQgKi9cbiAgc2VsZl9tdXRlOiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgdXNlciBpcyBzdHJlYW1pbmcgdXNpbmcgXCJHbyBMaXZlXCIgKi9cbiAgc2VsZl9zdHJlYW0/OiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgdXNlcidzIGNhbWVyYSBpcyBlbmFibGVkICovXG4gIHNlbGZfdmlkZW86IGJvb2xlYW5cbiAgLyoqIFdoZXRoZXIgdGhpcyB1c2VyIGlzIG11dGVkIGJ5IHRoZSBjdXJyZW50IHVzZXIgKi9cbiAgc3VwcHJlc3M6IGJvb2xlYW5cbiAgLyoqIFRoZSB0aW1lIGF0IHdoaWNoIHRoZSB1c2VyIHJlcXVlc3RlZCB0byBzcGVhayAqL1xuICByZXF1ZXN0X3RvX3NwZWFrX3RpbWVzdGFtcDogc3RyaW5nIHwgbnVsbFxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL3ZvaWNlI3ZvaWNlLXJlZ2lvbi1vYmplY3Qtdm9pY2UtcmVnaW9uLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkVm9pY2VSZWdpb24ge1xuICAvKiogVW5pcXVlIElkIGZvciB0aGUgcmVnaW9uICovXG4gIGlkOiBzdHJpbmdcbiAgLyoqIE5hbWUgb2YgdGhlIHJlZ2lvbiAqL1xuICBuYW1lOiBzdHJpbmdcbiAgLyoqIHRydWUgZm9yIGEgc2luZ2xlIHNlcnZlciB0aGF0IGlzIGNsb3Nlc3QgdG8gdGhlIGN1cnJlbnQgdXNlcidzIGNsaWVudCAqL1xuICBvcHRpbWFsOiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgaXMgYSBkZXByZWNhdGVkIHZvaWNlIHJlZ2lvbiAoYXZvaWQgc3dpdGNoaW5nIHRvIHRoZXNlKSAqL1xuICBkZXByZWNhdGVkOiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgaXMgYSBjdXN0b20gdm9pY2UgcmVnaW9uICh1c2VkIGZvciBldmVudHMvZXRjKSAqL1xuICBjdXN0b206IGJvb2xlYW5cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxtRUFBbUUifQ==
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL3ZvaWNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy92b2ljZSAqL1xuXG5pbXBvcnQgdHlwZSB7IERpc2NvcmRNZW1iZXJXaXRoVXNlciB9IGZyb20gJy4vZ3VpbGQuanMnXG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvdm9pY2Ujdm9pY2Utc3RhdGUtb2JqZWN0LXZvaWNlLXN0YXRlLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkVm9pY2VTdGF0ZSB7XG4gIC8qKiBUaGUgZ3VpbGQgaWQgdGhpcyB2b2ljZSBzdGF0ZSBpcyBmb3IgKi9cbiAgZ3VpbGRfaWQ/OiBzdHJpbmdcbiAgLyoqIFRoZSBjaGFubmVsIGlkIHRoaXMgdXNlciBpcyBjb25uZWN0ZWQgdG8gKi9cbiAgY2hhbm5lbF9pZDogc3RyaW5nIHwgbnVsbFxuICAvKiogVGhlIHVzZXIgaWQgdGhpcyB2b2ljZSBzdGF0ZSBpcyBmb3IgKi9cbiAgdXNlcl9pZDogc3RyaW5nXG4gIC8qKiBUaGUgZ3VpbGQgbWVtYmVyIHRoaXMgdm9pY2Ugc3RhdGUgaXMgZm9yICovXG4gIG1lbWJlcj86IERpc2NvcmRNZW1iZXJXaXRoVXNlclxuICAvKiogVGhlIHNlc3Npb24gaWQgZm9yIHRoaXMgdm9pY2Ugc3RhdGUgKi9cbiAgc2Vzc2lvbl9pZDogc3RyaW5nXG4gIC8qKiBXaGV0aGVyIHRoaXMgdXNlciBpcyBkZWFmZW5lZCBieSB0aGUgc2VydmVyICovXG4gIGRlYWY6IGJvb2xlYW5cbiAgLyoqIFdoZXRoZXIgdGhpcyB1c2VyIGlzIG11dGVkIGJ5IHRoZSBzZXJ2ZXIgKi9cbiAgbXV0ZTogYm9vbGVhblxuICAvKiogV2hldGhlciB0aGlzIHVzZXIgaXMgbG9jYWxseSBkZWFmZW5lZCAqL1xuICBzZWxmX2RlYWY6IGJvb2xlYW5cbiAgLyoqIFdoZXRoZXIgdGhpcyB1c2VyIGlzIGxvY2FsbHkgbXV0ZWQgKi9cbiAgc2VsZl9tdXRlOiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgdXNlciBpcyBzdHJlYW1pbmcgdXNpbmcgXCJHbyBMaXZlXCIgKi9cbiAgc2VsZl9zdHJlYW0/OiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgdXNlcidzIGNhbWVyYSBpcyBlbmFibGVkICovXG4gIHNlbGZfdmlkZW86IGJvb2xlYW5cbiAgLyoqIFdoZXRoZXIgdGhpcyB1c2VyIGlzIG11dGVkIGJ5IHRoZSBjdXJyZW50IHVzZXIgKi9cbiAgc3VwcHJlc3M6IGJvb2xlYW5cbiAgLyoqIFRoZSB0aW1lIGF0IHdoaWNoIHRoZSB1c2VyIHJlcXVlc3RlZCB0byBzcGVhayAqL1xuICByZXF1ZXN0X3RvX3NwZWFrX3RpbWVzdGFtcDogc3RyaW5nIHwgbnVsbFxufVxuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL3ZvaWNlI3ZvaWNlLXJlZ2lvbi1vYmplY3Qtdm9pY2UtcmVnaW9uLXN0cnVjdHVyZSAqL1xuZXhwb3J0IGludGVyZmFjZSBEaXNjb3JkVm9pY2VSZWdpb24ge1xuICAvKiogVW5pcXVlIElkIGZvciB0aGUgcmVnaW9uICovXG4gIGlkOiBzdHJpbmdcbiAgLyoqIE5hbWUgb2YgdGhlIHJlZ2lvbiAqL1xuICBuYW1lOiBzdHJpbmdcbiAgLyoqIHRydWUgZm9yIGEgc2luZ2xlIHNlcnZlciB0aGF0IGlzIGNsb3Nlc3QgdG8gdGhlIGN1cnJlbnQgdXNlcidzIGNsaWVudCAqL1xuICBvcHRpbWFsOiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgaXMgYSBkZXByZWNhdGVkIHZvaWNlIHJlZ2lvbiAoYXZvaWQgc3dpdGNoaW5nIHRvIHRoZXNlKSAqL1xuICBkZXByZWNhdGVkOiBib29sZWFuXG4gIC8qKiBXaGV0aGVyIHRoaXMgaXMgYSBjdXN0b20gdm9pY2UgcmVnaW9uICh1c2VkIGZvciBldmVudHMvZXRjKSAqL1xuICBjdXN0b206IGJvb2xlYW5cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxtRUFBbUUifQ==
@@ -10,4 +10,4 @@
10
10
  return DiscordEntitlementType;
11
11
  }({});
12
12
 
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2VudGl0bGVtZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9lbnRpdGxlbWVudCAqL1xuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2VudGl0bGVtZW50I2VudGl0bGVtZW50LW9iamVjdC1lbnRpdGxlbWVudC1zdHJ1Y3R1cmUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzY29yZEVudGl0bGVtZW50IHtcbiAgLyoqIElEIG9mIHRoZSBlbnRpdGxlbWVudCAqL1xuICBpZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgU0tVICovXG4gIHNrdV9pZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgdXNlciB0aGF0IGlzIGdyYW50ZWQgYWNjZXNzIHRvIHRoZSBlbnRpdGxlbWVudCdzIHNrdSAqL1xuICB1c2VyX2lkPzogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgZ3VpbGQgdGhhdCBpcyBncmFudGVkIGFjY2VzcyB0byB0aGUgZW50aXRsZW1lbnQncyBza3UgKi9cbiAgZ3VpbGRfaWQ/OiBzdHJpbmdcbiAgLyoqIElEIG9mIHRoZSBwYXJlbnQgYXBwbGljYXRpb24gKi9cbiAgYXBwbGljYXRpb25faWQ6IHN0cmluZ1xuICAvKiogVHlwZSBvZiBlbnRpdGxlbWVudCAqL1xuICB0eXBlOiBEaXNjb3JkRW50aXRsZW1lbnRUeXBlXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZGVsZXRlZCAqL1xuICBkZWxldGVkOiBib29sZWFuXG4gIC8qKiBTdGFydCBkYXRlIGF0IHdoaWNoIHRoZSBlbnRpdGxlbWVudCBpcyB2YWxpZC4gKi9cbiAgc3RhcnRzX2F0OiBzdHJpbmcgfCBudWxsXG4gIC8qKiBEYXRlIGF0IHdoaWNoIHRoZSBlbnRpdGxlbWVudCBpcyBubyBsb25nZXIgdmFsaWQuICovXG4gIGVuZHNfYXQ6IHN0cmluZyB8IG51bGxcbiAgLyoqIEZvciBjb25zdW1hYmxlIGl0ZW1zLCB3aGV0aGVyIG9yIG5vdCB0aGUgZW50aXRsZW1lbnQgaGFzIGJlZW4gY29uc3VtZWQgKi9cbiAgY29uc3VtZWQ/OiBib29sZWFuXG59XG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvZW50aXRsZW1lbnQjZW50aXRsZW1lbnQtb2JqZWN0LWVudGl0bGVtZW50LXR5cGVzICovXG5leHBvcnQgZW51bSBEaXNjb3JkRW50aXRsZW1lbnRUeXBlIHtcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgdXNlciAqL1xuICBQdXJjaGFzZSA9IDEsXG4gIC8qKiBFbnRpdGxlbWVudCBmb3IgRGlzY29yZCBOaXRybyBzdWJzY3JpcHRpb24gKi9cbiAgUHJlbWl1bVN1YnNjcmlwdGlvbiA9IDIsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGRldmVsb3BlciAqL1xuICBEZXZlbG9wZXJHaWZ0ID0gMyxcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgYSBkZXYgaW4gYXBwbGljYXRpb24gdGVzdCBtb2RlICovXG4gIFRlc3RNb2RlUHVyY2hhc2UgPSA0LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIGdyYW50ZWQgd2hlbiB0aGUgU0tVIHdhcyBmcmVlICovXG4gIEZyZWVQdXJjaGFzZSA9IDUsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGFub3RoZXIgdXNlciAqL1xuICBVc2VyR2lmdCA9IDYsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgY2xhaW1lZCBieSB1c2VyIGZvciBmcmVlIGFzIGEgTml0cm8gU3Vic2NyaWJlciAqL1xuICBQcmVtaXVtUHVyY2hhc2UgPSA3LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIHB1cmNoYXNlZCBhcyBhbiBhcHAgc3Vic2NyaXB0aW9uICovXG4gIEFwcGxpY2F0aW9uU3Vic2NyaXB0aW9uID0gOCxcbn1cbiJdLCJuYW1lcyI6WyJEaXNjb3JkRW50aXRsZW1lbnRUeXBlIl0sIm1hcHBpbmdzIjoiQUFBQSx5RUFBeUUsR0FFekUsdUdBQXVHLEdBd0J2RyxtR0FBbUcsR0FDbkcsT0FBTyxJQUFBLEFBQUtBLGdEQUFBQTtJQUNWLHNDQUFzQztJQUV0QywrQ0FBK0M7SUFFL0Msd0NBQXdDO0lBRXhDLGdFQUFnRTtJQUVoRSxrREFBa0Q7SUFFbEQsMkNBQTJDO0lBRTNDLG1FQUFtRTtJQUVuRSxxREFBcUQ7V0FmM0NBO01BaUJYIn0=
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXNjb3JkL2VudGl0bGVtZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBUeXBlcyBmb3I6IGh0dHBzOi8vZGlzY29yZC5jb20vZGV2ZWxvcGVycy9kb2NzL3Jlc291cmNlcy9lbnRpdGxlbWVudCAqL1xuXG4vKiogaHR0cHM6Ly9kaXNjb3JkLmNvbS9kZXZlbG9wZXJzL2RvY3MvcmVzb3VyY2VzL2VudGl0bGVtZW50I2VudGl0bGVtZW50LW9iamVjdC1lbnRpdGxlbWVudC1zdHJ1Y3R1cmUgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzY29yZEVudGl0bGVtZW50IHtcbiAgLyoqIElEIG9mIHRoZSBlbnRpdGxlbWVudCAqL1xuICBpZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgU0tVICovXG4gIHNrdV9pZDogc3RyaW5nXG4gIC8qKiBJRCBvZiB0aGUgcGFyZW50IGFwcGxpY2F0aW9uICovXG4gIGFwcGxpY2F0aW9uX2lkOiBzdHJpbmdcbiAgLyoqIElEIG9mIHRoZSB1c2VyIHRoYXQgaXMgZ3JhbnRlZCBhY2Nlc3MgdG8gdGhlIGVudGl0bGVtZW50J3Mgc2t1ICovXG4gIHVzZXJfaWQ/OiBzdHJpbmdcbiAgLyoqIFR5cGUgb2YgZW50aXRsZW1lbnQgKi9cbiAgdHlwZTogRGlzY29yZEVudGl0bGVtZW50VHlwZVxuICAvKiogRW50aXRsZW1lbnQgd2FzIGRlbGV0ZWQgKi9cbiAgZGVsZXRlZDogYm9vbGVhblxuICAvKiogU3RhcnQgZGF0ZSBhdCB3aGljaCB0aGUgZW50aXRsZW1lbnQgaXMgdmFsaWQuICovXG4gIHN0YXJ0c19hdDogc3RyaW5nIHwgbnVsbFxuICAvKiogRGF0ZSBhdCB3aGljaCB0aGUgZW50aXRsZW1lbnQgaXMgbm8gbG9uZ2VyIHZhbGlkLiAqL1xuICBlbmRzX2F0OiBzdHJpbmcgfCBudWxsXG4gIC8qKiBJRCBvZiB0aGUgZ3VpbGQgdGhhdCBpcyBncmFudGVkIGFjY2VzcyB0byB0aGUgZW50aXRsZW1lbnQncyBza3UgKi9cbiAgZ3VpbGRfaWQ/OiBzdHJpbmdcbiAgLyoqIEZvciBjb25zdW1hYmxlIGl0ZW1zLCB3aGV0aGVyIG9yIG5vdCB0aGUgZW50aXRsZW1lbnQgaGFzIGJlZW4gY29uc3VtZWQgKi9cbiAgY29uc3VtZWQ/OiBib29sZWFuXG59XG5cbi8qKiBodHRwczovL2Rpc2NvcmQuY29tL2RldmVsb3BlcnMvZG9jcy9yZXNvdXJjZXMvZW50aXRsZW1lbnQjZW50aXRsZW1lbnQtb2JqZWN0LWVudGl0bGVtZW50LXR5cGVzICovXG5leHBvcnQgZW51bSBEaXNjb3JkRW50aXRsZW1lbnRUeXBlIHtcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgdXNlciAqL1xuICBQdXJjaGFzZSA9IDEsXG4gIC8qKiBFbnRpdGxlbWVudCBmb3IgRGlzY29yZCBOaXRybyBzdWJzY3JpcHRpb24gKi9cbiAgUHJlbWl1bVN1YnNjcmlwdGlvbiA9IDIsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGRldmVsb3BlciAqL1xuICBEZXZlbG9wZXJHaWZ0ID0gMyxcbiAgLyoqIEVudGl0bGVtZW50IHdhcyBwdXJjaGFzZWQgYnkgYSBkZXYgaW4gYXBwbGljYXRpb24gdGVzdCBtb2RlICovXG4gIFRlc3RNb2RlUHVyY2hhc2UgPSA0LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIGdyYW50ZWQgd2hlbiB0aGUgU0tVIHdhcyBmcmVlICovXG4gIEZyZWVQdXJjaGFzZSA9IDUsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgZ2lmdGVkIGJ5IGFub3RoZXIgdXNlciAqL1xuICBVc2VyR2lmdCA9IDYsXG4gIC8qKiBFbnRpdGxlbWVudCB3YXMgY2xhaW1lZCBieSB1c2VyIGZvciBmcmVlIGFzIGEgTml0cm8gU3Vic2NyaWJlciAqL1xuICBQcmVtaXVtUHVyY2hhc2UgPSA3LFxuICAvKiogRW50aXRsZW1lbnQgd2FzIHB1cmNoYXNlZCBhcyBhbiBhcHAgc3Vic2NyaXB0aW9uICovXG4gIEFwcGxpY2F0aW9uU3Vic2NyaXB0aW9uID0gOCxcbn1cbiJdLCJuYW1lcyI6WyJEaXNjb3JkRW50aXRsZW1lbnRUeXBlIl0sIm1hcHBpbmdzIjoiQUFBQSx5RUFBeUUsR0FFekUsdUdBQXVHLEdBd0J2RyxtR0FBbUcsR0FDbkcsT0FBTyxJQUFBLEFBQUtBLGdEQUFBQTtJQUNWLHNDQUFzQztJQUV0QywrQ0FBK0M7SUFFL0Msd0NBQXdDO0lBRXhDLGdFQUFnRTtJQUVoRSxrREFBa0Q7SUFFbEQsMkNBQTJDO0lBRTNDLG1FQUFtRTtJQUVuRSxxREFBcUQ7V0FmM0NBO01BaUJYIn0=