djs-selfbot-v13 3.2.2 → 3.7.1

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.
Files changed (363) hide show
  1. package/README.md +37 -36
  2. package/package.json +89 -85
  3. package/src/WebSocket.js +39 -39
  4. package/src/client/BaseClient.js +86 -86
  5. package/src/client/Client.js +934 -836
  6. package/src/client/WebhookClient.js +61 -61
  7. package/src/client/actions/Action.js +116 -120
  8. package/src/client/actions/ActionsManager.js +80 -78
  9. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
  10. package/src/client/actions/AutoModerationActionExecution.js +27 -27
  11. package/src/client/actions/AutoModerationRuleCreate.js +28 -28
  12. package/src/client/actions/AutoModerationRuleDelete.js +32 -32
  13. package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
  14. package/src/client/actions/ChannelCreate.js +23 -23
  15. package/src/client/actions/ChannelDelete.js +39 -39
  16. package/src/client/actions/ChannelUpdate.js +43 -43
  17. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
  18. package/src/client/actions/GuildBanAdd.js +20 -20
  19. package/src/client/actions/GuildBanRemove.js +25 -25
  20. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
  21. package/src/client/actions/GuildDelete.js +65 -65
  22. package/src/client/actions/GuildEmojiCreate.js +20 -20
  23. package/src/client/actions/GuildEmojiDelete.js +21 -21
  24. package/src/client/actions/GuildEmojiUpdate.js +20 -20
  25. package/src/client/actions/GuildEmojisUpdate.js +34 -34
  26. package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
  27. package/src/client/actions/GuildMemberRemove.js +33 -32
  28. package/src/client/actions/GuildMemberUpdate.js +44 -43
  29. package/src/client/actions/GuildRoleCreate.js +25 -25
  30. package/src/client/actions/GuildRoleDelete.js +31 -31
  31. package/src/client/actions/GuildRoleUpdate.js +39 -39
  32. package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
  33. package/src/client/actions/GuildScheduledEventCreate.js +27 -27
  34. package/src/client/actions/GuildScheduledEventDelete.js +31 -31
  35. package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
  36. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
  37. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
  38. package/src/client/actions/GuildStickerCreate.js +20 -20
  39. package/src/client/actions/GuildStickerDelete.js +21 -21
  40. package/src/client/actions/GuildStickerUpdate.js +20 -20
  41. package/src/client/actions/GuildStickersUpdate.js +34 -34
  42. package/src/client/actions/GuildUpdate.js +33 -33
  43. package/src/client/actions/InviteCreate.js +28 -28
  44. package/src/client/actions/InviteDelete.js +30 -30
  45. package/src/client/actions/MessageCreate.js +50 -46
  46. package/src/client/actions/MessageDelete.js +32 -32
  47. package/src/client/actions/MessageDeleteBulk.js +46 -46
  48. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  49. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  50. package/src/client/actions/MessageReactionAdd.js +68 -56
  51. package/src/client/actions/MessageReactionRemove.js +50 -45
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -33
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
  54. package/src/client/actions/MessageUpdate.js +26 -26
  55. package/src/client/actions/PresenceUpdate.js +50 -46
  56. package/src/client/actions/StageInstanceCreate.js +28 -28
  57. package/src/client/actions/StageInstanceDelete.js +33 -33
  58. package/src/client/actions/StageInstanceUpdate.js +30 -30
  59. package/src/client/actions/ThreadCreate.js +24 -24
  60. package/src/client/actions/ThreadDelete.js +32 -32
  61. package/src/client/actions/ThreadListSync.js +59 -59
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -30
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -34
  64. package/src/client/actions/TypingStart.js +29 -29
  65. package/src/client/actions/UserUpdate.js +35 -35
  66. package/src/client/actions/VoiceStateUpdate.js +50 -57
  67. package/src/client/actions/WebhooksUpdate.js +20 -20
  68. package/src/client/voice/ClientVoiceManager.js +151 -51
  69. package/src/client/voice/VoiceConnection.js +1249 -0
  70. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  71. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  72. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  73. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  74. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  75. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  76. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  77. package/src/client/voice/player/MediaPlayer.js +321 -0
  78. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  79. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  80. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  81. package/src/client/voice/receiver/PacketHandler.js +260 -0
  82. package/src/client/voice/receiver/Receiver.js +96 -0
  83. package/src/client/voice/receiver/Recorder.js +173 -0
  84. package/src/client/voice/util/Function.js +116 -0
  85. package/src/client/voice/util/PlayInterface.js +122 -0
  86. package/src/client/voice/util/Secretbox.js +64 -0
  87. package/src/client/voice/util/Silence.js +16 -0
  88. package/src/client/voice/util/Socket.js +62 -0
  89. package/src/client/voice/util/VolumeInterface.js +104 -0
  90. package/src/client/websocket/WebSocketManager.js +392 -392
  91. package/src/client/websocket/WebSocketShard.js +907 -906
  92. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
  96. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
  97. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
  100. package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
  101. package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
  102. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
  103. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
  104. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
  105. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
  106. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
  108. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
  109. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
  110. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
  111. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
  112. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -52
  113. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
  114. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
  115. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
  116. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
  117. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -19
  118. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
  119. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
  120. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
  121. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
  122. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
  123. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
  128. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
  129. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
  130. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
  131. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
  132. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
  133. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
  134. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
  135. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
  136. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -22
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -12
  138. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
  142. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
  143. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
  144. package/src/client/websocket/handlers/READY.js +121 -120
  145. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
  146. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
  147. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
  148. package/src/client/websocket/handlers/RESUMED.js +14 -14
  149. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
  152. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
  153. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
  154. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
  155. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
  156. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
  157. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
  158. package/src/client/websocket/handlers/TYPING_START.js +5 -5
  159. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
  160. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
  161. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
  162. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
  163. package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
  164. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
  166. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
  167. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
  168. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
  169. package/src/client/websocket/handlers/index.js +84 -83
  170. package/src/errors/DJSError.js +61 -61
  171. package/src/errors/Messages.js +217 -183
  172. package/src/errors/index.js +4 -4
  173. package/src/index.js +172 -159
  174. package/src/managers/ApplicationCommandManager.js +264 -264
  175. package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
  176. package/src/managers/AutoModerationRuleManager.js +296 -296
  177. package/src/managers/BaseGuildEmojiManager.js +80 -80
  178. package/src/managers/BaseManager.js +19 -19
  179. package/src/managers/BillingManager.js +66 -66
  180. package/src/managers/CachedManager.js +71 -71
  181. package/src/managers/ChannelManager.js +148 -138
  182. package/src/managers/ClientUserSettingManager.js +372 -372
  183. package/src/managers/DataManager.js +61 -61
  184. package/src/managers/GuildBanManager.js +250 -250
  185. package/src/managers/GuildChannelManager.js +488 -488
  186. package/src/managers/GuildEmojiManager.js +171 -171
  187. package/src/managers/GuildEmojiRoleManager.js +118 -118
  188. package/src/managers/GuildForumThreadManager.js +108 -108
  189. package/src/managers/GuildInviteManager.js +213 -213
  190. package/src/managers/GuildManager.js +338 -304
  191. package/src/managers/GuildMemberManager.js +599 -597
  192. package/src/managers/GuildMemberRoleManager.js +195 -191
  193. package/src/managers/GuildScheduledEventManager.js +314 -296
  194. package/src/managers/GuildSettingManager.js +155 -155
  195. package/src/managers/GuildStickerManager.js +179 -179
  196. package/src/managers/GuildTextThreadManager.js +98 -98
  197. package/src/managers/InteractionManager.js +39 -39
  198. package/src/managers/MessageManager.js +423 -391
  199. package/src/managers/PermissionOverwriteManager.js +164 -166
  200. package/src/managers/PresenceManager.js +71 -58
  201. package/src/managers/ReactionManager.js +67 -67
  202. package/src/managers/ReactionUserManager.js +73 -71
  203. package/src/managers/RelationshipManager.js +278 -265
  204. package/src/managers/RoleManager.js +448 -352
  205. package/src/managers/SessionManager.js +66 -0
  206. package/src/managers/StageInstanceManager.js +162 -162
  207. package/src/managers/ThreadManager.js +175 -174
  208. package/src/managers/ThreadMemberManager.js +186 -186
  209. package/src/managers/UserManager.js +136 -146
  210. package/src/managers/UserNoteManager.js +53 -53
  211. package/src/managers/VoiceStateManager.js +59 -37
  212. package/src/rest/APIRequest.js +154 -160
  213. package/src/rest/APIRouter.js +53 -53
  214. package/src/rest/DiscordAPIError.js +119 -104
  215. package/src/rest/HTTPError.js +62 -62
  216. package/src/rest/RESTManager.js +67 -62
  217. package/src/rest/RateLimitError.js +55 -55
  218. package/src/rest/RequestHandler.js +466 -444
  219. package/src/sharding/Shard.js +444 -443
  220. package/src/sharding/ShardClientUtil.js +279 -275
  221. package/src/sharding/ShardingManager.js +319 -318
  222. package/src/structures/AnonymousGuild.js +98 -98
  223. package/src/structures/ApplicationCommand.js +593 -593
  224. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -48
  225. package/src/structures/AutoModerationActionExecution.js +89 -89
  226. package/src/structures/AutoModerationRule.js +294 -294
  227. package/src/structures/AutocompleteInteraction.js +107 -107
  228. package/src/structures/Base.js +43 -43
  229. package/src/structures/BaseCommandInteraction.js +211 -211
  230. package/src/structures/BaseGuild.js +116 -116
  231. package/src/structures/BaseGuildEmoji.js +56 -56
  232. package/src/structures/BaseGuildTextChannel.js +191 -191
  233. package/src/structures/BaseGuildVoiceChannel.js +241 -241
  234. package/src/structures/BaseMessageComponent.js +181 -114
  235. package/src/structures/ButtonInteraction.js +11 -11
  236. package/src/structures/CallState.js +63 -63
  237. package/src/structures/CategoryChannel.js +85 -85
  238. package/src/structures/Channel.js +284 -270
  239. package/src/structures/ClientPresence.js +77 -85
  240. package/src/structures/ClientUser.js +479 -448
  241. package/src/structures/CommandInteraction.js +41 -41
  242. package/src/structures/CommandInteractionOptionResolver.js +276 -276
  243. package/src/structures/ContainerComponent.js +68 -0
  244. package/src/structures/ContextMenuInteraction.js +65 -65
  245. package/src/structures/DMChannel.js +219 -217
  246. package/src/structures/DirectoryChannel.js +20 -20
  247. package/src/structures/Emoji.js +148 -148
  248. package/src/structures/FileComponent.js +49 -0
  249. package/src/structures/ForumChannel.js +31 -261
  250. package/src/structures/GroupDMChannel.js +394 -387
  251. package/src/structures/Guild.js +1643 -1608
  252. package/src/structures/GuildAuditLogs.js +746 -729
  253. package/src/structures/GuildBan.js +59 -59
  254. package/src/structures/GuildBoost.js +108 -108
  255. package/src/structures/GuildChannel.js +470 -468
  256. package/src/structures/GuildEmoji.js +161 -161
  257. package/src/structures/GuildMember.js +636 -568
  258. package/src/structures/GuildPreview.js +191 -191
  259. package/src/structures/GuildPreviewEmoji.js +27 -27
  260. package/src/structures/GuildScheduledEvent.js +536 -441
  261. package/src/structures/GuildTemplate.js +236 -236
  262. package/src/structures/Integration.js +188 -188
  263. package/src/structures/IntegrationApplication.js +96 -96
  264. package/src/structures/Interaction.js +290 -290
  265. package/src/structures/InteractionCollector.js +248 -248
  266. package/src/structures/InteractionWebhook.js +43 -43
  267. package/src/structures/Invite.js +358 -358
  268. package/src/structures/InviteGuild.js +23 -23
  269. package/src/structures/InviteStageInstance.js +86 -86
  270. package/src/structures/MediaChannel.js +11 -0
  271. package/src/structures/MediaGalleryComponent.js +41 -0
  272. package/src/structures/MediaGalleryItem.js +47 -0
  273. package/src/structures/Message.js +1252 -1227
  274. package/src/structures/MessageActionRow.js +105 -103
  275. package/src/structures/MessageAttachment.js +216 -204
  276. package/src/structures/MessageButton.js +166 -165
  277. package/src/structures/MessageCollector.js +146 -146
  278. package/src/structures/MessageComponentInteraction.js +120 -120
  279. package/src/structures/MessageContextMenuInteraction.js +20 -20
  280. package/src/structures/MessageEmbed.js +596 -586
  281. package/src/structures/MessageMentions.js +273 -273
  282. package/src/structures/MessagePayload.js +354 -318
  283. package/src/structures/MessageReaction.js +181 -171
  284. package/src/structures/MessageSelectMenu.js +141 -140
  285. package/src/structures/Modal.js +161 -161
  286. package/src/structures/ModalSubmitFieldsResolver.js +53 -53
  287. package/src/structures/ModalSubmitInteraction.js +119 -119
  288. package/src/structures/NewsChannel.js +32 -32
  289. package/src/structures/OAuth2Guild.js +28 -28
  290. package/src/structures/PermissionOverwrites.js +198 -196
  291. package/src/structures/Poll.js +108 -0
  292. package/src/structures/PollAnswer.js +88 -0
  293. package/src/structures/Presence.js +1105 -1101
  294. package/src/structures/ReactionCollector.js +229 -229
  295. package/src/structures/ReactionEmoji.js +31 -31
  296. package/src/structures/Role.js +590 -531
  297. package/src/structures/SectionComponent.js +48 -0
  298. package/src/structures/SelectMenuInteraction.js +21 -21
  299. package/src/structures/SeparatorComponent.js +48 -0
  300. package/src/structures/Session.js +81 -0
  301. package/src/structures/StageChannel.js +104 -104
  302. package/src/structures/StageInstance.js +208 -208
  303. package/src/structures/Sticker.js +310 -310
  304. package/src/structures/StickerPack.js +95 -95
  305. package/src/structures/StoreChannel.js +56 -56
  306. package/src/structures/Team.js +118 -118
  307. package/src/structures/TeamMember.js +80 -71
  308. package/src/structures/TextChannel.js +33 -33
  309. package/src/structures/TextDisplayComponent.js +40 -0
  310. package/src/structures/TextInputComponent.js +132 -131
  311. package/src/structures/ThreadChannel.js +605 -607
  312. package/src/structures/ThreadMember.js +105 -105
  313. package/src/structures/ThreadOnlyChannel.js +249 -0
  314. package/src/structures/ThumbnailComponent.js +57 -0
  315. package/src/structures/Typing.js +74 -74
  316. package/src/structures/UnfurledMediaItem.js +29 -0
  317. package/src/structures/User.js +640 -543
  318. package/src/structures/UserContextMenuInteraction.js +29 -29
  319. package/src/structures/VoiceChannel.js +110 -110
  320. package/src/structures/VoiceChannelEffect.js +69 -0
  321. package/src/structures/VoiceRegion.js +53 -53
  322. package/src/structures/VoiceState.js +354 -341
  323. package/src/structures/WebEmbed.js +373 -373
  324. package/src/structures/Webhook.js +478 -467
  325. package/src/structures/WelcomeChannel.js +60 -60
  326. package/src/structures/WelcomeScreen.js +48 -48
  327. package/src/structures/Widget.js +87 -87
  328. package/src/structures/WidgetMember.js +99 -99
  329. package/src/structures/interfaces/Application.js +825 -313
  330. package/src/structures/interfaces/Collector.js +300 -300
  331. package/src/structures/interfaces/InteractionResponses.js +313 -313
  332. package/src/structures/interfaces/TextBasedChannel.js +759 -719
  333. package/src/util/APITypes.js +59 -0
  334. package/src/util/ActivityFlags.js +44 -44
  335. package/src/util/ApplicationFlags.js +76 -76
  336. package/src/util/AttachmentFlags.js +38 -38
  337. package/src/util/BitField.js +170 -170
  338. package/src/util/ChannelFlags.js +45 -45
  339. package/src/util/Constants.js +1914 -1773
  340. package/src/util/DataResolver.js +146 -145
  341. package/src/util/Formatters.js +228 -228
  342. package/src/util/GuildMemberFlags.js +43 -43
  343. package/src/util/Intents.js +74 -74
  344. package/src/util/InviteFlags.js +34 -29
  345. package/src/util/LimitedCollection.js +131 -131
  346. package/src/util/MessageFlags.js +63 -54
  347. package/src/util/Options.js +358 -336
  348. package/src/util/Permissions.js +202 -202
  349. package/src/util/PremiumUsageFlags.js +31 -31
  350. package/src/util/PurchasedFlags.js +33 -33
  351. package/src/util/RemoteAuth.js +382 -379
  352. package/src/util/RoleFlags.js +37 -37
  353. package/src/util/SnowflakeUtil.js +92 -92
  354. package/src/util/Speaking.js +33 -0
  355. package/src/util/Sweepers.js +466 -466
  356. package/src/util/SystemChannelFlags.js +55 -55
  357. package/src/util/ThreadMemberFlags.js +30 -30
  358. package/src/util/UserFlags.js +104 -104
  359. package/src/util/Util.js +1048 -889
  360. package/typings/enums.d.ts +439 -297
  361. package/typings/index.d.ts +8247 -7432
  362. package/typings/rawDataTypes.d.ts +403 -342
  363. package/src/structures/MessagePoll.js +0 -238
