discord-sb.js 1.0.0

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 (366) hide show
  1. package/LICENSE +674 -0
  2. package/README.md +2 -0
  3. package/package.json +91 -0
  4. package/src/WebSocket.js +39 -0
  5. package/src/client/BaseClient.js +86 -0
  6. package/src/client/Client.js +978 -0
  7. package/src/client/WebhookClient.js +61 -0
  8. package/src/client/actions/Action.js +116 -0
  9. package/src/client/actions/ActionsManager.js +80 -0
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  11. package/src/client/actions/AutoModerationActionExecution.js +27 -0
  12. package/src/client/actions/AutoModerationRuleCreate.js +28 -0
  13. package/src/client/actions/AutoModerationRuleDelete.js +32 -0
  14. package/src/client/actions/AutoModerationRuleUpdate.js +30 -0
  15. package/src/client/actions/ChannelCreate.js +23 -0
  16. package/src/client/actions/ChannelDelete.js +39 -0
  17. package/src/client/actions/ChannelUpdate.js +43 -0
  18. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
  19. package/src/client/actions/GuildBanAdd.js +20 -0
  20. package/src/client/actions/GuildBanRemove.js +25 -0
  21. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
  22. package/src/client/actions/GuildDelete.js +65 -0
  23. package/src/client/actions/GuildEmojiCreate.js +20 -0
  24. package/src/client/actions/GuildEmojiDelete.js +21 -0
  25. package/src/client/actions/GuildEmojiUpdate.js +20 -0
  26. package/src/client/actions/GuildEmojisUpdate.js +34 -0
  27. package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
  28. package/src/client/actions/GuildMemberRemove.js +33 -0
  29. package/src/client/actions/GuildMemberUpdate.js +44 -0
  30. package/src/client/actions/GuildRoleCreate.js +25 -0
  31. package/src/client/actions/GuildRoleDelete.js +31 -0
  32. package/src/client/actions/GuildRoleUpdate.js +39 -0
  33. package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
  34. package/src/client/actions/GuildScheduledEventCreate.js +27 -0
  35. package/src/client/actions/GuildScheduledEventDelete.js +31 -0
  36. package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
  37. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
  38. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
  39. package/src/client/actions/GuildStickerCreate.js +20 -0
  40. package/src/client/actions/GuildStickerDelete.js +21 -0
  41. package/src/client/actions/GuildStickerUpdate.js +20 -0
  42. package/src/client/actions/GuildStickersUpdate.js +34 -0
  43. package/src/client/actions/GuildUpdate.js +33 -0
  44. package/src/client/actions/InviteCreate.js +28 -0
  45. package/src/client/actions/InviteDelete.js +30 -0
  46. package/src/client/actions/MessageCreate.js +50 -0
  47. package/src/client/actions/MessageDelete.js +32 -0
  48. package/src/client/actions/MessageDeleteBulk.js +46 -0
  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 -0
  52. package/src/client/actions/MessageReactionRemove.js +50 -0
  53. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  54. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  55. package/src/client/actions/MessageUpdate.js +26 -0
  56. package/src/client/actions/PresenceUpdate.js +50 -0
  57. package/src/client/actions/StageInstanceCreate.js +28 -0
  58. package/src/client/actions/StageInstanceDelete.js +33 -0
  59. package/src/client/actions/StageInstanceUpdate.js +30 -0
  60. package/src/client/actions/ThreadCreate.js +24 -0
  61. package/src/client/actions/ThreadDelete.js +32 -0
  62. package/src/client/actions/ThreadListSync.js +59 -0
  63. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  64. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  65. package/src/client/actions/TypingStart.js +29 -0
  66. package/src/client/actions/UserUpdate.js +35 -0
  67. package/src/client/actions/VoiceStateUpdate.js +50 -0
  68. package/src/client/actions/WebhooksUpdate.js +20 -0
  69. package/src/client/voice/ClientVoiceManager.js +151 -0
  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 -0
  92. package/src/client/websocket/WebSocketShard.js +907 -0
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  96. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  97. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  100. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  101. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  102. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  103. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  104. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  105. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  106. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -0
  108. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  109. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  110. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  111. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  112. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  113. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -0
  114. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  115. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  116. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  117. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  118. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  119. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  120. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  121. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  122. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  123. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  128. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  129. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  130. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  131. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -0
  132. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  133. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  134. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  135. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  136. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  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 -0
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  142. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  143. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  144. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  145. package/src/client/websocket/handlers/READY.js +121 -0
  146. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -0
  147. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -0
  148. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -0
  149. package/src/client/websocket/handlers/RESUMED.js +14 -0
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  152. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  153. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  154. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  155. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  156. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  157. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  158. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  159. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  160. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -0
  161. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  162. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -0
  163. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -0
  164. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  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 -0
  167. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  168. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  169. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  170. package/src/client/websocket/handlers/index.js +84 -0
  171. package/src/errors/DJSError.js +61 -0
  172. package/src/errors/Messages.js +217 -0
  173. package/src/errors/index.js +4 -0
  174. package/src/index.js +172 -0
  175. package/src/managers/ApplicationCommandManager.js +264 -0
  176. package/src/managers/ApplicationCommandPermissionsManager.js +417 -0
  177. package/src/managers/AutoModerationRuleManager.js +296 -0
  178. package/src/managers/BaseGuildEmojiManager.js +80 -0
  179. package/src/managers/BaseManager.js +19 -0
  180. package/src/managers/BillingManager.js +66 -0
  181. package/src/managers/CachedManager.js +71 -0
  182. package/src/managers/ChannelManager.js +148 -0
  183. package/src/managers/ClientUserSettingManager.js +372 -0
  184. package/src/managers/DataManager.js +61 -0
  185. package/src/managers/DeveloperManager.js +254 -0
  186. package/src/managers/GuildBanManager.js +250 -0
  187. package/src/managers/GuildChannelManager.js +488 -0
  188. package/src/managers/GuildEmojiManager.js +171 -0
  189. package/src/managers/GuildEmojiRoleManager.js +118 -0
  190. package/src/managers/GuildForumThreadManager.js +108 -0
  191. package/src/managers/GuildInviteManager.js +213 -0
  192. package/src/managers/GuildManager.js +338 -0
  193. package/src/managers/GuildMemberManager.js +599 -0
  194. package/src/managers/GuildMemberRoleManager.js +195 -0
  195. package/src/managers/GuildScheduledEventManager.js +314 -0
  196. package/src/managers/GuildSettingManager.js +155 -0
  197. package/src/managers/GuildStickerManager.js +179 -0
  198. package/src/managers/GuildTextThreadManager.js +98 -0
  199. package/src/managers/InteractionManager.js +39 -0
  200. package/src/managers/MessageManager.js +423 -0
  201. package/src/managers/PermissionOverwriteManager.js +164 -0
  202. package/src/managers/PresenceManager.js +71 -0
  203. package/src/managers/QuestManager.js +353 -0
  204. package/src/managers/ReactionManager.js +67 -0
  205. package/src/managers/ReactionUserManager.js +73 -0
  206. package/src/managers/RelationshipManager.js +278 -0
  207. package/src/managers/RoleManager.js +448 -0
  208. package/src/managers/SessionManager.js +66 -0
  209. package/src/managers/StageInstanceManager.js +162 -0
  210. package/src/managers/ThreadManager.js +175 -0
  211. package/src/managers/ThreadMemberManager.js +186 -0
  212. package/src/managers/UserManager.js +136 -0
  213. package/src/managers/UserNoteManager.js +53 -0
  214. package/src/managers/VoiceStateManager.js +59 -0
  215. package/src/rest/APIRequest.js +154 -0
  216. package/src/rest/APIRouter.js +53 -0
  217. package/src/rest/DiscordAPIError.js +119 -0
  218. package/src/rest/HTTPError.js +62 -0
  219. package/src/rest/RESTManager.js +67 -0
  220. package/src/rest/RateLimitError.js +55 -0
  221. package/src/rest/RequestHandler.js +466 -0
  222. package/src/sharding/Shard.js +444 -0
  223. package/src/sharding/ShardClientUtil.js +279 -0
  224. package/src/sharding/ShardingManager.js +319 -0
  225. package/src/structures/AnonymousGuild.js +98 -0
  226. package/src/structures/ApplicationCommand.js +593 -0
  227. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -0
  228. package/src/structures/AutoModerationActionExecution.js +89 -0
  229. package/src/structures/AutoModerationRule.js +294 -0
  230. package/src/structures/AutocompleteInteraction.js +107 -0
  231. package/src/structures/Base.js +43 -0
  232. package/src/structures/BaseCommandInteraction.js +211 -0
  233. package/src/structures/BaseGuild.js +116 -0
  234. package/src/structures/BaseGuildEmoji.js +56 -0
  235. package/src/structures/BaseGuildTextChannel.js +191 -0
  236. package/src/structures/BaseGuildVoiceChannel.js +241 -0
  237. package/src/structures/BaseMessageComponent.js +181 -0
  238. package/src/structures/ButtonInteraction.js +11 -0
  239. package/src/structures/CallState.js +63 -0
  240. package/src/structures/CategoryChannel.js +85 -0
  241. package/src/structures/Channel.js +284 -0
  242. package/src/structures/ClientPresence.js +77 -0
  243. package/src/structures/ClientUser.js +655 -0
  244. package/src/structures/CommandInteraction.js +41 -0
  245. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  246. package/src/structures/ContainerComponent.js +68 -0
  247. package/src/structures/ContextMenuInteraction.js +65 -0
  248. package/src/structures/DMChannel.js +219 -0
  249. package/src/structures/DirectoryChannel.js +20 -0
  250. package/src/structures/Emoji.js +148 -0
  251. package/src/structures/FileComponent.js +49 -0
  252. package/src/structures/ForumChannel.js +31 -0
  253. package/src/structures/GroupDMChannel.js +394 -0
  254. package/src/structures/Guild.js +1791 -0
  255. package/src/structures/GuildAuditLogs.js +746 -0
  256. package/src/structures/GuildBan.js +59 -0
  257. package/src/structures/GuildBoost.js +108 -0
  258. package/src/structures/GuildChannel.js +470 -0
  259. package/src/structures/GuildEmoji.js +161 -0
  260. package/src/structures/GuildMember.js +636 -0
  261. package/src/structures/GuildPreview.js +191 -0
  262. package/src/structures/GuildPreviewEmoji.js +27 -0
  263. package/src/structures/GuildScheduledEvent.js +536 -0
  264. package/src/structures/GuildTemplate.js +236 -0
  265. package/src/structures/Integration.js +188 -0
  266. package/src/structures/IntegrationApplication.js +96 -0
  267. package/src/structures/Interaction.js +290 -0
  268. package/src/structures/InteractionCollector.js +248 -0
  269. package/src/structures/InteractionWebhook.js +43 -0
  270. package/src/structures/Invite.js +358 -0
  271. package/src/structures/InviteGuild.js +23 -0
  272. package/src/structures/InviteStageInstance.js +86 -0
  273. package/src/structures/MediaChannel.js +11 -0
  274. package/src/structures/MediaGalleryComponent.js +41 -0
  275. package/src/structures/MediaGalleryItem.js +47 -0
  276. package/src/structures/Message.js +1252 -0
  277. package/src/structures/MessageActionRow.js +105 -0
  278. package/src/structures/MessageAttachment.js +216 -0
  279. package/src/structures/MessageButton.js +166 -0
  280. package/src/structures/MessageCollector.js +146 -0
  281. package/src/structures/MessageComponentInteraction.js +120 -0
  282. package/src/structures/MessageContextMenuInteraction.js +20 -0
  283. package/src/structures/MessageEmbed.js +596 -0
  284. package/src/structures/MessageMentions.js +273 -0
  285. package/src/structures/MessagePayload.js +354 -0
  286. package/src/structures/MessageReaction.js +181 -0
  287. package/src/structures/MessageSelectMenu.js +141 -0
  288. package/src/structures/Modal.js +161 -0
  289. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  290. package/src/structures/ModalSubmitInteraction.js +119 -0
  291. package/src/structures/NewsChannel.js +32 -0
  292. package/src/structures/OAuth2Guild.js +28 -0
  293. package/src/structures/PermissionOverwrites.js +198 -0
  294. package/src/structures/Poll.js +108 -0
  295. package/src/structures/PollAnswer.js +88 -0
  296. package/src/structures/Presence.js +1157 -0
  297. package/src/structures/ReactionCollector.js +229 -0
  298. package/src/structures/ReactionEmoji.js +31 -0
  299. package/src/structures/Role.js +590 -0
  300. package/src/structures/SectionComponent.js +48 -0
  301. package/src/structures/SelectMenuInteraction.js +21 -0
  302. package/src/structures/SeparatorComponent.js +48 -0
  303. package/src/structures/Session.js +81 -0
  304. package/src/structures/StageChannel.js +104 -0
  305. package/src/structures/StageInstance.js +208 -0
  306. package/src/structures/Sticker.js +310 -0
  307. package/src/structures/StickerPack.js +95 -0
  308. package/src/structures/StoreChannel.js +56 -0
  309. package/src/structures/Team.js +118 -0
  310. package/src/structures/TeamMember.js +80 -0
  311. package/src/structures/TextChannel.js +33 -0
  312. package/src/structures/TextDisplayComponent.js +40 -0
  313. package/src/structures/TextInputComponent.js +132 -0
  314. package/src/structures/ThreadChannel.js +605 -0
  315. package/src/structures/ThreadMember.js +105 -0
  316. package/src/structures/ThreadOnlyChannel.js +249 -0
  317. package/src/structures/ThumbnailComponent.js +57 -0
  318. package/src/structures/Typing.js +74 -0
  319. package/src/structures/UnfurledMediaItem.js +29 -0
  320. package/src/structures/User.js +640 -0
  321. package/src/structures/UserContextMenuInteraction.js +29 -0
  322. package/src/structures/VoiceChannel.js +110 -0
  323. package/src/structures/VoiceChannelEffect.js +69 -0
  324. package/src/structures/VoiceRegion.js +53 -0
  325. package/src/structures/VoiceState.js +354 -0
  326. package/src/structures/WebEmbed.js +373 -0
  327. package/src/structures/Webhook.js +478 -0
  328. package/src/structures/WelcomeChannel.js +60 -0
  329. package/src/structures/WelcomeScreen.js +48 -0
  330. package/src/structures/Widget.js +87 -0
  331. package/src/structures/WidgetMember.js +99 -0
  332. package/src/structures/interfaces/Application.js +953 -0
  333. package/src/structures/interfaces/Collector.js +300 -0
  334. package/src/structures/interfaces/InteractionResponses.js +313 -0
  335. package/src/structures/interfaces/TextBasedChannel.js +821 -0
  336. package/src/util/APITypes.js +59 -0
  337. package/src/util/ActivityFlags.js +44 -0
  338. package/src/util/ApplicationFlags.js +76 -0
  339. package/src/util/AttachmentFlags.js +38 -0
  340. package/src/util/BitField.js +170 -0
  341. package/src/util/ChannelFlags.js +45 -0
  342. package/src/util/Constants.js +1914 -0
  343. package/src/util/DataResolver.js +146 -0
  344. package/src/util/Formatters.js +228 -0
  345. package/src/util/GuildMemberFlags.js +43 -0
  346. package/src/util/Intents.js +74 -0
  347. package/src/util/InviteFlags.js +34 -0
  348. package/src/util/LimitedCollection.js +131 -0
  349. package/src/util/MessageFlags.js +63 -0
  350. package/src/util/Options.js +358 -0
  351. package/src/util/Permissions.js +202 -0
  352. package/src/util/PremiumUsageFlags.js +31 -0
  353. package/src/util/PurchasedFlags.js +33 -0
  354. package/src/util/RemoteAuth.js +415 -0
  355. package/src/util/RoleFlags.js +37 -0
  356. package/src/util/SnowflakeUtil.js +92 -0
  357. package/src/util/Speaking.js +33 -0
  358. package/src/util/Sweepers.js +466 -0
  359. package/src/util/SystemChannelFlags.js +55 -0
  360. package/src/util/ThreadMemberFlags.js +30 -0
  361. package/src/util/UserFlags.js +104 -0
  362. package/src/util/Util.js +1048 -0
  363. package/typings/enums.d.ts +439 -0
  364. package/typings/index.d.ts +8505 -0
  365. package/typings/index.test-d.ts +0 -0
  366. package/typings/rawDataTypes.d.ts +403 -0
