djs-selfbot-v13 3.1.8 → 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 (364) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +48 -37
  3. package/package.json +44 -26
  4. package/src/WebSocket.js +39 -39
  5. package/src/client/BaseClient.js +86 -86
  6. package/src/client/Client.js +934 -765
  7. package/src/client/WebhookClient.js +61 -61
  8. package/src/client/actions/Action.js +116 -120
  9. package/src/client/actions/ActionsManager.js +80 -78
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
  11. package/src/client/actions/AutoModerationActionExecution.js +27 -27
  12. package/src/client/actions/AutoModerationRuleCreate.js +28 -28
  13. package/src/client/actions/AutoModerationRuleDelete.js +32 -32
  14. package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
  15. package/src/client/actions/ChannelCreate.js +23 -23
  16. package/src/client/actions/ChannelDelete.js +39 -39
  17. package/src/client/actions/ChannelUpdate.js +43 -43
  18. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
  19. package/src/client/actions/GuildBanAdd.js +20 -20
  20. package/src/client/actions/GuildBanRemove.js +25 -25
  21. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
  22. package/src/client/actions/GuildDelete.js +65 -65
  23. package/src/client/actions/GuildEmojiCreate.js +20 -20
  24. package/src/client/actions/GuildEmojiDelete.js +21 -21
  25. package/src/client/actions/GuildEmojiUpdate.js +20 -20
  26. package/src/client/actions/GuildEmojisUpdate.js +34 -34
  27. package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
  28. package/src/client/actions/GuildMemberRemove.js +33 -33
  29. package/src/client/actions/GuildMemberUpdate.js +44 -44
  30. package/src/client/actions/GuildRoleCreate.js +25 -25
  31. package/src/client/actions/GuildRoleDelete.js +31 -31
  32. package/src/client/actions/GuildRoleUpdate.js +39 -39
  33. package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
  34. package/src/client/actions/GuildScheduledEventCreate.js +27 -27
  35. package/src/client/actions/GuildScheduledEventDelete.js +31 -31
  36. package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
  37. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
  38. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
  39. package/src/client/actions/GuildStickerCreate.js +20 -20
  40. package/src/client/actions/GuildStickerDelete.js +21 -21
  41. package/src/client/actions/GuildStickerUpdate.js +20 -20
  42. package/src/client/actions/GuildStickersUpdate.js +34 -34
  43. package/src/client/actions/GuildUpdate.js +33 -33
  44. package/src/client/actions/InviteCreate.js +28 -28
  45. package/src/client/actions/InviteDelete.js +30 -30
  46. package/src/client/actions/MessageCreate.js +50 -46
  47. package/src/client/actions/MessageDelete.js +32 -32
  48. package/src/client/actions/MessageDeleteBulk.js +46 -46
  49. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  50. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  51. package/src/client/actions/MessageReactionAdd.js +68 -56
  52. package/src/client/actions/MessageReactionRemove.js +50 -45
  53. package/src/client/actions/MessageReactionRemoveAll.js +33 -33
  54. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
  55. package/src/client/actions/MessageUpdate.js +26 -26
  56. package/src/client/actions/PresenceUpdate.js +50 -46
  57. package/src/client/actions/StageInstanceCreate.js +28 -28
  58. package/src/client/actions/StageInstanceDelete.js +33 -33
  59. package/src/client/actions/StageInstanceUpdate.js +30 -30
  60. package/src/client/actions/ThreadCreate.js +24 -24
  61. package/src/client/actions/ThreadDelete.js +32 -32
  62. package/src/client/actions/ThreadListSync.js +59 -59
  63. package/src/client/actions/ThreadMemberUpdate.js +30 -30
  64. package/src/client/actions/ThreadMembersUpdate.js +34 -34
  65. package/src/client/actions/TypingStart.js +29 -29
  66. package/src/client/actions/UserUpdate.js +35 -35
  67. package/src/client/actions/VoiceStateUpdate.js +50 -57
  68. package/src/client/actions/WebhooksUpdate.js +20 -20
  69. package/src/client/voice/ClientVoiceManager.js +151 -51
  70. package/src/client/voice/VoiceConnection.js +1249 -0
  71. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  72. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  73. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  74. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  75. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  76. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  77. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  78. package/src/client/voice/player/MediaPlayer.js +321 -0
  79. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  80. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  81. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  82. package/src/client/voice/receiver/PacketHandler.js +260 -0
  83. package/src/client/voice/receiver/Receiver.js +96 -0
  84. package/src/client/voice/receiver/Recorder.js +173 -0
  85. package/src/client/voice/util/Function.js +116 -0
  86. package/src/client/voice/util/PlayInterface.js +122 -0
  87. package/src/client/voice/util/Secretbox.js +64 -0
  88. package/src/client/voice/util/Silence.js +16 -0
  89. package/src/client/voice/util/Socket.js +62 -0
  90. package/src/client/voice/util/VolumeInterface.js +104 -0
  91. package/src/client/websocket/WebSocketManager.js +392 -392
  92. package/src/client/websocket/WebSocketShard.js +907 -906
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
  96. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
  97. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
  100. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
  101. package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
  102. package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
  103. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
  104. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
  105. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
  106. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
  108. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
  109. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
  110. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
  111. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
  112. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
  113. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -53
  114. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
  115. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
  116. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
  117. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
  118. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -20
  119. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
  120. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
  121. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
  122. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
  123. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
  128. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
  129. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
  130. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
  131. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
  132. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
  133. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
  134. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
  135. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
  136. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -0
  138. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -0
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
  142. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
  143. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
  144. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
  145. package/src/client/websocket/handlers/READY.js +121 -80
  146. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
  147. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
  148. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
  149. package/src/client/websocket/handlers/RESUMED.js +14 -14
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
  152. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
  153. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
  154. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
  155. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
  156. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
  157. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
  158. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
  159. package/src/client/websocket/handlers/TYPING_START.js +5 -5
  160. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
  161. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
  162. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
  163. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
  164. package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  166. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
  167. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
  168. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
  169. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
  170. package/src/client/websocket/handlers/index.js +84 -81
  171. package/src/errors/DJSError.js +61 -61
  172. package/src/errors/Messages.js +217 -182
  173. package/src/errors/index.js +4 -4
  174. package/src/index.js +172 -158
  175. package/src/managers/ApplicationCommandManager.js +264 -264
  176. package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
  177. package/src/managers/AutoModerationRuleManager.js +296 -296
  178. package/src/managers/BaseGuildEmojiManager.js +80 -80
  179. package/src/managers/BaseManager.js +19 -19
  180. package/src/managers/BillingManager.js +66 -66
  181. package/src/managers/CachedManager.js +71 -71
  182. package/src/managers/ChannelManager.js +148 -138
  183. package/src/managers/ClientUserSettingManager.js +372 -372
  184. package/src/managers/DataManager.js +61 -61
  185. package/src/managers/GuildBanManager.js +250 -204
  186. package/src/managers/GuildChannelManager.js +488 -504
  187. package/src/managers/GuildEmojiManager.js +171 -171
  188. package/src/managers/GuildEmojiRoleManager.js +118 -118
  189. package/src/managers/GuildForumThreadManager.js +108 -108
  190. package/src/managers/GuildInviteManager.js +213 -213
  191. package/src/managers/GuildManager.js +338 -304
  192. package/src/managers/GuildMemberManager.js +599 -593
  193. package/src/managers/GuildMemberRoleManager.js +195 -191
  194. package/src/managers/GuildScheduledEventManager.js +314 -296
  195. package/src/managers/GuildSettingManager.js +155 -155
  196. package/src/managers/GuildStickerManager.js +179 -179
  197. package/src/managers/GuildTextThreadManager.js +98 -98
  198. package/src/managers/InteractionManager.js +39 -39
  199. package/src/managers/MessageManager.js +423 -391
  200. package/src/managers/PermissionOverwriteManager.js +164 -166
  201. package/src/managers/PresenceManager.js +71 -58
  202. package/src/managers/ReactionManager.js +67 -67
  203. package/src/managers/ReactionUserManager.js +73 -71
  204. package/src/managers/RelationshipManager.js +278 -265
  205. package/src/managers/RoleManager.js +448 -352
  206. package/src/managers/SessionManager.js +66 -0
  207. package/src/managers/StageInstanceManager.js +162 -162
  208. package/src/managers/ThreadManager.js +175 -174
  209. package/src/managers/ThreadMemberManager.js +186 -186
  210. package/src/managers/UserManager.js +136 -146
  211. package/src/managers/UserNoteManager.js +53 -53
  212. package/src/managers/VoiceStateManager.js +59 -37
  213. package/src/rest/APIRequest.js +154 -154
  214. package/src/rest/APIRouter.js +53 -53
  215. package/src/rest/DiscordAPIError.js +119 -104
  216. package/src/rest/HTTPError.js +62 -62
  217. package/src/rest/RESTManager.js +67 -62
  218. package/src/rest/RateLimitError.js +55 -55
  219. package/src/rest/RequestHandler.js +466 -444
  220. package/src/sharding/Shard.js +444 -443
  221. package/src/sharding/ShardClientUtil.js +279 -275
  222. package/src/sharding/ShardingManager.js +319 -318
  223. package/src/structures/AnonymousGuild.js +98 -98
  224. package/src/structures/ApplicationCommand.js +593 -593
  225. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -48
  226. package/src/structures/AutoModerationActionExecution.js +89 -89
  227. package/src/structures/AutoModerationRule.js +294 -294
  228. package/src/structures/AutocompleteInteraction.js +107 -107
  229. package/src/structures/Base.js +43 -43
  230. package/src/structures/BaseCommandInteraction.js +211 -211
  231. package/src/structures/BaseGuild.js +116 -116
  232. package/src/structures/BaseGuildEmoji.js +56 -56
  233. package/src/structures/BaseGuildTextChannel.js +191 -191
  234. package/src/structures/BaseGuildVoiceChannel.js +241 -241
  235. package/src/structures/BaseMessageComponent.js +181 -114
  236. package/src/structures/ButtonInteraction.js +11 -11
  237. package/src/structures/CallState.js +63 -63
  238. package/src/structures/CategoryChannel.js +85 -85
  239. package/src/structures/Channel.js +284 -270
  240. package/src/structures/ClientPresence.js +77 -88
  241. package/src/structures/ClientUser.js +479 -450
  242. package/src/structures/CommandInteraction.js +41 -41
  243. package/src/structures/CommandInteractionOptionResolver.js +276 -276
  244. package/src/structures/ContainerComponent.js +68 -0
  245. package/src/structures/ContextMenuInteraction.js +65 -65
  246. package/src/structures/DMChannel.js +219 -217
  247. package/src/structures/DirectoryChannel.js +20 -20
  248. package/src/structures/Emoji.js +148 -148
  249. package/src/structures/FileComponent.js +49 -0
  250. package/src/structures/ForumChannel.js +31 -261
  251. package/src/structures/GroupDMChannel.js +394 -387
  252. package/src/structures/Guild.js +1643 -1608
  253. package/src/structures/GuildAuditLogs.js +746 -729
  254. package/src/structures/GuildBan.js +59 -59
  255. package/src/structures/GuildBoost.js +108 -108
  256. package/src/structures/GuildChannel.js +470 -468
  257. package/src/structures/GuildEmoji.js +161 -161
  258. package/src/structures/GuildMember.js +636 -568
  259. package/src/structures/GuildPreview.js +191 -191
  260. package/src/structures/GuildPreviewEmoji.js +27 -27
  261. package/src/structures/GuildScheduledEvent.js +536 -441
  262. package/src/structures/GuildTemplate.js +236 -236
  263. package/src/structures/Integration.js +188 -188
  264. package/src/structures/IntegrationApplication.js +96 -96
  265. package/src/structures/Interaction.js +290 -290
  266. package/src/structures/InteractionCollector.js +248 -248
  267. package/src/structures/InteractionWebhook.js +43 -43
  268. package/src/structures/Invite.js +358 -358
  269. package/src/structures/InviteGuild.js +23 -23
  270. package/src/structures/InviteStageInstance.js +86 -86
  271. package/src/structures/MediaChannel.js +11 -0
  272. package/src/structures/MediaGalleryComponent.js +41 -0
  273. package/src/structures/MediaGalleryItem.js +47 -0
  274. package/src/structures/Message.js +1252 -1236
  275. package/src/structures/MessageActionRow.js +105 -103
  276. package/src/structures/MessageAttachment.js +216 -204
  277. package/src/structures/MessageButton.js +166 -165
  278. package/src/structures/MessageCollector.js +146 -146
  279. package/src/structures/MessageComponentInteraction.js +120 -120
  280. package/src/structures/MessageContextMenuInteraction.js +20 -20
  281. package/src/structures/MessageEmbed.js +596 -586
  282. package/src/structures/MessageMentions.js +273 -273
  283. package/src/structures/MessagePayload.js +354 -316
  284. package/src/structures/MessageReaction.js +181 -171
  285. package/src/structures/MessageSelectMenu.js +141 -140
  286. package/src/structures/Modal.js +161 -174
  287. package/src/structures/ModalSubmitFieldsResolver.js +53 -53
  288. package/src/structures/ModalSubmitInteraction.js +119 -119
  289. package/src/structures/NewsChannel.js +32 -32
  290. package/src/structures/OAuth2Guild.js +28 -28
  291. package/src/structures/PermissionOverwrites.js +198 -196
  292. package/src/structures/Poll.js +108 -0
  293. package/src/structures/PollAnswer.js +88 -0
  294. package/src/structures/Presence.js +1105 -443
  295. package/src/structures/ReactionCollector.js +229 -229
  296. package/src/structures/ReactionEmoji.js +31 -31
  297. package/src/structures/Role.js +590 -531
  298. package/src/structures/SectionComponent.js +48 -0
  299. package/src/structures/SelectMenuInteraction.js +21 -21
  300. package/src/structures/SeparatorComponent.js +48 -0
  301. package/src/structures/Session.js +81 -0
  302. package/src/structures/StageChannel.js +104 -104
  303. package/src/structures/StageInstance.js +208 -208
  304. package/src/structures/Sticker.js +310 -310
  305. package/src/structures/StickerPack.js +95 -95
  306. package/src/structures/StoreChannel.js +56 -56
  307. package/src/structures/Team.js +118 -118
  308. package/src/structures/TeamMember.js +80 -71
  309. package/src/structures/TextChannel.js +33 -33
  310. package/src/structures/TextDisplayComponent.js +40 -0
  311. package/src/structures/TextInputComponent.js +132 -131
  312. package/src/structures/ThreadChannel.js +605 -607
  313. package/src/structures/ThreadMember.js +105 -105
  314. package/src/structures/ThreadOnlyChannel.js +249 -0
  315. package/src/structures/ThumbnailComponent.js +57 -0
  316. package/src/structures/Typing.js +74 -74
  317. package/src/structures/UnfurledMediaItem.js +29 -0
  318. package/src/structures/User.js +640 -509
  319. package/src/structures/UserContextMenuInteraction.js +29 -29
  320. package/src/structures/VoiceChannel.js +110 -110
  321. package/src/structures/VoiceChannelEffect.js +69 -0
  322. package/src/structures/VoiceRegion.js +53 -53
  323. package/src/structures/VoiceState.js +354 -341
  324. package/src/structures/WebEmbed.js +373 -373
  325. package/src/structures/Webhook.js +478 -467
  326. package/src/structures/WelcomeChannel.js +60 -60
  327. package/src/structures/WelcomeScreen.js +48 -48
  328. package/src/structures/Widget.js +87 -87
  329. package/src/structures/WidgetMember.js +99 -99
  330. package/src/structures/interfaces/Application.js +825 -313
  331. package/src/structures/interfaces/Collector.js +300 -300
  332. package/src/structures/interfaces/InteractionResponses.js +313 -313
  333. package/src/structures/interfaces/TextBasedChannel.js +759 -721
  334. package/src/util/APITypes.js +59 -0
  335. package/src/util/ActivityFlags.js +44 -44
  336. package/src/util/ApplicationFlags.js +76 -76
  337. package/src/util/AttachmentFlags.js +38 -38
  338. package/src/util/BitField.js +170 -170
  339. package/src/util/ChannelFlags.js +45 -45
  340. package/src/util/Constants.js +1914 -1760
  341. package/src/util/DataResolver.js +146 -145
  342. package/src/util/Formatters.js +228 -228
  343. package/src/util/GuildMemberFlags.js +43 -43
  344. package/src/util/Intents.js +74 -74
  345. package/src/util/InviteFlags.js +34 -29
  346. package/src/util/LimitedCollection.js +131 -131
  347. package/src/util/MessageFlags.js +63 -54
  348. package/src/util/Options.js +358 -342
  349. package/src/util/Permissions.js +202 -192
  350. package/src/util/PremiumUsageFlags.js +31 -31
  351. package/src/util/PurchasedFlags.js +33 -33
  352. package/src/util/RemoteAuth.js +382 -379
  353. package/src/util/RoleFlags.js +37 -37
  354. package/src/util/SnowflakeUtil.js +92 -92
  355. package/src/util/Speaking.js +33 -0
  356. package/src/util/Sweepers.js +466 -466
  357. package/src/util/SystemChannelFlags.js +55 -55
  358. package/src/util/ThreadMemberFlags.js +30 -30
  359. package/src/util/UserFlags.js +104 -104
  360. package/src/util/Util.js +1048 -803
  361. package/typings/enums.d.ts +439 -291
  362. package/typings/index.d.ts +8247 -7390
  363. package/typings/rawDataTypes.d.ts +403 -342
  364. package/src/structures/RichPresence.js +0 -702
@@ -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;