@@ -1,441 +1,536 @@
1
- 'use strict';
2
-
3
- const Base = require('./Base');
4
- const { Error } = require('../errors');
5
- const {
6
- GuildScheduledEventEntityTypes,
7
- GuildScheduledEventStatuses,
8
- GuildScheduledEventPrivacyLevels,
9
- Endpoints,
10
- } = require('../util/Constants');
11
- const SnowflakeUtil = require('../util/SnowflakeUtil');
12
-
13
- /**
14
- * Represents a scheduled event in a {@link Guild}.
15
- * @extends {Base}
16
- */
17
- class GuildScheduledEvent extends Base {
18
- constructor(client, data) {
19
- super(client);
20
-
21
- /**
22
- * The id of the guild scheduled event
23
- * @type {Snowflake}
24
- */
25
- this.id = data.id;
26
-
27
- /**
28
- * The id of the guild this guild scheduled event belongs to
29
- * @type {Snowflake}
30
- */
31
- this.guildId = data.guild_id;
32
-
33
- this._patch(data);
34
- }
35
-
36
- _patch(data) {
37
- if ('channel_id' in data) {
38
- /**
39
- * The channel id in which the scheduled event will be hosted, or `null` if entity type is `EXTERNAL`
40
- * @type {?Snowflake}
41
- */
42
- this.channelId = data.channel_id;
43
- } else {
44
- this.channelId ??= null;
45
- }
46
-
47
- if ('creator_id' in data) {
48
- /**
49
- * The id of the user that created this guild scheduled event
50
- * @type {?Snowflake}
51
- */
52
- this.creatorId = data.creator_id;
53
- } else {
54
- this.creatorId ??= null;
55
- }
56
-
57
- /**
58
- * The name of the guild scheduled event
59
- * @type {string}
60
- */
61
- this.name = data.name;
62
-
63
- if ('description' in data) {
64
- /**
65
- * The description of the guild scheduled event
66
- * @type {?string}
67
- */
68
- this.description = data.description;
69
- } else {
70
- this.description ??= null;
71
- }
72
-
73
- /**
74
- * The timestamp the guild scheduled event will start at
75
- * <info>This can be potentially `null` only when it's an {@link AuditLogEntryTarget}</info>
76
- * @type {?number}
77
- */
78
- this.scheduledStartTimestamp = data.scheduled_start_time ? Date.parse(data.scheduled_start_time) : null;
79
-
80
- /**
81
- * The timestamp the guild scheduled event will end at,
82
- * or `null` if the event does not have a scheduled time to end
83
- * @type {?number}
84
- */
85
- this.scheduledEndTimestamp = data.scheduled_end_time ? Date.parse(data.scheduled_end_time) : null;
86
-
87
- /**
88
- * The privacy level of the guild scheduled event
89
- * @type {PrivacyLevel}
90
- */
91
- this.privacyLevel = GuildScheduledEventPrivacyLevels[data.privacy_level];
92
-
93
- /**
94
- * The status of the guild scheduled event
95
- * @type {GuildScheduledEventStatus}
96
- */
97
- this.status = GuildScheduledEventStatuses[data.status];
98
-
99
- /**
100
- * The type of hosting entity associated with the scheduled event
101
- * @type {GuildScheduledEventEntityType}
102
- */
103
- this.entityType = GuildScheduledEventEntityTypes[data.entity_type];
104
-
105
- if ('entity_id' in data) {
106
- /**
107
- * The id of the hosting entity associated with the scheduled event
108
- * @type {?Snowflake}
109
- */
110
- this.entityId = data.entity_id;
111
- } else {
112
- this.entityId ??= null;
113
- }
114
-
115
- if ('user_count' in data) {
116
- /**
117
- * The number of users who are subscribed to this guild scheduled event
118
- * @type {?number}
119
- */
120
- this.userCount = data.user_count;
121
- } else {
122
- this.userCount ??= null;
123
- }
124
-
125
- if ('creator' in data) {
126
- /**
127
- * The user that created this guild scheduled event
128
- * @type {?User}
129
- */
130
- this.creator = this.client.users._add(data.creator);
131
- } else {
132
- this.creator ??= this.client.users.resolve(this.creatorId);
133
- }
134
-
135
- /* eslint-disable max-len */
136
- /**
137
- * Represents the additional metadata for a {@link GuildScheduledEvent}
138
- * @see {@link https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-entity-metadata}
139
- * @typedef {Object} GuildScheduledEventEntityMetadata
140
- * @property {?string} location The location of the guild scheduled event
141
- */
142
- /* eslint-enable max-len */
143
-
144
- if ('entity_metadata' in data) {
145
- if (data.entity_metadata) {
146
- /**
147
- * Additional metadata
148
- * @type {?GuildScheduledEventEntityMetadata}
149
- */
150
- this.entityMetadata = {
151
- location: data.entity_metadata.location ?? this.entityMetadata?.location ?? null,
152
- };
153
- } else {
154
- this.entityMetadata = null;
155
- }
156
- } else {
157
- this.entityMetadata ??= null;
158
- }
159
-
160
- if ('image' in data) {
161
- /**
162
- * The cover image hash for this scheduled event
163
- * @type {?string}
164
- */
165
- this.image = data.image;
166
- } else {
167
- this.image ??= null;
168
- }
169
- }
170
-
171
- /**
172
- * The URL of this scheduled event's cover image
173
- * @param {StaticImageURLOptions} [options={}] Options for image URL
174
- * @returns {?string}
175
- */
176
- coverImageURL({ format, size } = {}) {
177
- return this.image && this.client.rest.cdn.guildScheduledEventCover(this.id, this.image, format, size);
178
- }
179
-
180
- /**
181
- * The timestamp the guild scheduled event was created at
182
- * @type {number}
183
- * @readonly
184
- */
185
- get createdTimestamp() {
186
- return SnowflakeUtil.timestampFrom(this.id);
187
- }
188
-
189
- /**
190
- * The time the guild scheduled event was created at
191
- * @type {Date}
192
- * @readonly
193
- */
194
- get createdAt() {
195
- return new Date(this.createdTimestamp);
196
- }
197
-
198
- /**
199
- * The time the guild scheduled event will start at
200
- * @type {Date}
201
- * @readonly
202
- */
203
- get scheduledStartAt() {
204
- return new Date(this.scheduledStartTimestamp);
205
- }
206
-
207
- /**
208
- * The time the guild scheduled event will end at,
209
- * or `null` if the event does not have a scheduled time to end
210
- * @type {?Date}
211
- * @readonly
212
- */
213
- get scheduledEndAt() {
214
- return this.scheduledEndTimestamp && new Date(this.scheduledEndTimestamp);
215
- }
216
-
217
- /**
218
- * The channel associated with this scheduled event
219
- * @type {?(VoiceChannel|StageChannel)}
220
- * @readonly
221
- */
222
- get channel() {
223
- return this.client.channels.resolve(this.channelId);
224
- }
225
-
226
- /**
227
- * The guild this scheduled event belongs to
228
- * @type {?Guild}
229
- * @readonly
230
- */
231
- get guild() {
232
- return this.client.guilds.resolve(this.guildId);
233
- }
234
-
235
- /**
236
- * The URL to the guild scheduled event
237
- * @type {string}
238
- * @readonly
239
- */
240
- get url() {
241
- return Endpoints.scheduledEvent(this.client.options.http.scheduledEvent, this.guildId, this.id);
242
- }
243
-
244
- /**
245
- * Options used to create an invite URL to a {@link GuildScheduledEvent}
246
- * @typedef {CreateInviteOptions} CreateGuildScheduledEventInviteURLOptions
247
- * @property {GuildInvitableChannelResolvable} [channel] The channel to create the invite in.
248
- * <warn>This is required when the `entityType` of `GuildScheduledEvent` is `EXTERNAL`, gets ignored otherwise</warn>
249
- */
250
-
251
- /**
252
- * Creates an invite URL to this guild scheduled event.
253
- * @param {CreateGuildScheduledEventInviteURLOptions} [options] The options to create the invite
254
- * @returns {Promise<string>}
255
- */
256
- async createInviteURL(options) {
257
- let channelId = this.channelId;
258
- if (this.entityType === 'EXTERNAL') {
259
- if (!options?.channel) throw new Error('INVITE_OPTIONS_MISSING_CHANNEL');
260
- channelId = this.guild.channels.resolveId(options.channel);
261
- if (!channelId) throw new Error('GUILD_CHANNEL_RESOLVE');
262
- }
263
- const invite = await this.guild.invites.create(channelId, options);
264
- return Endpoints.invite(this.client.options.http.invite, invite.code, this.id);
265
- }
266
-
267
- /**
268
- * Edits this guild scheduled event.
269
- * @param {GuildScheduledEventEditOptions} options The options to edit the guild scheduled event
270
- * @returns {Promise<GuildScheduledEvent>}
271
- * @example
272
- * // Edit a guild scheduled event
273
- * guildScheduledEvent.edit({ name: 'Party' })
274
- * .then(guildScheduledEvent => console.log(guildScheduledEvent))
275
- * .catch(console.error);
276
- */
277
- edit(options) {
278
- return this.guild.scheduledEvents.edit(this.id, options);
279
- }
280
-
281
- /**
282
- * Deletes this guild scheduled event.
283
- * @returns {Promise<GuildScheduledEvent>}
284
- * @example
285
- * // Delete a guild scheduled event
286
- * guildScheduledEvent.delete()
287
- * .then(guildScheduledEvent => console.log(guildScheduledEvent))
288
- * .catch(console.error);
289
- */
290
- async delete() {
291
- await this.guild.scheduledEvents.delete(this.id);
292
- return this;
293
- }
294
-
295
- /**
296
- * Sets a new name for the guild scheduled event.
297
- * @param {string} name The new name of the guild scheduled event
298
- * @param {string} [reason] The reason for changing the name
299
- * @returns {Promise<GuildScheduledEvent>}
300
- * @example
301
- * // Set name of a guild scheduled event
302
- * guildScheduledEvent.setName('Birthday Party')
303
- * .then(guildScheduledEvent => console.log(`Set the name to: ${guildScheduledEvent.name}`))
304
- * .catch(console.error);
305
- */
306
- setName(name, reason) {
307
- return this.edit({ name, reason });
308
- }
309
-
310
- /**
311
- * Sets a new time to schedule the event at.
312
- * @param {DateResolvable} scheduledStartTime The time to schedule the event at
313
- * @param {string} [reason] The reason for changing the scheduled start time
314
- * @returns {Promise<GuildScheduledEvent>}
315
- * @example
316
- * // Set start time of a guild scheduled event
317
- * guildScheduledEvent.setScheduledStartTime('2022-09-24T00:00:00+05:30')
318
- * .then(guildScheduledEvent => console.log(`Set the start time to: ${guildScheduledEvent.scheduledStartTime}`))
319
- * .catch(console.error);
320
- */
321
- setScheduledStartTime(scheduledStartTime, reason) {
322
- return this.edit({ scheduledStartTime, reason });
323
- }
324
-
325
- // TODO: scheduledEndTime gets reset on passing null but it hasn't been documented
326
- /**
327
- * Sets a new time to end the event at.
328
- * @param {DateResolvable} scheduledEndTime The time to end the event at
329
- * @param {string} [reason] The reason for changing the scheduled end time
330
- * @returns {Promise<GuildScheduledEvent>}
331
- * @example
332
- * // Set end time of a guild scheduled event
333
- * guildScheduledEvent.setScheduledEndTime('2022-09-25T00:00:00+05:30')
334
- * .then(guildScheduledEvent => console.log(`Set the end time to: ${guildScheduledEvent.scheduledEndTime}`))
335
- * .catch(console.error);
336
- */
337
- setScheduledEndTime(scheduledEndTime, reason) {
338
- return this.edit({ scheduledEndTime, reason });
339
- }
340
-
341
- /**
342
- * Sets the new description of the guild scheduled event.
343
- * @param {string} description The description of the guild scheduled event
344
- * @param {string} [reason] The reason for changing the description
345
- * @returns {Promise<GuildScheduledEvent>}
346
- * @example
347
- * // Set description of a guild scheduled event
348
- * guildScheduledEvent.setDescription('A virtual birthday party')
349
- * .then(guildScheduledEvent => console.log(`Set the description to: ${guildScheduledEvent.description}`))
350
- * .catch(console.error);
351
- */
352
- setDescription(description, reason) {
353
- return this.edit({ description, reason });
354
- }
355
-
356
- /**
357
- * Sets the new status of the guild scheduled event.
358
- * <info>If you're working with TypeScript, use this method in conjunction with status type-guards
359
- * like {@link GuildScheduledEvent#isScheduled} to get only valid status as suggestion</info>
360
- * @param {GuildScheduledEventStatus|number} status The status of the guild scheduled event
361
- * @param {string} [reason] The reason for changing the status
362
- * @returns {Promise<GuildScheduledEvent>}
363
- * @example
364
- * // Set status of a guild scheduled event
365
- * guildScheduledEvent.setStatus('ACTIVE')
366
- * .then(guildScheduledEvent => console.log(`Set the status to: ${guildScheduledEvent.status}`))
367
- * .catch(console.error);
368
- */
369
- setStatus(status, reason) {
370
- return this.edit({ status, reason });
371
- }
372
-
373
- /**
374
- * Sets the new location of the guild scheduled event.
375
- * @param {string} location The location of the guild scheduled event
376
- * @param {string} [reason] The reason for changing the location
377
- * @returns {Promise<GuildScheduledEvent>}
378
- * @example
379
- * // Set location of a guild scheduled event
380
- * guildScheduledEvent.setLocation('Earth')
381
- * .then(guildScheduledEvent => console.log(`Set the location to: ${guildScheduledEvent.entityMetadata.location}`))
382
- * .catch(console.error);
383
- */
384
- setLocation(location, reason) {
385
- return this.edit({ entityMetadata: { location }, reason });
386
- }
387
-
388
- /**
389
- * Fetches subscribers of this guild scheduled event.
390
- * @param {FetchGuildScheduledEventSubscribersOptions} [options] Options for fetching the subscribers
391
- * @returns {Promise<Collection<Snowflake, GuildScheduledEventUser>>}
392
- */
393
- fetchSubscribers(options) {
394
- return this.guild.scheduledEvents.fetchSubscribers(this.id, options);
395
- }
396
-
397
- /**
398
- * When concatenated with a string, this automatically concatenates the event's URL instead of the object.
399
- * @returns {string}
400
- * @example
401
- * // Logs: Event: https://discord.com/events/412345678901234567/499876543211234567
402
- * console.log(`Event: ${guildScheduledEvent}`);
403
- */
404
- toString() {
405
- return this.url;
406
- }
407
-
408
- /**
409
- * Indicates whether this guild scheduled event has an `ACTIVE` status.
410
- * @returns {boolean}
411
- */
412
- isActive() {
413
- return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.ACTIVE;
414
- }
415
-
416
- /**
417
- * Indicates whether this guild scheduled event has a `CANCELED` status.
418
- * @returns {boolean}
419
- */
420
- isCanceled() {
421
- return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.CANCELED;
422
- }
423
-
424
- /**
425
- * Indicates whether this guild scheduled event has a `COMPLETED` status.
426
- * @returns {boolean}
427
- */
428
- isCompleted() {
429
- return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.COMPLETED;
430
- }
431
-
432
- /**
433
- * Indicates whether this guild scheduled event has a `SCHEDULED` status.
434
- * @returns {boolean}
435
- */
436
- isScheduled() {
437
- return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.SCHEDULED;
438
- }
439
- }
440
-
441
- exports.GuildScheduledEvent = GuildScheduledEvent;
1
+ 'use strict';
2
+
3
+ const Base = require('./Base');
4
+ const { Error } = require('../errors');
5
+ const {
6
+ GuildScheduledEventEntityTypes,
7
+ GuildScheduledEventStatuses,
8
+ GuildScheduledEventPrivacyLevels,
9
+ Endpoints,
10
+ } = require('../util/Constants');
11
+ const SnowflakeUtil = require('../util/SnowflakeUtil');
12
+
13
+ /**
14
+ * Represents a scheduled event in a {@link Guild}.
15
+ * @extends {Base}
16
+ */
17
+ class GuildScheduledEvent extends Base {
18
+ constructor(client, data) {
19
+ super(client);
20
+
21
+ /**
22
+ * The id of the guild scheduled event
23
+ * @type {Snowflake}
24
+ */
25
+ this.id = data.id;
26
+
27
+ /**
28
+ * The id of the guild this guild scheduled event belongs to
29
+ * @type {Snowflake}
30
+ */
31
+ this.guildId = data.guild_id;
32
+
33
+ this._patch(data);
34
+ }
35
+
36
+ _patch(data) {
37
+ if ('channel_id' in data) {
38
+ /**
39
+ * The channel id in which the scheduled event will be hosted, or `null` if entity type is `EXTERNAL`
40
+ * @type {?Snowflake}
41
+ */
42
+ this.channelId = data.channel_id;
43
+ } else {
44
+ this.channelId ??= null;
45
+ }
46
+
47
+ if ('creator_id' in data) {
48
+ /**
49
+ * The id of the user that created this guild scheduled event
50
+ * @type {?Snowflake}
51
+ */
52
+ this.creatorId = data.creator_id;
53
+ } else {
54
+ this.creatorId ??= null;
55
+ }
56
+
57
+ if ('name' in data) {
58
+ /**
59
+ * The name of the guild scheduled event
60
+ * @type {?string}
61
+ */
62
+ this.name = data.name;
63
+ } else {
64
+ // Only if partial.
65
+ this.name ??= null;
66
+ }
67
+
68
+ if ('description' in data) {
69
+ /**
70
+ * The description of the guild scheduled event
71
+ * @type {?string}
72
+ */
73
+ this.description = data.description;
74
+ } else {
75
+ this.description ??= null;
76
+ }
77
+
78
+ if ('scheduled_start_time' in data) {
79
+ /**
80
+ * The timestamp the guild scheduled event will start at
81
+ * <info>This can be potentially `null` only when it's an {@link AuditLogEntryTarget}</info>
82
+ * @type {?number}
83
+ */
84
+ this.scheduledStartTimestamp = Date.parse(data.scheduled_start_time);
85
+ } else {
86
+ this.scheduledStartTimestamp ??= null;
87
+ }
88
+
89
+ if ('scheduled_end_time' in data) {
90
+ /**
91
+ * The timestamp the guild scheduled event will end at
92
+ * or `null` if the event does not have a scheduled time to end
93
+ * @type {?number}
94
+ */
95
+ this.scheduledEndTimestamp = data.scheduled_end_time ? Date.parse(data.scheduled_end_time) : null;
96
+ } else {
97
+ this.scheduledEndTimestamp ??= null;
98
+ }
99
+
100
+ if ('privacy_level' in data) {
101
+ /**
102
+ * The privacy level of the guild scheduled event
103
+ * @type {PrivacyLevel}
104
+ */
105
+ this.privacyLevel = GuildScheduledEventPrivacyLevels[data.privacy_level];
106
+ } else {
107
+ // Only if partial.
108
+ this.privacyLevel ??= null;
109
+ }
110
+
111
+ if ('status' in data) {
112
+ /**
113
+ * The status of the guild scheduled event
114
+ * @type {GuildScheduledEventStatus}
115
+ */
116
+ this.status = GuildScheduledEventStatuses[data.status];
117
+ } else {
118
+ // Only if partial.
119
+ this.status ??= null;
120
+ }
121
+
122
+ if ('entity_type' in data) {
123
+ /**
124
+ * The type of hosting entity associated with the scheduled event
125
+ * @type {GuildScheduledEventEntityType}
126
+ */
127
+ this.entityType = GuildScheduledEventEntityTypes[data.entity_type];
128
+ } else {
129
+ // Only if partial.
130
+ this.entityType ??= null;
131
+ }
132
+
133
+ if ('entity_id' in data) {
134
+ /**
135
+ * The id of the hosting entity associated with the scheduled event
136
+ * @type {?Snowflake}
137
+ */
138
+ this.entityId = data.entity_id;
139
+ } else {
140
+ this.entityId ??= null;
141
+ }
142
+
143
+ if ('user_count' in data) {
144
+ /**
145
+ * The number of users who are subscribed to this guild scheduled event
146
+ * @type {?number}
147
+ */
148
+ this.userCount = data.user_count;
149
+ } else {
150
+ this.userCount ??= null;
151
+ }
152
+
153
+ if ('creator' in data) {
154
+ /**
155
+ * The user that created this guild scheduled event
156
+ * @type {?User}
157
+ */
158
+ this.creator = this.client.users._add(data.creator);
159
+ } else {
160
+ this.creator ??= this.client.users.resolve(this.creatorId);
161
+ }
162
+
163
+ /* eslint-disable max-len */
164
+ /**
165
+ * Represents the additional metadata for a {@link GuildScheduledEvent}
166
+ * @see {@link https://discord.com/developers/docs/resources/guild-scheduled-event#guild-scheduled-event-object-guild-scheduled-event-entity-metadata}
167
+ * @typedef {Object} GuildScheduledEventEntityMetadata
168
+ * @property {?string} location The location of the guild scheduled event
169
+ */
170
+ /* eslint-enable max-len */
171
+
172
+ if ('entity_metadata' in data) {
173
+ if (data.entity_metadata) {
174
+ /**
175
+ * Additional metadata
176
+ * @type {?GuildScheduledEventEntityMetadata}
177
+ */
178
+ this.entityMetadata = {
179
+ location: data.entity_metadata.location ?? this.entityMetadata?.location ?? null,
180
+ };
181
+ } else {
182
+ this.entityMetadata = null;
183
+ }
184
+ } else {
185
+ this.entityMetadata ??= null;
186
+ }
187
+
188
+ if ('image' in data) {
189
+ /**
190
+ * The cover image hash for this scheduled event
191
+ * @type {?string}
192
+ */
193
+ this.image = data.image;
194
+ } else {
195
+ this.image ??= null;
196
+ }
197
+
198
+ /**
199
+ * Represents the recurrence rule for a {@link GuildScheduledEvent}.
200
+ * @typedef {Object} GuildScheduledEventRecurrenceRule
201
+ * @property {number} startTimestamp The timestamp the recurrence rule interval starts at
202
+ * @property {Date} startAt The time the recurrence rule interval starts at
203
+ * @property {?number} endTimestamp The timestamp the recurrence rule interval ends at
204
+ * @property {?Date} endAt The time the recurrence rule interval ends at
205
+ * @property {GuildScheduledEventRecurrenceRuleFrequency} frequency How often the event occurs
206
+ * @property {number} interval The spacing between the events
207
+ * @property {?GuildScheduledEventRecurrenceRuleWeekday[]} byWeekday The days within a week to recur on
208
+ * @property {?GuildScheduledEventRecurrenceRuleNWeekday[]} byNWeekday The days within a week to recur on
209
+ * @property {?GuildScheduledEventRecurrenceRuleMonth[]} byMonth The months to recur on
210
+ * @property {?number[]} byMonthDay The days within a month to recur on
211
+ * @property {?number[]} byYearDay The days within a year to recur on
212
+ * @property {?number} count The total amount of times the event is allowed to recur before stopping
213
+ */
214
+ /**
215
+ * @typedef {Object} GuildScheduledEventRecurrenceRuleNWeekday
216
+ * @property {number} n The week to recur on
217
+ * @property {GuildScheduledEventRecurrenceRuleWeekday} day The day within the week to recur on
218
+ */
219
+
220
+ if ('recurrence_rule' in data) {
221
+ /**
222
+ * The recurrence rule for this scheduled event
223
+ * @type {?GuildScheduledEventRecurrenceRule}
224
+ */
225
+ this.recurrenceRule = data.recurrence_rule && {
226
+ startTimestamp: Date.parse(data.recurrence_rule.start),
227
+ get startAt() {
228
+ return new Date(this.startTimestamp);
229
+ },
230
+ endTimestamp: data.recurrence_rule.end && Date.parse(data.recurrence_rule.end),
231
+ get endAt() {
232
+ return this.endTimestamp && new Date(this.endTimestamp);
233
+ },
234
+ frequency: data.recurrence_rule.frequency,
235
+ interval: data.recurrence_rule.interval,
236
+ byWeekday: data.recurrence_rule.by_weekday,
237
+ byNWeekday: data.recurrence_rule.by_n_weekday,
238
+ byMonth: data.recurrence_rule.by_month,
239
+ byMonthDay: data.recurrence_rule.by_month_day,
240
+ byYearDay: data.recurrence_rule.by_year_day,
241
+ count: data.recurrence_rule.count,
242
+ };
243
+ } else {
244
+ this.recurrenceRule ??= null;
245
+ }
246
+ }
247
+
248
+ /**
249
+ * The URL of this scheduled event's cover image
250
+ * @param {StaticImageURLOptions} [options={}] Options for image URL
251
+ * @returns {?string}
252
+ */
253
+ coverImageURL({ format, size } = {}) {
254
+ return this.image && this.client.rest.cdn.GuildScheduledEventCover(this.id, this.image, format, size);
255
+ }
256
+
257
+ /**
258
+ * Whether this guild scheduled event is partial.
259
+ * @type {boolean}
260
+ * @readonly
261
+ */
262
+ get partial() {
263
+ return this.name === null;
264
+ }
265
+
266
+ /**
267
+ * The timestamp the guild scheduled event was created at
268
+ * @type {number}
269
+ * @readonly
270
+ */
271
+ get createdTimestamp() {
272
+ return SnowflakeUtil.timestampFrom(this.id);
273
+ }
274
+
275
+ /**
276
+ * The time the guild scheduled event was created at
277
+ * @type {Date}
278
+ * @readonly
279
+ */
280
+ get createdAt() {
281
+ return new Date(this.createdTimestamp);
282
+ }
283
+
284
+ /**
285
+ * The time the guild scheduled event will start at
286
+ * @type {Date}
287
+ * @readonly
288
+ */
289
+ get scheduledStartAt() {
290
+ return new Date(this.scheduledStartTimestamp);
291
+ }
292
+
293
+ /**
294
+ * The time the guild scheduled event will end at,
295
+ * or `null` if the event does not have a scheduled time to end
296
+ * @type {?Date}
297
+ * @readonly
298
+ */
299
+ get scheduledEndAt() {
300
+ return this.scheduledEndTimestamp && new Date(this.scheduledEndTimestamp);
301
+ }
302
+
303
+ /**
304
+ * The channel associated with this scheduled event
305
+ * @type {?(VoiceChannel|StageChannel)}
306
+ * @readonly
307
+ */
308
+ get channel() {
309
+ return this.client.channels.resolve(this.channelId);
310
+ }
311
+
312
+ /**
313
+ * The guild this scheduled event belongs to
314
+ * @type {?Guild}
315
+ * @readonly
316
+ */
317
+ get guild() {
318
+ return this.client.guilds.resolve(this.guildId);
319
+ }
320
+
321
+ /**
322
+ * The URL to the guild scheduled event
323
+ * @type {string}
324
+ * @readonly
325
+ */
326
+ get url() {
327
+ return Endpoints.scheduledEvent(this.client.options.http.scheduledEvent, this.guildId, this.id);
328
+ }
329
+
330
+ /**
331
+ * Fetches this guild scheduled event.
332
+ * @param {boolean} [force=true] Whether to skip the cache check and request the API
333
+ * @returns {Promise<GuildScheduledEvent>}
334
+ */
335
+ fetch(force = true) {
336
+ return this.guild.scheduledEvents.fetch({ guildScheduledEvent: this.id, force });
337
+ }
338
+
339
+ /**
340
+ * Options used to create an invite URL to a {@link GuildScheduledEvent}
341
+ * @typedef {CreateInviteOptions} CreateGuildScheduledEventInviteURLOptions
342
+ * @property {GuildInvitableChannelResolvable} [channel] The channel to create the invite in.
343
+ * <warn>This is required when the `entityType` of `GuildScheduledEvent` is `EXTERNAL`, gets ignored otherwise</warn>
344
+ */
345
+
346
+ /**
347
+ * Creates an invite URL to this guild scheduled event.
348
+ * @param {CreateGuildScheduledEventInviteURLOptions} [options] The options to create the invite
349
+ * @returns {Promise<string>}
350
+ */
351
+ async createInviteURL(options) {
352
+ let channelId = this.channelId;
353
+ if (this.entityType === 'EXTERNAL') {
354
+ if (!options?.channel) throw new Error('INVITE_OPTIONS_MISSING_CHANNEL');
355
+ channelId = this.guild.channels.resolveId(options.channel);
356
+ if (!channelId) throw new Error('GUILD_CHANNEL_RESOLVE');
357
+ }
358
+ const invite = await this.guild.invites.create(channelId, options);
359
+ return Endpoints.invite(this.client.options.http.invite, invite.code, this.id);
360
+ }
361
+
362
+ /**
363
+ * Edits this guild scheduled event.
364
+ * @param {GuildScheduledEventEditOptions} options The options to edit the guild scheduled event
365
+ * @returns {Promise<GuildScheduledEvent>}
366
+ * @example
367
+ * // Edit a guild scheduled event
368
+ * guildScheduledEvent.edit({ name: 'Party' })
369
+ * .then(guildScheduledEvent => console.log(guildScheduledEvent))
370
+ * .catch(console.error);
371
+ */
372
+ edit(options) {
373
+ return this.guild.scheduledEvents.edit(this.id, options);
374
+ }
375
+
376
+ /**
377
+ * Deletes this guild scheduled event.
378
+ * @returns {Promise<GuildScheduledEvent>}
379
+ * @example
380
+ * // Delete a guild scheduled event
381
+ * guildScheduledEvent.delete()
382
+ * .then(guildScheduledEvent => console.log(guildScheduledEvent))
383
+ * .catch(console.error);
384
+ */
385
+ async delete() {
386
+ await this.guild.scheduledEvents.delete(this.id);
387
+ return this;
388
+ }
389
+
390
+ /**
391
+ * Sets a new name for the guild scheduled event.
392
+ * @param {string} name The new name of the guild scheduled event
393
+ * @param {string} [reason] The reason for changing the name
394
+ * @returns {Promise<GuildScheduledEvent>}
395
+ * @example
396
+ * // Set name of a guild scheduled event
397
+ * guildScheduledEvent.setName('Birthday Party')
398
+ * .then(guildScheduledEvent => console.log(`Set the name to: ${guildScheduledEvent.name}`))
399
+ * .catch(console.error);
400
+ */
401
+ setName(name, reason) {
402
+ return this.edit({ name, reason });
403
+ }
404
+
405
+ /**
406
+ * Sets a new time to schedule the event at.
407
+ * @param {DateResolvable} scheduledStartTime The time to schedule the event at
408
+ * @param {string} [reason] The reason for changing the scheduled start time
409
+ * @returns {Promise<GuildScheduledEvent>}
410
+ * @example
411
+ * // Set start time of a guild scheduled event
412
+ * guildScheduledEvent.setScheduledStartTime('2022-09-24T00:00:00+05:30')
413
+ * .then(guildScheduledEvent => console.log(`Set the start time to: ${guildScheduledEvent.scheduledStartTime}`))
414
+ * .catch(console.error);
415
+ */
416
+ setScheduledStartTime(scheduledStartTime, reason) {
417
+ return this.edit({ scheduledStartTime, reason });
418
+ }
419
+
420
+ // TODO: scheduledEndTime gets reset on passing null but it hasn't been documented
421
+ /**
422
+ * Sets a new time to end the event at.
423
+ * @param {DateResolvable} scheduledEndTime The time to end the event at
424
+ * @param {string} [reason] The reason for changing the scheduled end time
425
+ * @returns {Promise<GuildScheduledEvent>}
426
+ * @example
427
+ * // Set end time of a guild scheduled event
428
+ * guildScheduledEvent.setScheduledEndTime('2022-09-25T00:00:00+05:30')
429
+ * .then(guildScheduledEvent => console.log(`Set the end time to: ${guildScheduledEvent.scheduledEndTime}`))
430
+ * .catch(console.error);
431
+ */
432
+ setScheduledEndTime(scheduledEndTime, reason) {
433
+ return this.edit({ scheduledEndTime, reason });
434
+ }
435
+
436
+ /**
437
+ * Sets the new description of the guild scheduled event.
438
+ * @param {string} description The description of the guild scheduled event
439
+ * @param {string} [reason] The reason for changing the description
440
+ * @returns {Promise<GuildScheduledEvent>}
441
+ * @example
442
+ * // Set description of a guild scheduled event
443
+ * guildScheduledEvent.setDescription('A virtual birthday party')
444
+ * .then(guildScheduledEvent => console.log(`Set the description to: ${guildScheduledEvent.description}`))
445
+ * .catch(console.error);
446
+ */
447
+ setDescription(description, reason) {
448
+ return this.edit({ description, reason });
449
+ }
450
+
451
+ /**
452
+ * Sets the new status of the guild scheduled event.
453
+ * <info>If you're working with TypeScript, use this method in conjunction with status type-guards
454
+ * like {@link GuildScheduledEvent#isScheduled} to get only valid status as suggestion</info>
455
+ * @param {GuildScheduledEventStatus|number} status The status of the guild scheduled event
456
+ * @param {string} [reason] The reason for changing the status
457
+ * @returns {Promise<GuildScheduledEvent>}
458
+ * @example
459
+ * // Set status of a guild scheduled event
460
+ * guildScheduledEvent.setStatus('ACTIVE')
461
+ * .then(guildScheduledEvent => console.log(`Set the status to: ${guildScheduledEvent.status}`))
462
+ * .catch(console.error);
463
+ */
464
+ setStatus(status, reason) {
465
+ return this.edit({ status, reason });
466
+ }
467
+
468
+ /**
469
+ * Sets the new location of the guild scheduled event.
470
+ * @param {string} location The location of the guild scheduled event
471
+ * @param {string} [reason] The reason for changing the location
472
+ * @returns {Promise<GuildScheduledEvent>}
473
+ * @example
474
+ * // Set location of a guild scheduled event
475
+ * guildScheduledEvent.setLocation('Earth')
476
+ * .then(guildScheduledEvent => console.log(`Set the location to: ${guildScheduledEvent.entityMetadata.location}`))
477
+ * .catch(console.error);
478
+ */
479
+ setLocation(location, reason) {
480
+ return this.edit({ entityMetadata: { location }, reason });
481
+ }
482
+
483
+ /**
484
+ * Fetches subscribers of this guild scheduled event.
485
+ * @param {FetchGuildScheduledEventSubscribersOptions} [options] Options for fetching the subscribers
486
+ * @returns {Promise<Collection<Snowflake, GuildScheduledEventUser>>}
487
+ */
488
+ fetchSubscribers(options) {
489
+ return this.guild.scheduledEvents.fetchSubscribers(this.id, options);
490
+ }
491
+
492
+ /**
493
+ * When concatenated with a string, this automatically concatenates the event's URL instead of the object.
494
+ * @returns {string}
495
+ * @example
496
+ * // Logs: Event: https://discord.com/events/412345678901234567/499876543211234567
497
+ * console.log(`Event: ${guildScheduledEvent}`);
498
+ */
499
+ toString() {
500
+ return this.url;
501
+ }
502
+
503
+ /**
504
+ * Indicates whether this guild scheduled event has an `ACTIVE` status.
505
+ * @returns {boolean}
506
+ */
507
+ isActive() {
508
+ return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.ACTIVE;
509
+ }
510
+
511
+ /**
512
+ * Indicates whether this guild scheduled event has a `CANCELED` status.
513
+ * @returns {boolean}
514
+ */
515
+ isCanceled() {
516
+ return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.CANCELED;
517
+ }
518
+
519
+ /**
520
+ * Indicates whether this guild scheduled event has a `COMPLETED` status.
521
+ * @returns {boolean}
522
+ */
523
+ isCompleted() {
524
+ return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.COMPLETED;
525
+ }
526
+
527
+ /**
528
+ * Indicates whether this guild scheduled event has a `SCHEDULED` status.
529
+ * @returns {boolean}
530
+ */
531
+ isScheduled() {
532
+ return GuildScheduledEventStatuses[this.status] === GuildScheduledEventStatuses.SCHEDULED;
533
+ }
534
+ }
535
+
536
+ exports.GuildScheduledEvent = GuildScheduledEvent;