@@ -0,0 +1,605 @@
1
+ 'use strict';
2
+
3
+ const { Channel } = require('./Channel');
4
+ const TextBasedChannel = require('./interfaces/TextBasedChannel');
5
+ const { RangeError } = require('../errors');
6
+ const MessageManager = require('../managers/MessageManager');
7
+ const ThreadMemberManager = require('../managers/ThreadMemberManager');
8
+ const ChannelFlags = require('../util/ChannelFlags');
9
+ const Permissions = require('../util/Permissions');
10
+ const { resolveAutoArchiveMaxLimit } = require('../util/Util');
11
+
12
+ /**
13
+ * Represents a thread channel on Discord.
14
+ * @extends {Channel}
15
+ * @implements {TextBasedChannel}
16
+ */
17
+ class ThreadChannel extends Channel {
18
+ constructor(guild, data, client) {
19
+ super(guild?.client ?? client, data, false);
20
+
21
+ /**
22
+ * The guild the thread is in
23
+ * @type {Guild}
24
+ */
25
+ this.guild = guild;
26
+
27
+ /**
28
+ * The id of the member who created this thread
29
+ * @type {Snowflake}
30
+ */
31
+ this.ownerId = data.owner_id;
32
+
33
+ /**
34
+ * The id of the guild the channel is in
35
+ * @type {Snowflake}
36
+ */
37
+ this.guildId = guild?.id ?? data.guild_id;
38
+
39
+ /**
40
+ * A manager of the messages sent to this thread
41
+ * @type {MessageManager}
42
+ */
43
+ this.messages = new MessageManager(this);
44
+
45
+ /**
46
+ * A manager of the members that are part of this thread
47
+ * @type {ThreadMemberManager}
48
+ */
49
+ this.members = new ThreadMemberManager(this);
50
+ if (data) this._patch(data);
51
+ }
52
+
53
+ _patch(data, partial = false) {
54
+ super._patch(data);
55
+
56
+ if ('name' in data) {
57
+ /**
58
+ * The name of the thread
59
+ * @type {string}
60
+ */
61
+ this.name = data.name;
62
+ }
63
+
64
+ if ('guild_id' in data) {
65
+ this.guildId = data.guild_id;
66
+ }
67
+
68
+ if ('parent_id' in data) {
69
+ /**
70
+ * The id of the parent channel of this thread
71
+ * @type {?Snowflake}
72
+ */
73
+ this.parentId = data.parent_id;
74
+ } else {
75
+ this.parentId ??= null;
76
+ }
77
+
78
+ if ('thread_metadata' in data) {
79
+ /**
80
+ * Whether the thread is locked
81
+ * @type {?boolean}
82
+ */
83
+ this.locked = data.thread_metadata.locked ?? false;
84
+
85
+ /**
86
+ * Whether members without `MANAGE_THREADS` can invite other members without `MANAGE_THREADS`
87
+ * <info>Always `null` in public threads</info>
88
+ * @type {?boolean}
89
+ */
90
+ this.invitable = this.type === 'GUILD_PRIVATE_THREAD' ? data.thread_metadata.invitable ?? false : null;
91
+
92
+ /**
93
+ * Whether the thread is archived
94
+ * @type {?boolean}
95
+ */
96
+ this.archived = data.thread_metadata.archived;
97
+
98
+ /**
99
+ * The amount of time (in minutes) after which the thread will automatically archive in case of no recent activity
100
+ * @type {?number}
101
+ */
102
+ this.autoArchiveDuration = data.thread_metadata.auto_archive_duration;
103
+
104
+ /**
105
+ * The timestamp when the thread's archive status was last changed
106
+ * <info>If the thread was never archived or unarchived, this is the timestamp at which the thread was
107
+ * created</info>
108
+ * @type {?number}
109
+ */
110
+ this.archiveTimestamp = data.thread_metadata?.archive_timestamp
111
+ ? Date.parse(data.thread_metadata.archive_timestamp)
112
+ : null;
113
+
114
+ if ('create_timestamp' in data.thread_metadata) {
115
+ // Note: this is needed because we can't assign directly to getters
116
+ this._createdTimestamp = Date.parse(data.thread_metadata.create_timestamp);
117
+ }
118
+ } else {
119
+ this.locked ??= null;
120
+ this.archived ??= null;
121
+ this.autoArchiveDuration ??= null;
122
+ this.archiveTimestamp ??= null;
123
+ this.invitable ??= null;
124
+ }
125
+
126
+ this._createdTimestamp ??= this.type === 'GUILD_PRIVATE_THREAD' ? super.createdTimestamp : null;
127
+
128
+ if ('last_message_id' in data) {
129
+ /**
130
+ * The last message id sent in this thread, if one was sent
131
+ * @type {?Snowflake}
132
+ */
133
+ this.lastMessageId = data.last_message_id;
134
+ } else {
135
+ this.lastMessageId ??= null;
136
+ }
137
+
138
+ if ('last_pin_timestamp' in data) {
139
+ /**
140
+ * The timestamp when the last pinned message was pinned, if there was one
141
+ * @type {?number}
142
+ */
143
+ this.lastPinTimestamp = data.last_pin_timestamp ? new Date(data.last_pin_timestamp).getTime() : null;
144
+ } else {
145
+ this.lastPinTimestamp ??= null;
146
+ }
147
+
148
+ if ('rate_limit_per_user' in data || !partial) {
149
+ /**
150
+ * The rate limit per user (slowmode) for this thread in seconds
151
+ * @type {?number}
152
+ */
153
+ this.rateLimitPerUser = data.rate_limit_per_user ?? 0;
154
+ } else {
155
+ this.rateLimitPerUser ??= null;
156
+ }
157
+
158
+ if ('message_count' in data) {
159
+ /**
160
+ * <info>Threads created before July 1, 2022 may have an inaccurate count.
161
+ * If you need an approximate value higher than that, use `ThreadChannel#messages.cache.size`</info>
162
+ * @type {?number}
163
+ */
164
+ this.messageCount = data.message_count;
165
+ } else {
166
+ this.messageCount ??= null;
167
+ }
168
+
169
+ if ('member_count' in data) {
170
+ /**
171
+ * The approximate count of users in this thread
172
+ * <info>This stops counting at 50. If you need an approximate value higher than that, use
173
+ * `ThreadChannel#members.cache.size`</info>
174
+ * @type {?number}
175
+ */
176
+ this.memberCount = data.member_count;
177
+ } else {
178
+ this.memberCount ??= null;
179
+ }
180
+
181
+ if ('total_message_sent' in data) {
182
+ /**
183
+ * The number of messages ever sent in a thread, similar to {@link ThreadChannel#messageCount} except it
184
+ * will not decrement whenever a message is deleted
185
+ * @type {?number}
186
+ */
187
+ this.totalMessageSent = data.total_message_sent;
188
+ } else {
189
+ this.totalMessageSent ??= null;
190
+ }
191
+
192
+ if ('applied_tags' in data) {
193
+ /**
194
+ * The tags applied to this thread
195
+ * @type {Snowflake[]}
196
+ */
197
+ this.appliedTags = data.applied_tags;
198
+ } else {
199
+ this.appliedTags ??= [];
200
+ }
201
+
202
+ if (data.member && this.client.user) this.members._add({ user_id: this.client.user.id, ...data.member });
203
+ if (data.messages) for (const message of data.messages) this.messages._add(message);
204
+ }
205
+
206
+ /**
207
+ * The timestamp when this thread was created. This isn't available for threads
208
+ * created before 2022-01-09
209
+ * @type {?number}
210
+ * @readonly
211
+ */
212
+ get createdTimestamp() {
213
+ return this._createdTimestamp;
214
+ }
215
+
216
+ /**
217
+ * A collection of associated guild member objects of this thread's members
218
+ * @type {Collection<Snowflake, GuildMember>}
219
+ * @readonly
220
+ */
221
+ get guildMembers() {
222
+ return this.members.cache.mapValues(member => member.guildMember);
223
+ }
224
+
225
+ /**
226
+ * The time at which this thread's archive status was last changed
227
+ * <info>If the thread was never archived or unarchived, this is the time at which the thread was created</info>
228
+ * @type {?Date}
229
+ * @readonly
230
+ */
231
+ get archivedAt() {
232
+ if (!this.archiveTimestamp) return null;
233
+ return new Date(this.archiveTimestamp);
234
+ }
235
+
236
+ /**
237
+ * The time the thread was created at
238
+ * @type {?Date}
239
+ * @readonly
240
+ */
241
+ get createdAt() {
242
+ return this.createdTimestamp && new Date(this.createdTimestamp);
243
+ }
244
+
245
+ /**
246
+ * The parent channel of this thread
247
+ * @type {?(NewsChannel|TextChannel|ForumChannel|MediaChannel)}
248
+ * @readonly
249
+ */
250
+ get parent() {
251
+ return this.guild.channels.resolve(this.parentId);
252
+ }
253
+
254
+ /**
255
+ * Makes the client user join the thread.
256
+ * @returns {Promise<ThreadChannel>}
257
+ */
258
+ async join() {
259
+ await this.members.add('@me');
260
+ return this;
261
+ }
262
+
263
+ /**
264
+ * Makes the client user leave the thread.
265
+ * @returns {Promise<ThreadChannel>}
266
+ */
267
+ async leave() {
268
+ await this.members.remove('@me');
269
+ return this;
270
+ }
271
+
272
+ /**
273
+ * Gets the overall set of permissions for a member or role in this thread's parent channel, taking overwrites into
274
+ * account.
275
+ * @param {GuildMemberResolvable|RoleResolvable} memberOrRole The member or role to obtain the overall permissions for
276
+ * @param {boolean} [checkAdmin=true] Whether having `ADMINISTRATOR` will return all permissions
277
+ * @returns {?Readonly<Permissions>}
278
+ */
279
+ permissionsFor(memberOrRole, checkAdmin) {
280
+ return this.parent?.permissionsFor(memberOrRole, checkAdmin) ?? null;
281
+ }
282
+
283
+ /**
284
+ * Fetches the owner of this thread. If the thread member object isn't needed,
285
+ * use {@link ThreadChannel#ownerId} instead.
286
+ * @param {BaseFetchOptions} [options] The options for fetching the member
287
+ * @returns {Promise<?ThreadMember>}
288
+ */
289
+ async fetchOwner({ cache = true, force = false } = {}) {
290
+ if (!force) {
291
+ const existing = this.members.cache.get(this.ownerId);
292
+ if (existing) return existing;
293
+ }
294
+
295
+ // We cannot fetch a single thread member, as of this commit's date, Discord API responds with 405
296
+ const members = await this.members.fetch(cache);
297
+ return members.get(this.ownerId) ?? null;
298
+ }
299
+
300
+ /**
301
+ * Fetches the message that started this thread, if any.
302
+ * <info>The `Promise` will reject if the original message in a forum post is deleted
303
+ * or when the original message in the parent channel is deleted.
304
+ * If you just need the id of that message, use {@link ThreadChannel#id} instead.</info>
305
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
306
+ * @returns {Promise<Message|null>}
307
+ */
308
+ // eslint-disable-next-line require-await
309
+ async fetchStarterMessage(options) {
310
+ const channel = this.parent?.type === 'GUILD_FORUM' ? this : this.parent;
311
+ return channel?.messages.fetch(this.id, options) ?? null;
312
+ }
313
+
314
+ /**
315
+ * The options used to edit a thread channel
316
+ * @typedef {Object} ThreadEditData
317
+ * @property {string} [name] The new name for the thread
318
+ * @property {boolean} [archived] Whether the thread is archived
319
+ * @property {ThreadAutoArchiveDuration} [autoArchiveDuration] The amount of time (in minutes) after which the thread
320
+ * should automatically archive in case of no recent activity
321
+ * @property {number} [rateLimitPerUser] The rate limit per user (slowmode) for the thread in seconds
322
+ * @property {boolean} [locked] Whether the thread is locked
323
+ * @property {boolean} [invitable] Whether non-moderators can add other non-moderators to a thread
324
+ * <info>Can only be edited on `GUILD_PRIVATE_THREAD`</info>
325
+ * @property {Snowflake[]} [appliedTags] The tags to apply to the thread
326
+ * @property {ChannelFlagsResolvable} [flags] The flags to set on the channel
327
+ */
328
+
329
+ /**
330
+ * Edits this thread.
331
+ * @param {ThreadEditData} data The new data for this thread
332
+ * @param {string} [reason] Reason for editing this thread
333
+ * @returns {Promise<ThreadChannel>}
334
+ * @example
335
+ * // Edit a thread
336
+ * thread.edit({ name: 'new-thread' })
337
+ * .then(editedThread => console.log(editedThread))
338
+ * .catch(console.error);
339
+ */
340
+ async edit(data, reason) {
341
+ let autoArchiveDuration = data.autoArchiveDuration;
342
+ if (autoArchiveDuration === 'MAX') autoArchiveDuration = resolveAutoArchiveMaxLimit(this.guild);
343
+
344
+ const newData = await this.client.api.channels(this.id).patch({
345
+ data: {
346
+ name: data.name,
347
+ archived: data.archived,
348
+ auto_archive_duration: autoArchiveDuration,
349
+ rate_limit_per_user: data.rateLimitPerUser,
350
+ locked: data.locked,
351
+ invitable: this.type === 'GUILD_PRIVATE_THREAD' ? data.invitable : undefined,
352
+ applied_tags: data.appliedTags,
353
+ flags: 'flags' in data ? ChannelFlags.resolve(data.flags) : undefined,
354
+ },
355
+ reason,
356
+ });
357
+
358
+ return this.client.actions.ChannelUpdate.handle(newData).updated;
359
+ }
360
+
361
+ /**
362
+ * Sets whether the thread is archived.
363
+ * @param {boolean} [archived=true] Whether the thread is archived
364
+ * @param {string} [reason] Reason for archiving or unarchiving
365
+ * @returns {Promise<ThreadChannel>}
366
+ * @example
367
+ * // Archive the thread
368
+ * thread.setArchived(true)
369
+ * .then(newThread => console.log(`Thread is now ${newThread.archived ? 'archived' : 'active'}`))
370
+ * .catch(console.error);
371
+ */
372
+ setArchived(archived = true, reason) {
373
+ return this.edit({ archived }, reason);
374
+ }
375
+
376
+ /**
377
+ * Sets the duration after which the thread will automatically archive in case of no recent activity.
378
+ * @param {ThreadAutoArchiveDuration} autoArchiveDuration The amount of time (in minutes) after which the thread
379
+ * should automatically archive in case of no recent activity
380
+ * @param {string} [reason] Reason for changing the auto archive duration
381
+ * @returns {Promise<ThreadChannel>}
382
+ * @example
383
+ * // Set the thread's auto archive time to 1 hour
384
+ * thread.setAutoArchiveDuration(60)
385
+ * .then(newThread => {
386
+ * console.log(`Thread will now archive after ${newThread.autoArchiveDuration} minutes of inactivity`);
387
+ * });
388
+ * .catch(console.error);
389
+ */
390
+ setAutoArchiveDuration(autoArchiveDuration, reason) {
391
+ return this.edit({ autoArchiveDuration }, reason);
392
+ }
393
+
394
+ /**
395
+ * Sets whether members without the `MANAGE_THREADS` permission can invite other members without the
396
+ * `MANAGE_THREADS` permission to this thread.
397
+ * @param {boolean} [invitable=true] Whether non-moderators can invite non-moderators to this thread
398
+ * @param {string} [reason] Reason for changing invite
399
+ * @returns {Promise<ThreadChannel>}
400
+ */
401
+ async setInvitable(invitable = true, reason) {
402
+ if (this.type !== 'GUILD_PRIVATE_THREAD') throw new RangeError('THREAD_INVITABLE_TYPE', this.type);
403
+ return this.edit({ invitable }, reason);
404
+ }
405
+
406
+ /**
407
+ * Sets whether the thread can be **unarchived** by anyone with `SEND_MESSAGES` permission.
408
+ * When a thread is locked only members with `MANAGE_THREADS` can unarchive it.
409
+ * @param {boolean} [locked=true] Whether the thread is locked
410
+ * @param {string} [reason] Reason for locking or unlocking the thread
411
+ * @returns {Promise<ThreadChannel>}
412
+ * @example
413
+ * // Set the thread to locked
414
+ * thread.setLocked(true)
415
+ * .then(newThread => console.log(`Thread is now ${newThread.locked ? 'locked' : 'unlocked'}`))
416
+ * .catch(console.error);
417
+ */
418
+ setLocked(locked = true, reason) {
419
+ return this.edit({ locked }, reason);
420
+ }
421
+
422
+ /**
423
+ * Sets a new name for this thread.
424
+ * @param {string} name The new name for the thread
425
+ * @param {string} [reason] Reason for changing the thread's name
426
+ * @returns {Promise<ThreadChannel>}
427
+ * @example
428
+ * // Change the thread's name
429
+ * thread.setName('not_general')
430
+ * .then(newThread => console.log(`Thread's new name is ${newThread.name}`))
431
+ * .catch(console.error);
432
+ */
433
+ setName(name, reason) {
434
+ return this.edit({ name }, reason);
435
+ }
436
+
437
+ /**
438
+ * Sets the rate limit per user (slowmode) for this thread.
439
+ * @param {number} rateLimitPerUser The new rate limit in seconds
440
+ * @param {string} [reason] Reason for changing the thread's rate limit
441
+ * @returns {Promise<ThreadChannel>}
442
+ */
443
+ setRateLimitPerUser(rateLimitPerUser, reason) {
444
+ return this.edit({ rateLimitPerUser }, reason);
445
+ }
446
+
447
+ /**
448
+ * Pins this thread from the forum channel.
449
+ * @param {string} [reason] Reason for pinning
450
+ * @returns {Promise<ThreadChannel>}
451
+ */
452
+ pin(reason) {
453
+ return this.edit({ flags: this.flags.add(ChannelFlags.FLAGS.PINNED) }, reason);
454
+ }
455
+
456
+ /**
457
+ * Unpins this thread from the forum channel.
458
+ * @param {string} [reason] Reason for unpinning
459
+ * @returns {Promise<ThreadChannel>}
460
+ */
461
+ unpin(reason) {
462
+ return this.edit({ flags: this.flags.remove(ChannelFlags.FLAGS.PINNED) }, reason);
463
+ }
464
+
465
+ /**
466
+ * Set the applied tags for this channel (only applicable to forum threads)
467
+ * @param {Snowflake[]} appliedTags The tags to set for this channel
468
+ * @param {string} [reason] Reason for changing the thread's applied tags
469
+ * @returns {Promise<ThreadChannel>}
470
+ */
471
+ setAppliedTags(appliedTags, reason) {
472
+ return this.edit({ appliedTags }, reason);
473
+ }
474
+
475
+ /**
476
+ * Whether the client user is a member of the thread.
477
+ * @type {boolean}
478
+ * @readonly
479
+ */
480
+ get joined() {
481
+ return this.members.cache.has(this.client.user?.id);
482
+ }
483
+
484
+ /**
485
+ * Whether the thread is editable by the client user (name, archived, autoArchiveDuration)
486
+ * @type {boolean}
487
+ * @readonly
488
+ */
489
+ get editable() {
490
+ return (
491
+ (this.ownerId === this.client.user.id && (this.type !== 'GUILD_PRIVATE_THREAD' || this.joined)) || this.manageable
492
+ );
493
+ }
494
+
495
+ /**
496
+ * Whether the thread is joinable by the client user
497
+ * @type {boolean}
498
+ * @readonly
499
+ */
500
+ get joinable() {
501
+ return (
502
+ !this.archived &&
503
+ !this.joined &&
504
+ this.permissionsFor(this.client.user)?.has(
505
+ this.type === 'GUILD_PRIVATE_THREAD' ? Permissions.FLAGS.MANAGE_THREADS : Permissions.FLAGS.VIEW_CHANNEL,
506
+ false,
507
+ )
508
+ );
509
+ }
510
+
511
+ /**
512
+ * Whether the thread is manageable by the client user, for deleting or editing rateLimitPerUser or locked.
513
+ * @type {boolean}
514
+ * @readonly
515
+ */
516
+ get manageable() {
517
+ const permissions = this.permissionsFor(this.client.user);
518
+ if (!permissions) return false;
519
+ // This flag allows managing even if timed out
520
+ if (permissions.has(Permissions.FLAGS.ADMINISTRATOR, false)) return true;
521
+
522
+ return (
523
+ this.guild.members.me.communicationDisabledUntilTimestamp < Date.now() &&
524
+ permissions.has(Permissions.FLAGS.MANAGE_THREADS, false)
525
+ );
526
+ }
527
+
528
+ /**
529
+ * Whether the thread is viewable by the client user
530
+ * @type {boolean}
531
+ * @readonly
532
+ */
533
+ get viewable() {
534
+ if (this.client.user.id === this.guild.ownerId) return true;
535
+ const permissions = this.permissionsFor(this.client.user);
536
+ if (!permissions) return false;
537
+ return permissions.has(Permissions.FLAGS.VIEW_CHANNEL, false);
538
+ }
539
+
540
+ /**
541
+ * Whether the client user can send messages in this thread
542
+ * @type {boolean}
543
+ * @readonly
544
+ */
545
+ get sendable() {
546
+ const permissions = this.permissionsFor(this.client.user);
547
+ if (!permissions) return false;
548
+ // This flag allows sending even if timed out
549
+ if (permissions.has(Permissions.FLAGS.ADMINISTRATOR, false)) return true;
550
+
551
+ return (
552
+ !(this.archived && this.locked && !this.manageable) &&
553
+ (this.type !== 'GUILD_PRIVATE_THREAD' || this.joined || this.manageable) &&
554
+ permissions.has(Permissions.FLAGS.SEND_MESSAGES_IN_THREADS, false) &&
555
+ this.guild.members.me.communicationDisabledUntilTimestamp < Date.now()
556
+ );
557
+ }
558
+
559
+ /**
560
+ * Whether the thread is unarchivable by the client user
561
+ * @type {boolean}
562
+ * @readonly
563
+ */
564
+ get unarchivable() {
565
+ return this.archived && this.sendable && (!this.locked || this.manageable);
566
+ }
567
+
568
+ /**
569
+ * Whether this thread is a private thread
570
+ * @returns {boolean}
571
+ */
572
+ isPrivate() {
573
+ return this.type === 'GUILD_PRIVATE_THREAD';
574
+ }
575
+
576
+ /**
577
+ * Deletes this thread.
578
+ * @param {string} [reason] Reason for deleting this thread
579
+ * @returns {Promise<ThreadChannel>}
580
+ * @example
581
+ * // Delete the thread
582
+ * thread.delete('cleaning out old threads')
583
+ * .then(deletedThread => console.log(deletedThread))
584
+ * .catch(console.error);
585
+ */
586
+ async delete(reason) {
587
+ await this.guild.channels.delete(this.id, reason);
588
+ return this;
589
+ }
590
+
591
+ // These are here only for documentation purposes - they are implemented by TextBasedChannel
592
+ /* eslint-disable no-empty-function */
593
+ get lastMessage() {}
594
+ get lastPinAt() {}
595
+ send() {}
596
+ sendTyping() {}
597
+ createMessageCollector() {}
598
+ awaitMessages() {}
599
+ // Doesn't work on Thread channels; setRateLimitPerUser() {}
600
+ // Doesn't work on Thread channels; setNSFW() {}
601
+ }
602
+
603
+ TextBasedChannel.applyToClass(ThreadChannel, true, ['fetchWebhooks', 'setRateLimitPerUser', 'setNSFW']);
604
+
605
+ module.exports = ThreadChannel;
@@ -0,0 +1,105 @@
1
+ 'use strict';
2
+
3
+ const Base = require('./Base');
4
+ const ThreadMemberFlags = require('../util/ThreadMemberFlags');
5
+
6
+ /**
7
+ * Represents a Member for a Thread.
8
+ * @extends {Base}
9
+ */
10
+ class ThreadMember extends Base {
11
+ constructor(thread, data, extra = {}) {
12
+ super(thread.client);
13
+
14
+ /**
15
+ * The thread that this member is a part of
16
+ * @type {ThreadChannel}
17
+ */
18
+ this.thread = thread;
19
+
20
+ /**
21
+ * The timestamp the member last joined the thread at
22
+ * @type {?number}
23
+ */
24
+ this.joinedTimestamp = null;
25
+
26
+ /**
27
+ * The id of the thread member
28
+ * @type {Snowflake}
29
+ */
30
+ this.id = data.user_id;
31
+
32
+ this._patch(data, extra);
33
+ }
34
+
35
+ _patch(data, extra = {}) {
36
+ if ('join_timestamp' in data) this.joinedTimestamp = new Date(data.join_timestamp).getTime();
37
+
38
+ if ('flags' in data) {
39
+ /**
40
+ * The flags for this thread member
41
+ * @type {ThreadMemberFlags}
42
+ */
43
+ this.flags = new ThreadMemberFlags(data.flags).freeze();
44
+ }
45
+
46
+ if ('member' in data) {
47
+ /**
48
+ * The guild member associated with this thread member.
49
+ * @type {?GuildMember}
50
+ * @private
51
+ */
52
+ this.member = this.thread.guild.members._add(data.member, extra.cache);
53
+ } else {
54
+ this.member ??= null;
55
+ }
56
+ }
57
+
58
+ /**
59
+ * The guild member associated with this thread member
60
+ * @type {?GuildMember}
61
+ * @readonly
62
+ */
63
+ get guildMember() {
64
+ return this.member ?? this.thread.guild.members.cache.get(this.id) ?? null;
65
+ }
66
+
67
+ /**
68
+ * The last time this member joined the thread
69
+ * @type {?Date}
70
+ * @readonly
71
+ */
72
+ get joinedAt() {
73
+ return this.joinedTimestamp ? new Date(this.joinedTimestamp) : null;
74
+ }
75
+
76
+ /**
77
+ * The user associated with this thread member
78
+ * @type {?User}
79
+ * @readonly
80
+ */
81
+ get user() {
82
+ return this.client.users.cache.get(this.id) ?? null;
83
+ }
84
+
85
+ /**
86
+ * Whether the client user can manage this thread member
87
+ * @type {boolean}
88
+ * @readonly
89
+ */
90
+ get manageable() {
91
+ return !this.thread.archived && this.thread.editable;
92
+ }
93
+
94
+ /**
95
+ * Removes this member from the thread.
96
+ * @param {string} [reason] Reason for removing the member
97
+ * @returns {ThreadMember}
98
+ */
99
+ async remove(reason) {
100
+ await this.thread.members.remove(this.id, reason);
101
+ return this;
102
+ }
103
+ }
104
+
105
+ module.exports = ThreadMember;