djs-selfbot-v13 3.2.2 → 3.7.2

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/README.md +63 -36
  2. package/package.json +89 -85
  3. package/src/WebSocket.js +39 -39
  4. package/src/client/BaseClient.js +86 -86
  5. package/src/client/Client.js +941 -836
  6. package/src/client/WebhookClient.js +61 -61
  7. package/src/client/actions/Action.js +116 -120
  8. package/src/client/actions/ActionsManager.js +80 -78
  9. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
  10. package/src/client/actions/AutoModerationActionExecution.js +27 -27
  11. package/src/client/actions/AutoModerationRuleCreate.js +28 -28
  12. package/src/client/actions/AutoModerationRuleDelete.js +32 -32
  13. package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
  14. package/src/client/actions/ChannelCreate.js +23 -23
  15. package/src/client/actions/ChannelDelete.js +39 -39
  16. package/src/client/actions/ChannelUpdate.js +43 -43
  17. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
  18. package/src/client/actions/GuildBanAdd.js +20 -20
  19. package/src/client/actions/GuildBanRemove.js +25 -25
  20. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
  21. package/src/client/actions/GuildDelete.js +65 -65
  22. package/src/client/actions/GuildEmojiCreate.js +20 -20
  23. package/src/client/actions/GuildEmojiDelete.js +21 -21
  24. package/src/client/actions/GuildEmojiUpdate.js +20 -20
  25. package/src/client/actions/GuildEmojisUpdate.js +34 -34
  26. package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
  27. package/src/client/actions/GuildMemberRemove.js +33 -32
  28. package/src/client/actions/GuildMemberUpdate.js +44 -43
  29. package/src/client/actions/GuildRoleCreate.js +25 -25
  30. package/src/client/actions/GuildRoleDelete.js +31 -31
  31. package/src/client/actions/GuildRoleUpdate.js +39 -39
  32. package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
  33. package/src/client/actions/GuildScheduledEventCreate.js +27 -27
  34. package/src/client/actions/GuildScheduledEventDelete.js +31 -31
  35. package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
  36. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
  37. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
  38. package/src/client/actions/GuildStickerCreate.js +20 -20
  39. package/src/client/actions/GuildStickerDelete.js +21 -21
  40. package/src/client/actions/GuildStickerUpdate.js +20 -20
  41. package/src/client/actions/GuildStickersUpdate.js +34 -34
  42. package/src/client/actions/GuildUpdate.js +33 -33
  43. package/src/client/actions/InviteCreate.js +28 -28
  44. package/src/client/actions/InviteDelete.js +30 -30
  45. package/src/client/actions/MessageCreate.js +50 -46
  46. package/src/client/actions/MessageDelete.js +32 -32
  47. package/src/client/actions/MessageDeleteBulk.js +46 -46
  48. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  49. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  50. package/src/client/actions/MessageReactionAdd.js +68 -56
  51. package/src/client/actions/MessageReactionRemove.js +50 -45
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -33
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
  54. package/src/client/actions/MessageUpdate.js +26 -26
  55. package/src/client/actions/PresenceUpdate.js +50 -46
  56. package/src/client/actions/StageInstanceCreate.js +28 -28
  57. package/src/client/actions/StageInstanceDelete.js +33 -33
  58. package/src/client/actions/StageInstanceUpdate.js +30 -30
  59. package/src/client/actions/ThreadCreate.js +24 -24
  60. package/src/client/actions/ThreadDelete.js +32 -32
  61. package/src/client/actions/ThreadListSync.js +59 -59
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -30
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -34
  64. package/src/client/actions/TypingStart.js +29 -29
  65. package/src/client/actions/UserUpdate.js +35 -35
  66. package/src/client/actions/VoiceStateUpdate.js +50 -57
  67. package/src/client/actions/WebhooksUpdate.js +20 -20
  68. package/src/client/voice/ClientVoiceManager.js +151 -51
  69. package/src/client/voice/VoiceConnection.js +1249 -0
  70. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  71. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  72. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  73. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  74. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  75. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  76. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  77. package/src/client/voice/player/MediaPlayer.js +321 -0
  78. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  79. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  80. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  81. package/src/client/voice/receiver/PacketHandler.js +260 -0
  82. package/src/client/voice/receiver/Receiver.js +96 -0
  83. package/src/client/voice/receiver/Recorder.js +173 -0
  84. package/src/client/voice/util/Function.js +116 -0
  85. package/src/client/voice/util/PlayInterface.js +122 -0
  86. package/src/client/voice/util/Secretbox.js +64 -0
  87. package/src/client/voice/util/Silence.js +16 -0
  88. package/src/client/voice/util/Socket.js +62 -0
  89. package/src/client/voice/util/VolumeInterface.js +104 -0
  90. package/src/client/websocket/WebSocketManager.js +392 -392
  91. package/src/client/websocket/WebSocketShard.js +907 -906
  92. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
  96. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
  97. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
  100. package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
  101. package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
  102. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
  103. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
  104. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
  105. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
  106. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
  108. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
  109. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
  110. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
  111. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
  112. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -52
  113. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
  114. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
  115. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
  116. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
  117. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -19
  118. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
  119. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
  120. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
  121. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
  122. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
  123. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
  128. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
  129. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
  130. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
  131. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
  132. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
  133. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
  134. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
  135. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
  136. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -22
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -12
  138. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
  142. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
  143. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
  144. package/src/client/websocket/handlers/READY.js +121 -120
  145. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
  146. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
  147. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
  148. package/src/client/websocket/handlers/RESUMED.js +14 -14
  149. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
  152. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
  153. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
  154. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
  155. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
  156. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
  157. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
  158. package/src/client/websocket/handlers/TYPING_START.js +5 -5
  159. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
  160. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
  161. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
  162. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
  163. package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
  164. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
  166. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
  167. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
  168. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
  169. package/src/client/websocket/handlers/index.js +84 -83
  170. package/src/errors/DJSError.js +61 -61
  171. package/src/errors/Messages.js +217 -183
  172. package/src/errors/index.js +4 -4
  173. package/src/index.js +172 -159
  174. package/src/managers/ApplicationCommandManager.js +264 -264
  175. package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
  176. package/src/managers/AutoModerationRuleManager.js +296 -296
  177. package/src/managers/BaseGuildEmojiManager.js +80 -80
  178. package/src/managers/BaseManager.js +19 -19
  179. package/src/managers/BillingManager.js +66 -66
  180. package/src/managers/CachedManager.js +71 -71
  181. package/src/managers/ChannelManager.js +148 -138
  182. package/src/managers/ClientUserSettingManager.js +372 -372
  183. package/src/managers/DataManager.js +61 -61
  184. package/src/managers/GuildBanManager.js +250 -250
  185. package/src/managers/GuildChannelManager.js +488 -488
  186. package/src/managers/GuildEmojiManager.js +171 -171
  187. package/src/managers/GuildEmojiRoleManager.js +118 -118
  188. package/src/managers/GuildForumThreadManager.js +108 -108
  189. package/src/managers/GuildInviteManager.js +213 -213
  190. package/src/managers/GuildManager.js +338 -304
  191. package/src/managers/GuildMemberManager.js +599 -597
  192. package/src/managers/GuildMemberRoleManager.js +195 -191
  193. package/src/managers/GuildScheduledEventManager.js +314 -296
  194. package/src/managers/GuildSettingManager.js +155 -155
  195. package/src/managers/GuildStickerManager.js +179 -179
  196. package/src/managers/GuildTextThreadManager.js +98 -98
  197. package/src/managers/InteractionManager.js +39 -39
  198. package/src/managers/MessageManager.js +423 -391
  199. package/src/managers/PermissionOverwriteManager.js +164 -166
  200. package/src/managers/PresenceManager.js +71 -58
  201. package/src/managers/QuestManager.js +376 -0
  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 -160
  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 -85
  241. package/src/structures/ClientUser.js +653 -448
  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 +1697 -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 -1227
  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 -318
  284. package/src/structures/MessageReaction.js +181 -171
  285. package/src/structures/MessageSelectMenu.js +141 -140
  286. package/src/structures/Modal.js +161 -161
  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 +1137 -1101
  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 -543
  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 -719
  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 -1773
  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 -336
  349. package/src/util/Permissions.js +202 -202
  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 -889
  361. package/typings/enums.d.ts +439 -297
  362. package/typings/index.d.ts +8392 -7432
  363. package/typings/rawDataTypes.d.ts +403 -342
  364. package/src/structures/MessagePoll.js +0 -238
@@ -1,729 +1,746 @@
1
- 'use strict';
2
-
3
- const { Collection } = require('@discordjs/collection');
4
- const ApplicationCommand = require('./ApplicationCommand');
5
- const AutoModerationRule = require('./AutoModerationRule');
6
- const { GuildScheduledEvent } = require('./GuildScheduledEvent');
7
- const Integration = require('./Integration');
8
- const Invite = require('./Invite');
9
- const { StageInstance } = require('./StageInstance');
10
- const { Sticker } = require('./Sticker');
11
- const Webhook = require('./Webhook');
12
- const { OverwriteTypes, PartialTypes, AutoModerationRuleTriggerTypes } = require('../util/Constants');
13
- const SnowflakeUtil = require('../util/SnowflakeUtil');
14
- const Util = require('../util/Util');
15
-
16
- /**
17
- * The target type of an entry. Here are the available types:
18
- * * GUILD
19
- * * CHANNEL
20
- * * USER
21
- * * ROLE
22
- * * INVITE
23
- * * WEBHOOK
24
- * * EMOJI
25
- * * MESSAGE
26
- * * INTEGRATION
27
- * * STAGE_INSTANCE
28
- * * STICKER
29
- * * THREAD
30
- * * GUILD_SCHEDULED_EVENT
31
- * * APPLICATION_COMMAND
32
- * * AUTO_MODERATION
33
- * @typedef {string} AuditLogTargetType
34
- */
35
-
36
- /**
37
- * Key mirror of all available audit log targets.
38
- * @name GuildAuditLogs.Targets
39
- * @type {Object<string, string>}
40
- */
41
- const Targets = {
42
- ALL: 'ALL',
43
- GUILD: 'GUILD',
44
- GUILD_SCHEDULED_EVENT: 'GUILD_SCHEDULED_EVENT',
45
- CHANNEL: 'CHANNEL',
46
- USER: 'USER',
47
- ROLE: 'ROLE',
48
- INVITE: 'INVITE',
49
- WEBHOOK: 'WEBHOOK',
50
- EMOJI: 'EMOJI',
51
- MESSAGE: 'MESSAGE',
52
- INTEGRATION: 'INTEGRATION',
53
- STAGE_INSTANCE: 'STAGE_INSTANCE',
54
- STICKER: 'STICKER',
55
- THREAD: 'THREAD',
56
- APPLICATION_COMMAND: 'APPLICATION_COMMAND',
57
- AUTO_MODERATION: 'AUTO_MODERATION',
58
- UNKNOWN: 'UNKNOWN',
59
- };
60
-
61
- /**
62
- * The action of an entry. Here are the available actions:
63
- * * ALL: null
64
- * * GUILD_UPDATE: 1
65
- * * CHANNEL_CREATE: 10
66
- * * CHANNEL_UPDATE: 11
67
- * * CHANNEL_DELETE: 12
68
- * * CHANNEL_OVERWRITE_CREATE: 13
69
- * * CHANNEL_OVERWRITE_UPDATE: 14
70
- * * CHANNEL_OVERWRITE_DELETE: 15
71
- * * MEMBER_KICK: 20
72
- * * MEMBER_PRUNE: 21
73
- * * MEMBER_BAN_ADD: 22
74
- * * MEMBER_BAN_REMOVE: 23
75
- * * MEMBER_UPDATE: 24
76
- * * MEMBER_ROLE_UPDATE: 25
77
- * * MEMBER_MOVE: 26
78
- * * MEMBER_DISCONNECT: 27
79
- * * BOT_ADD: 28,
80
- * * ROLE_CREATE: 30
81
- * * ROLE_UPDATE: 31
82
- * * ROLE_DELETE: 32
83
- * * INVITE_CREATE: 40
84
- * * INVITE_UPDATE: 41
85
- * * INVITE_DELETE: 42
86
- * * WEBHOOK_CREATE: 50
87
- * * WEBHOOK_UPDATE: 51
88
- * * WEBHOOK_DELETE: 52
89
- * * EMOJI_CREATE: 60
90
- * * EMOJI_UPDATE: 61
91
- * * EMOJI_DELETE: 62
92
- * * MESSAGE_DELETE: 72
93
- * * MESSAGE_BULK_DELETE: 73
94
- * * MESSAGE_PIN: 74
95
- * * MESSAGE_UNPIN: 75
96
- * * INTEGRATION_CREATE: 80
97
- * * INTEGRATION_UPDATE: 81
98
- * * INTEGRATION_DELETE: 82
99
- * * STAGE_INSTANCE_CREATE: 83
100
- * * STAGE_INSTANCE_UPDATE: 84
101
- * * STAGE_INSTANCE_DELETE: 85
102
- * * STICKER_CREATE: 90
103
- * * STICKER_UPDATE: 91
104
- * * STICKER_DELETE: 92
105
- * * GUILD_SCHEDULED_EVENT_CREATE: 100
106
- * * GUILD_SCHEDULED_EVENT_UPDATE: 101
107
- * * GUILD_SCHEDULED_EVENT_DELETE: 102
108
- * * THREAD_CREATE: 110
109
- * * THREAD_UPDATE: 111
110
- * * THREAD_DELETE: 112
111
- * * APPLICATION_COMMAND_PERMISSION_UPDATE: 121
112
- * * AUTO_MODERATION_RULE_CREATE: 140
113
- * * AUTO_MODERATION_RULE_UPDATE: 141
114
- * * AUTO_MODERATION_RULE_DELETE: 142
115
- * * AUTO_MODERATION_BLOCK_MESSAGE: 143
116
- * * AUTO_MODERATION_FLAG_TO_CHANNEL: 144
117
- * * AUTO_MODERATION_USER_COMMUNICATION_DISABLED: 145
118
- * @typedef {?(number|string)} AuditLogAction
119
- * @see {@link https://discord.com/developers/docs/resources/audit-log#audit-log-entry-object-audit-log-events}
120
- */
121
-
122
- /**
123
- * All available actions keyed under their names to their numeric values.
124
- * @name GuildAuditLogs.Actions
125
- * @type {Object<string, number>}
126
- */
127
- const Actions = {
128
- ALL: null,
129
- GUILD_UPDATE: 1,
130
- CHANNEL_CREATE: 10,
131
- CHANNEL_UPDATE: 11,
132
- CHANNEL_DELETE: 12,
133
- CHANNEL_OVERWRITE_CREATE: 13,
134
- CHANNEL_OVERWRITE_UPDATE: 14,
135
- CHANNEL_OVERWRITE_DELETE: 15,
136
- MEMBER_KICK: 20,
137
- MEMBER_PRUNE: 21,
138
- MEMBER_BAN_ADD: 22,
139
- MEMBER_BAN_REMOVE: 23,
140
- MEMBER_UPDATE: 24,
141
- MEMBER_ROLE_UPDATE: 25,
142
- MEMBER_MOVE: 26,
143
- MEMBER_DISCONNECT: 27,
144
- BOT_ADD: 28,
145
- ROLE_CREATE: 30,
146
- ROLE_UPDATE: 31,
147
- ROLE_DELETE: 32,
148
- INVITE_CREATE: 40,
149
- INVITE_UPDATE: 41,
150
- INVITE_DELETE: 42,
151
- WEBHOOK_CREATE: 50,
152
- WEBHOOK_UPDATE: 51,
153
- WEBHOOK_DELETE: 52,
154
- EMOJI_CREATE: 60,
155
- EMOJI_UPDATE: 61,
156
- EMOJI_DELETE: 62,
157
- MESSAGE_DELETE: 72,
158
- MESSAGE_BULK_DELETE: 73,
159
- MESSAGE_PIN: 74,
160
- MESSAGE_UNPIN: 75,
161
- INTEGRATION_CREATE: 80,
162
- INTEGRATION_UPDATE: 81,
163
- INTEGRATION_DELETE: 82,
164
- STAGE_INSTANCE_CREATE: 83,
165
- STAGE_INSTANCE_UPDATE: 84,
166
- STAGE_INSTANCE_DELETE: 85,
167
- STICKER_CREATE: 90,
168
- STICKER_UPDATE: 91,
169
- STICKER_DELETE: 92,
170
- GUILD_SCHEDULED_EVENT_CREATE: 100,
171
- GUILD_SCHEDULED_EVENT_UPDATE: 101,
172
- GUILD_SCHEDULED_EVENT_DELETE: 102,
173
- THREAD_CREATE: 110,
174
- THREAD_UPDATE: 111,
175
- THREAD_DELETE: 112,
176
- APPLICATION_COMMAND_PERMISSION_UPDATE: 121,
177
- AUTO_MODERATION_RULE_CREATE: 140,
178
- AUTO_MODERATION_RULE_UPDATE: 141,
179
- AUTO_MODERATION_RULE_DELETE: 142,
180
- AUTO_MODERATION_BLOCK_MESSAGE: 143,
181
- AUTO_MODERATION_FLAG_TO_CHANNEL: 144,
182
- AUTO_MODERATION_USER_COMMUNICATION_DISABLED: 145,
183
- };
184
-
185
- /**
186
- * Audit logs entries are held in this class.
187
- */
188
- class GuildAuditLogs {
189
- constructor(guild, data) {
190
- if (data.users) for (const user of data.users) guild.client.users._add(user);
191
- if (data.threads) for (const thread of data.threads) guild.client.channels._add(thread, guild);
192
- /**
193
- * Cached webhooks
194
- * @type {Collection<Snowflake, Webhook>}
195
- * @private
196
- */
197
- this.webhooks = new Collection();
198
- if (data.webhooks) {
199
- for (const hook of data.webhooks) {
200
- this.webhooks.set(hook.id, new Webhook(guild.client, hook));
201
- }
202
- }
203
-
204
- /**
205
- * Cached integrations
206
- * @type {Collection<Snowflake|string, Integration>}
207
- * @private
208
- */
209
- this.integrations = new Collection();
210
- if (data.integrations) {
211
- for (const integration of data.integrations) {
212
- this.integrations.set(integration.id, new Integration(guild.client, integration, guild));
213
- }
214
- }
215
-
216
- /**
217
- * Cached application commands, includes application commands from other applications
218
- * @type {Collection<Snowflake, ApplicationCommand>}
219
- * @private
220
- */
221
- this.applicationCommands = new Collection();
222
- if (data.application_commands) {
223
- for (const command of data.application_commands) {
224
- this.applicationCommands.set(command.id, new ApplicationCommand(guild.client, command, guild));
225
- }
226
- }
227
- /**
228
- * Cached auto moderation rules.
229
- * @type {Collection<Snowflake, AutoModerationRule>}
230
- * @private
231
- */
232
- this.autoModerationRules = data.auto_moderation_rules.reduce(
233
- (autoModerationRules, autoModerationRule) =>
234
- autoModerationRules.set(autoModerationRule.id, guild.autoModerationRules._add(autoModerationRule)),
235
- new Collection(),
236
- );
237
-
238
- /**
239
- * The entries for this guild's audit logs
240
- * @type {Collection<Snowflake, GuildAuditLogsEntry>}
241
- */
242
- this.entries = new Collection();
243
- for (const item of data.audit_log_entries) {
244
- const entry = new GuildAuditLogsEntry(guild, item, this);
245
- this.entries.set(entry.id, entry);
246
- }
247
- }
248
-
249
- /**
250
- * Handles possible promises for entry targets.
251
- * @returns {Promise<GuildAuditLogs>}
252
- */
253
- static async build(...args) {
254
- const logs = new GuildAuditLogs(...args);
255
- await Promise.all(logs.entries.map(e => e.target));
256
- return logs;
257
- }
258
-
259
- /**
260
- * The target of an entry. It can be one of:
261
- * * A guild
262
- * * A channel
263
- * * A user
264
- * * A role
265
- * * An invite
266
- * * A webhook
267
- * * An emoji
268
- * * A message
269
- * * An integration
270
- * * A stage instance
271
- * * A sticker
272
- * * A guild scheduled event
273
- * * A thread
274
- * * An application command
275
- * * An auto moderation rule
276
- * * An object with an id key if target was deleted
277
- * * An object where the keys represent either the new value or the old value
278
- * @typedef {?(Object|Guild|Channel|User|Role|Invite|Webhook|GuildEmoji|Message|Integration|StageInstance|Sticker|
279
- * GuildScheduledEvent|ApplicationCommand|AutoModerationRule)} AuditLogEntryTarget
280
- */
281
-
282
- /**
283
- * Finds the target type from the entry action.
284
- * @param {AuditLogAction} target The action target
285
- * @returns {AuditLogTargetType}
286
- */
287
- static targetType(target) {
288
- if (target < 10) return Targets.GUILD;
289
- if (target < 20) return Targets.CHANNEL;
290
- if (target < 30) return Targets.USER;
291
- if (target < 40) return Targets.ROLE;
292
- if (target < 50) return Targets.INVITE;
293
- if (target < 60) return Targets.WEBHOOK;
294
- if (target < 70) return Targets.EMOJI;
295
- if (target < 80) return Targets.MESSAGE;
296
- if (target < 83) return Targets.INTEGRATION;
297
- if (target < 86) return Targets.STAGE_INSTANCE;
298
- if (target < 100) return Targets.STICKER;
299
- if (target < 110) return Targets.GUILD_SCHEDULED_EVENT;
300
- if (target < 120) return Targets.THREAD;
301
- if (target < 130) return Targets.APPLICATION_COMMAND;
302
- if (target >= 140 && target < 150) return Targets.AUTO_MODERATION;
303
- return Targets.UNKNOWN;
304
- }
305
-
306
- /**
307
- * The action type of an entry, e.g. `CREATE`. Here are the available types:
308
- * * CREATE
309
- * * DELETE
310
- * * UPDATE
311
- * * ALL
312
- * @typedef {string} AuditLogActionType
313
- */
314
-
315
- /**
316
- * Finds the action type from the entry action.
317
- * @param {AuditLogAction} action The action target
318
- * @returns {AuditLogActionType}
319
- */
320
- static actionType(action) {
321
- if (
322
- [
323
- Actions.CHANNEL_CREATE,
324
- Actions.CHANNEL_OVERWRITE_CREATE,
325
- Actions.MEMBER_BAN_REMOVE,
326
- Actions.BOT_ADD,
327
- Actions.ROLE_CREATE,
328
- Actions.INVITE_CREATE,
329
- Actions.WEBHOOK_CREATE,
330
- Actions.EMOJI_CREATE,
331
- Actions.MESSAGE_PIN,
332
- Actions.INTEGRATION_CREATE,
333
- Actions.STAGE_INSTANCE_CREATE,
334
- Actions.STICKER_CREATE,
335
- Actions.GUILD_SCHEDULED_EVENT_CREATE,
336
- Actions.THREAD_CREATE,
337
- Actions.AUTO_MODERATION_RULE_CREATE,
338
- Actions.AUTO_MODERATION_BLOCK_MESSAGE,
339
- ].includes(action)
340
- ) {
341
- return 'CREATE';
342
- }
343
-
344
- if (
345
- [
346
- Actions.CHANNEL_DELETE,
347
- Actions.CHANNEL_OVERWRITE_DELETE,
348
- Actions.MEMBER_KICK,
349
- Actions.MEMBER_PRUNE,
350
- Actions.MEMBER_BAN_ADD,
351
- Actions.MEMBER_DISCONNECT,
352
- Actions.ROLE_DELETE,
353
- Actions.INVITE_DELETE,
354
- Actions.WEBHOOK_DELETE,
355
- Actions.EMOJI_DELETE,
356
- Actions.MESSAGE_DELETE,
357
- Actions.MESSAGE_BULK_DELETE,
358
- Actions.MESSAGE_UNPIN,
359
- Actions.INTEGRATION_DELETE,
360
- Actions.STAGE_INSTANCE_DELETE,
361
- Actions.STICKER_DELETE,
362
- Actions.GUILD_SCHEDULED_EVENT_DELETE,
363
- Actions.THREAD_DELETE,
364
- Actions.AUTO_MODERATION_RULE_DELETE,
365
- ].includes(action)
366
- ) {
367
- return 'DELETE';
368
- }
369
-
370
- if (
371
- [
372
- Actions.GUILD_UPDATE,
373
- Actions.CHANNEL_UPDATE,
374
- Actions.CHANNEL_OVERWRITE_UPDATE,
375
- Actions.MEMBER_UPDATE,
376
- Actions.MEMBER_ROLE_UPDATE,
377
- Actions.MEMBER_MOVE,
378
- Actions.ROLE_UPDATE,
379
- Actions.INVITE_UPDATE,
380
- Actions.WEBHOOK_UPDATE,
381
- Actions.EMOJI_UPDATE,
382
- Actions.INTEGRATION_UPDATE,
383
- Actions.STAGE_INSTANCE_UPDATE,
384
- Actions.STICKER_UPDATE,
385
- Actions.GUILD_SCHEDULED_EVENT_UPDATE,
386
- Actions.THREAD_UPDATE,
387
- Actions.APPLICATION_COMMAND_PERMISSION_UPDATE,
388
- Actions.AUTO_MODERATION_RULE_UPDATE,
389
- ].includes(action)
390
- ) {
391
- return 'UPDATE';
392
- }
393
-
394
- return 'ALL';
395
- }
396
-
397
- toJSON() {
398
- return Util.flatten(this);
399
- }
400
- }
401
-
402
- /**
403
- * Audit logs entry.
404
- */
405
- class GuildAuditLogsEntry {
406
- constructor(guild, data, logs) {
407
- const targetType = GuildAuditLogs.targetType(data.action_type);
408
- /**
409
- * The target type of this entry
410
- * @type {AuditLogTargetType}
411
- */
412
- this.targetType = targetType;
413
-
414
- /**
415
- * The action type of this entry
416
- * @type {AuditLogActionType}
417
- */
418
- this.actionType = GuildAuditLogs.actionType(data.action_type);
419
-
420
- /**
421
- * Specific action type of this entry in its string presentation
422
- * @type {AuditLogAction}
423
- */
424
- this.action = Object.keys(Actions).find(k => Actions[k] === data.action_type);
425
-
426
- /**
427
- * The reason of this entry
428
- * @type {?string}
429
- */
430
- this.reason = data.reason ?? null;
431
-
432
- /**
433
- * The id of the user that executed this entry
434
- * @type {?Snowflake}
435
- */
436
- this.executorId = data.user_id;
437
-
438
- /**
439
- * The user that executed this entry
440
- * @type {?User}
441
- */
442
- this.executor = data.user_id
443
- ? guild.client.options.partials.includes(PartialTypes.USER)
444
- ? guild.client.users._add({ id: data.user_id })
445
- : guild.client.users.cache.get(data.user_id) ?? null
446
- : null;
447
-
448
- /**
449
- * An entry in the audit log representing a specific change.
450
- * @typedef {Object} AuditLogChange
451
- * @property {string} key The property that was changed, e.g. `nick` for nickname changes
452
- * @property {*} [old] The old value of the change, e.g. for nicknames, the old nickname
453
- * @property {*} [new] The new value of the change, e.g. for nicknames, the new nickname
454
- */
455
-
456
- /**
457
- * Specific property changes
458
- * @type {AuditLogChange[]}
459
- */
460
- this.changes = data.changes?.map(c => ({ key: c.key, old: c.old_value, new: c.new_value })) ?? [];
461
-
462
- /**
463
- * The entry's id
464
- * @type {Snowflake}
465
- */
466
- this.id = data.id;
467
-
468
- /**
469
- * Any extra data from the entry
470
- * @type {?(Object|Role|GuildMember)}
471
- */
472
- this.extra = null;
473
- switch (data.action_type) {
474
- case Actions.MEMBER_PRUNE:
475
- this.extra = {
476
- removed: Number(data.options.members_removed),
477
- days: Number(data.options.delete_member_days),
478
- };
479
- break;
480
-
481
- case Actions.MEMBER_MOVE:
482
- case Actions.MESSAGE_DELETE:
483
- case Actions.MESSAGE_BULK_DELETE:
484
- this.extra = {
485
- channel: guild.channels.cache.get(data.options.channel_id) ?? { id: data.options.channel_id },
486
- count: Number(data.options.count),
487
- };
488
- break;
489
- case Actions.MESSAGE_PIN:
490
- case Actions.MESSAGE_UNPIN:
491
- this.extra = {
492
- channel: guild.client.channels.cache.get(data.options.channel_id) ?? { id: data.options.channel_id },
493
- messageId: data.options.message_id,
494
- };
495
- break;
496
-
497
- case Actions.MEMBER_DISCONNECT:
498
- this.extra = {
499
- count: Number(data.options.count),
500
- };
501
- break;
502
-
503
- case Actions.CHANNEL_OVERWRITE_CREATE:
504
- case Actions.CHANNEL_OVERWRITE_UPDATE:
505
- case Actions.CHANNEL_OVERWRITE_DELETE:
506
- switch (Number(data.options.type)) {
507
- case OverwriteTypes.role:
508
- this.extra = guild.roles.cache.get(data.options.id) ?? {
509
- id: data.options.id,
510
- name: data.options.role_name,
511
- type: OverwriteTypes[OverwriteTypes.role],
512
- };
513
- break;
514
-
515
- case OverwriteTypes.member:
516
- this.extra = guild.members.cache.get(data.options.id) ?? {
517
- id: data.options.id,
518
- type: OverwriteTypes[OverwriteTypes.member],
519
- };
520
- break;
521
-
522
- default:
523
- break;
524
- }
525
- break;
526
-
527
- case Actions.STAGE_INSTANCE_CREATE:
528
- case Actions.STAGE_INSTANCE_DELETE:
529
- case Actions.STAGE_INSTANCE_UPDATE:
530
- this.extra = {
531
- channel: guild.client.channels.cache.get(data.options?.channel_id) ?? { id: data.options?.channel_id },
532
- };
533
- break;
534
- case Actions.APPLICATION_COMMAND_PERMISSION_UPDATE:
535
- this.extra = {
536
- applicationId: data.options.application_id,
537
- };
538
- break;
539
- case Actions.AUTO_MODERATION_BLOCK_MESSAGE:
540
- case Actions.AUTO_MODERATION_FLAG_TO_CHANNEL:
541
- case Actions.AUTO_MODERATION_USER_COMMUNICATION_DISABLED:
542
- this.extra = {
543
- autoModerationRuleName: data.options.auto_moderation_rule_name,
544
- autoModerationRuleTriggerType: AutoModerationRuleTriggerTypes[data.options.auto_moderation_rule_trigger_type],
545
- channel: guild.client.channels.cache.get(data.options?.channel_id) ?? { id: data.options?.channel_id },
546
- };
547
- break;
548
- default:
549
- break;
550
- }
551
-
552
- /**
553
- * The id of the target of this entry
554
- * @type {?Snowflake}
555
- */
556
- this.targetId = data.target_id;
557
-
558
- /**
559
- * The target of this entry
560
- * @type {?AuditLogEntryTarget}
561
- */
562
- this.target = null;
563
- if (targetType === Targets.UNKNOWN) {
564
- this.target = this.changes.reduce((o, c) => {
565
- o[c.key] = c.new ?? c.old;
566
- return o;
567
- }, {});
568
- this.target.id = data.target_id;
569
- // MEMBER_DISCONNECT and similar types do not provide a target_id.
570
- } else if (targetType === Targets.USER && data.target_id) {
571
- this.target = guild.client.options.partials.includes(PartialTypes.USER)
572
- ? guild.client.users._add({ id: data.target_id })
573
- : guild.client.users.cache.get(data.target_id) ?? null;
574
- } else if (targetType === Targets.GUILD) {
575
- this.target = guild.client.guilds.cache.get(data.target_id);
576
- } else if (targetType === Targets.WEBHOOK) {
577
- this.target =
578
- logs?.webhooks.get(data.target_id) ??
579
- new Webhook(
580
- guild.client,
581
- this.changes.reduce(
582
- (o, c) => {
583
- o[c.key] = c.new ?? c.old;
584
- return o;
585
- },
586
- {
587
- id: data.target_id,
588
- guild_id: guild.id,
589
- },
590
- ),
591
- );
592
- } else if (targetType === Targets.INVITE) {
593
- let change = this.changes.find(c => c.key === 'code');
594
- change = change.new ?? change.old;
595
-
596
- this.target =
597
- guild.invites.cache.get(change) ??
598
- new Invite(
599
- guild.client,
600
- this.changes.reduce(
601
- (o, c) => {
602
- o[c.key] = c.new ?? c.old;
603
- return o;
604
- },
605
- { guild },
606
- ),
607
- );
608
- } else if (targetType === Targets.MESSAGE) {
609
- // Discord sends a channel id for the MESSAGE_BULK_DELETE action type.
610
- this.target =
611
- data.action_type === Actions.MESSAGE_BULK_DELETE
612
- ? guild.channels.cache.get(data.target_id) ?? { id: data.target_id }
613
- : guild.client.users.cache.get(data.target_id) ?? null;
614
- } else if (targetType === Targets.INTEGRATION) {
615
- this.target =
616
- logs?.integrations.get(data.target_id) ??
617
- new Integration(
618
- guild.client,
619
- this.changes.reduce(
620
- (o, c) => {
621
- o[c.key] = c.new ?? c.old;
622
- return o;
623
- },
624
- { id: data.target_id },
625
- ),
626
- guild,
627
- );
628
- } else if (targetType === Targets.CHANNEL || targetType === Targets.THREAD) {
629
- this.target =
630
- guild.channels.cache.get(data.target_id) ??
631
- this.changes.reduce(
632
- (o, c) => {
633
- o[c.key] = c.new ?? c.old;
634
- return o;
635
- },
636
- { id: data.target_id },
637
- );
638
- } else if (targetType === Targets.STAGE_INSTANCE) {
639
- this.target =
640
- guild.stageInstances.cache.get(data.target_id) ??
641
- new StageInstance(
642
- guild.client,
643
- this.changes.reduce(
644
- (o, c) => {
645
- o[c.key] = c.new ?? c.old;
646
- return o;
647
- },
648
- {
649
- id: data.target_id,
650
- channel_id: data.options?.channel_id,
651
- guild_id: guild.id,
652
- },
653
- ),
654
- );
655
- } else if (targetType === Targets.STICKER) {
656
- this.target =
657
- guild.stickers.cache.get(data.target_id) ??
658
- new Sticker(
659
- guild.client,
660
- this.changes.reduce(
661
- (o, c) => {
662
- o[c.key] = c.new ?? c.old;
663
- return o;
664
- },
665
- { id: data.target_id },
666
- ),
667
- );
668
- } else if (targetType === Targets.GUILD_SCHEDULED_EVENT) {
669
- this.target =
670
- guild.scheduledEvents.cache.get(data.target_id) ??
671
- new GuildScheduledEvent(
672
- guild.client,
673
- this.changes.reduce(
674
- (o, c) => {
675
- o[c.key] = c.new ?? c.old;
676
- return o;
677
- },
678
- { id: data.target_id, guild_id: guild.id },
679
- ),
680
- );
681
- } else if (targetType === Targets.APPLICATION_COMMAND) {
682
- this.target = logs?.applicationCommands.get(data.target_id) ?? { id: data.target_id };
683
- } else if (targetType === Targets.AUTO_MODERATION) {
684
- this.target =
685
- guild.autoModerationRules.cache.get(data.target_id) ??
686
- new AutoModerationRule(
687
- guild.client,
688
- this.changes.reduce(
689
- (o, c) => {
690
- o[c.key] = c.new ?? c.old;
691
- return o;
692
- },
693
- { id: data.target_id, guild_id: guild.id },
694
- ),
695
- guild,
696
- );
697
- } else if (data.target_id) {
698
- this.target = guild[`${targetType.toLowerCase()}s`]?.cache.get(data.target_id) ?? { id: data.target_id };
699
- }
700
- }
701
-
702
- /**
703
- * The timestamp this entry was created at
704
- * @type {number}
705
- * @readonly
706
- */
707
- get createdTimestamp() {
708
- return SnowflakeUtil.timestampFrom(this.id);
709
- }
710
-
711
- /**
712
- * The time this entry was created at
713
- * @type {Date}
714
- * @readonly
715
- */
716
- get createdAt() {
717
- return new Date(this.createdTimestamp);
718
- }
719
-
720
- toJSON() {
721
- return Util.flatten(this, { createdTimestamp: true });
722
- }
723
- }
724
-
725
- GuildAuditLogs.Actions = Actions;
726
- GuildAuditLogs.Targets = Targets;
727
- GuildAuditLogs.Entry = GuildAuditLogsEntry;
728
-
729
- module.exports = GuildAuditLogs;
1
+ 'use strict';
2
+
3
+ const { Collection } = require('@discordjs/collection');
4
+ const ApplicationCommand = require('./ApplicationCommand');
5
+ const AutoModerationRule = require('./AutoModerationRule');
6
+ const { GuildScheduledEvent } = require('./GuildScheduledEvent');
7
+ const Integration = require('./Integration');
8
+ const Invite = require('./Invite');
9
+ const { StageInstance } = require('./StageInstance');
10
+ const { Sticker } = require('./Sticker');
11
+ const Webhook = require('./Webhook');
12
+ const { OverwriteTypes, PartialTypes, AutoModerationRuleTriggerTypes } = require('../util/Constants');
13
+ const SnowflakeUtil = require('../util/SnowflakeUtil');
14
+ const Util = require('../util/Util');
15
+
16
+ /**
17
+ * The target type of an entry. Here are the available types:
18
+ * * GUILD
19
+ * * CHANNEL
20
+ * * USER
21
+ * * ROLE
22
+ * * INVITE
23
+ * * WEBHOOK
24
+ * * EMOJI
25
+ * * MESSAGE
26
+ * * INTEGRATION
27
+ * * STAGE_INSTANCE
28
+ * * STICKER
29
+ * * THREAD
30
+ * * GUILD_SCHEDULED_EVENT
31
+ * * APPLICATION_COMMAND
32
+ * * AUTO_MODERATION
33
+ * @typedef {string} AuditLogTargetType
34
+ */
35
+
36
+ /**
37
+ * Key mirror of all available audit log targets.
38
+ * @name GuildAuditLogs.Targets
39
+ * @type {Object<string, string>}
40
+ */
41
+ const Targets = {
42
+ ALL: 'ALL',
43
+ GUILD: 'GUILD',
44
+ GUILD_SCHEDULED_EVENT: 'GUILD_SCHEDULED_EVENT',
45
+ CHANNEL: 'CHANNEL',
46
+ USER: 'USER',
47
+ ROLE: 'ROLE',
48
+ INVITE: 'INVITE',
49
+ WEBHOOK: 'WEBHOOK',
50
+ EMOJI: 'EMOJI',
51
+ MESSAGE: 'MESSAGE',
52
+ INTEGRATION: 'INTEGRATION',
53
+ STAGE_INSTANCE: 'STAGE_INSTANCE',
54
+ STICKER: 'STICKER',
55
+ THREAD: 'THREAD',
56
+ APPLICATION_COMMAND: 'APPLICATION_COMMAND',
57
+ AUTO_MODERATION: 'AUTO_MODERATION',
58
+ SOUNDBOARD_SOUND: 'SOUNDBOARD_SOUND',
59
+ GUILD_ONBOARDING_PROMPT: 'GUILD_ONBOARDING_PROMPT',
60
+ GUILD_ONBOARDING: 'GUILD_ONBOARDING',
61
+ UNKNOWN: 'UNKNOWN',
62
+ };
63
+
64
+ /**
65
+ * The action of an entry. Here are the available actions:
66
+ * * ALL: null
67
+ * * GUILD_UPDATE: 1
68
+ * * CHANNEL_CREATE: 10
69
+ * * CHANNEL_UPDATE: 11
70
+ * * CHANNEL_DELETE: 12
71
+ * * CHANNEL_OVERWRITE_CREATE: 13
72
+ * * CHANNEL_OVERWRITE_UPDATE: 14
73
+ * * CHANNEL_OVERWRITE_DELETE: 15
74
+ * * MEMBER_KICK: 20
75
+ * * MEMBER_PRUNE: 21
76
+ * * MEMBER_BAN_ADD: 22
77
+ * * MEMBER_BAN_REMOVE: 23
78
+ * * MEMBER_UPDATE: 24
79
+ * * MEMBER_ROLE_UPDATE: 25
80
+ * * MEMBER_MOVE: 26
81
+ * * MEMBER_DISCONNECT: 27
82
+ * * BOT_ADD: 28,
83
+ * * ROLE_CREATE: 30
84
+ * * ROLE_UPDATE: 31
85
+ * * ROLE_DELETE: 32
86
+ * * INVITE_CREATE: 40
87
+ * * INVITE_UPDATE: 41
88
+ * * INVITE_DELETE: 42
89
+ * * WEBHOOK_CREATE: 50
90
+ * * WEBHOOK_UPDATE: 51
91
+ * * WEBHOOK_DELETE: 52
92
+ * * EMOJI_CREATE: 60
93
+ * * EMOJI_UPDATE: 61
94
+ * * EMOJI_DELETE: 62
95
+ * * MESSAGE_DELETE: 72
96
+ * * MESSAGE_BULK_DELETE: 73
97
+ * * MESSAGE_PIN: 74
98
+ * * MESSAGE_UNPIN: 75
99
+ * * INTEGRATION_CREATE: 80
100
+ * * INTEGRATION_UPDATE: 81
101
+ * * INTEGRATION_DELETE: 82
102
+ * * STAGE_INSTANCE_CREATE: 83
103
+ * * STAGE_INSTANCE_UPDATE: 84
104
+ * * STAGE_INSTANCE_DELETE: 85
105
+ * * STICKER_CREATE: 90
106
+ * * STICKER_UPDATE: 91
107
+ * * STICKER_DELETE: 92
108
+ * * GUILD_SCHEDULED_EVENT_CREATE: 100
109
+ * * GUILD_SCHEDULED_EVENT_UPDATE: 101
110
+ * * GUILD_SCHEDULED_EVENT_DELETE: 102
111
+ * * THREAD_CREATE: 110
112
+ * * THREAD_UPDATE: 111
113
+ * * THREAD_DELETE: 112
114
+ * * APPLICATION_COMMAND_PERMISSION_UPDATE: 121
115
+ * * AUTO_MODERATION_RULE_CREATE: 140
116
+ * * AUTO_MODERATION_RULE_UPDATE: 141
117
+ * * AUTO_MODERATION_RULE_DELETE: 142
118
+ * * AUTO_MODERATION_BLOCK_MESSAGE: 143
119
+ * * AUTO_MODERATION_FLAG_TO_CHANNEL: 144
120
+ * * AUTO_MODERATION_USER_COMMUNICATION_DISABLED: 145
121
+ * @typedef {?(number|string)} AuditLogAction
122
+ * @see {@link https://discord.com/developers/docs/resources/audit-log#audit-log-entry-object-audit-log-events}
123
+ */
124
+
125
+ /**
126
+ * All available actions keyed under their names to their numeric values.
127
+ * @name GuildAuditLogs.Actions
128
+ * @type {Object<string, number>}
129
+ */
130
+ const Actions = {
131
+ ALL: null,
132
+ GUILD_UPDATE: 1,
133
+ CHANNEL_CREATE: 10,
134
+ CHANNEL_UPDATE: 11,
135
+ CHANNEL_DELETE: 12,
136
+ CHANNEL_OVERWRITE_CREATE: 13,
137
+ CHANNEL_OVERWRITE_UPDATE: 14,
138
+ CHANNEL_OVERWRITE_DELETE: 15,
139
+ MEMBER_KICK: 20,
140
+ MEMBER_PRUNE: 21,
141
+ MEMBER_BAN_ADD: 22,
142
+ MEMBER_BAN_REMOVE: 23,
143
+ MEMBER_UPDATE: 24,
144
+ MEMBER_ROLE_UPDATE: 25,
145
+ MEMBER_MOVE: 26,
146
+ MEMBER_DISCONNECT: 27,
147
+ BOT_ADD: 28,
148
+ ROLE_CREATE: 30,
149
+ ROLE_UPDATE: 31,
150
+ ROLE_DELETE: 32,
151
+ INVITE_CREATE: 40,
152
+ INVITE_UPDATE: 41,
153
+ INVITE_DELETE: 42,
154
+ WEBHOOK_CREATE: 50,
155
+ WEBHOOK_UPDATE: 51,
156
+ WEBHOOK_DELETE: 52,
157
+ EMOJI_CREATE: 60,
158
+ EMOJI_UPDATE: 61,
159
+ EMOJI_DELETE: 62,
160
+ MESSAGE_DELETE: 72,
161
+ MESSAGE_BULK_DELETE: 73,
162
+ MESSAGE_PIN: 74,
163
+ MESSAGE_UNPIN: 75,
164
+ INTEGRATION_CREATE: 80,
165
+ INTEGRATION_UPDATE: 81,
166
+ INTEGRATION_DELETE: 82,
167
+ STAGE_INSTANCE_CREATE: 83,
168
+ STAGE_INSTANCE_UPDATE: 84,
169
+ STAGE_INSTANCE_DELETE: 85,
170
+ STICKER_CREATE: 90,
171
+ STICKER_UPDATE: 91,
172
+ STICKER_DELETE: 92,
173
+ GUILD_SCHEDULED_EVENT_CREATE: 100,
174
+ GUILD_SCHEDULED_EVENT_UPDATE: 101,
175
+ GUILD_SCHEDULED_EVENT_DELETE: 102,
176
+ THREAD_CREATE: 110,
177
+ THREAD_UPDATE: 111,
178
+ THREAD_DELETE: 112,
179
+ APPLICATION_COMMAND_PERMISSION_UPDATE: 121,
180
+ AUTO_MODERATION_RULE_CREATE: 140,
181
+ AUTO_MODERATION_RULE_UPDATE: 141,
182
+ AUTO_MODERATION_RULE_DELETE: 142,
183
+ AUTO_MODERATION_BLOCK_MESSAGE: 143,
184
+ AUTO_MODERATION_FLAG_TO_CHANNEL: 144,
185
+ AUTO_MODERATION_USER_COMMUNICATION_DISABLED: 145,
186
+ };
187
+
188
+ /**
189
+ * Audit logs entries are held in this class.
190
+ */
191
+ class GuildAuditLogs {
192
+ constructor(guild, data) {
193
+ if (data.users) for (const user of data.users) guild.client.users._add(user);
194
+ if (data.threads) for (const thread of data.threads) guild.client.channels._add(thread, guild);
195
+ /**
196
+ * Cached webhooks
197
+ * @type {Collection<Snowflake, Webhook>}
198
+ * @private
199
+ */
200
+ this.webhooks = new Collection();
201
+ if (data.webhooks) {
202
+ for (const hook of data.webhooks) {
203
+ this.webhooks.set(hook.id, new Webhook(guild.client, hook));
204
+ }
205
+ }
206
+
207
+ /**
208
+ * Cached integrations
209
+ * @type {Collection<Snowflake|string, Integration>}
210
+ * @private
211
+ */
212
+ this.integrations = new Collection();
213
+ if (data.integrations) {
214
+ for (const integration of data.integrations) {
215
+ this.integrations.set(integration.id, new Integration(guild.client, integration, guild));
216
+ }
217
+ }
218
+
219
+ /**
220
+ * Cached application commands, includes application commands from other applications
221
+ * @type {Collection<Snowflake, ApplicationCommand>}
222
+ * @private
223
+ */
224
+ this.applicationCommands = new Collection();
225
+ if (data.application_commands) {
226
+ for (const command of data.application_commands) {
227
+ this.applicationCommands.set(command.id, new ApplicationCommand(guild.client, command, guild));
228
+ }
229
+ }
230
+ /**
231
+ * Cached auto moderation rules.
232
+ * @type {Collection<Snowflake, AutoModerationRule>}
233
+ * @private
234
+ */
235
+ this.autoModerationRules = data.auto_moderation_rules.reduce(
236
+ (autoModerationRules, autoModerationRule) =>
237
+ autoModerationRules.set(autoModerationRule.id, guild.autoModerationRules._add(autoModerationRule)),
238
+ new Collection(),
239
+ );
240
+
241
+ /**
242
+ * The entries for this guild's audit logs
243
+ * @type {Collection<Snowflake, GuildAuditLogsEntry>}
244
+ */
245
+ this.entries = new Collection();
246
+ for (const item of data.audit_log_entries) {
247
+ const entry = new GuildAuditLogsEntry(guild, item, this);
248
+ this.entries.set(entry.id, entry);
249
+ }
250
+ }
251
+
252
+ /**
253
+ * Handles possible promises for entry targets.
254
+ * @returns {Promise<GuildAuditLogs>}
255
+ */
256
+ static async build(...args) {
257
+ const logs = new GuildAuditLogs(...args);
258
+ await Promise.all(logs.entries.map(e => e.target));
259
+ return logs;
260
+ }
261
+
262
+ /**
263
+ * The target of an entry. It can be one of:
264
+ * * A guild
265
+ * * A channel
266
+ * * A user
267
+ * * A role
268
+ * * An invite
269
+ * * A webhook
270
+ * * An emoji
271
+ * * A message
272
+ * * An integration
273
+ * * A stage instance
274
+ * * A sticker
275
+ * * A guild scheduled event
276
+ * * A thread
277
+ * * An application command
278
+ * * An auto moderation rule
279
+ * * An object with an id key if target was deleted
280
+ * * An object where the keys represent either the new value or the old value
281
+ * @typedef {?(Object|Guild|Channel|User|Role|Invite|Webhook|GuildEmoji|Message|Integration|StageInstance|Sticker|
282
+ * GuildScheduledEvent|ApplicationCommand|AutoModerationRule)} AuditLogEntryTarget
283
+ */
284
+
285
+ /**
286
+ * Finds the target type from the entry action.
287
+ * @param {AuditLogAction} target The action target
288
+ * @returns {AuditLogTargetType}
289
+ */
290
+ static targetType(target) {
291
+ if (target < 10) return Targets.GUILD;
292
+ if (target < 20) return Targets.CHANNEL;
293
+ if (target < 30) return Targets.USER;
294
+ if (target < 40) return Targets.ROLE;
295
+ if (target < 50) return Targets.INVITE;
296
+ if (target < 60) return Targets.WEBHOOK;
297
+ if (target < 70) return Targets.EMOJI;
298
+ if (target < 80) return Targets.MESSAGE;
299
+ if (target < 83) return Targets.INTEGRATION;
300
+ if (target < 86) return Targets.STAGE_INSTANCE;
301
+ if (target < 100) return Targets.STICKER;
302
+ if (target < 110) return Targets.GUILD_SCHEDULED_EVENT;
303
+ if (target < 120) return Targets.THREAD;
304
+ if (target < 130) return Targets.APPLICATION_COMMAND;
305
+ if (target < 140) return Targets.SOUNDBOARD_SOUND; // !Todo
306
+ if (target < 143) return Targets.AUTO_MODERATION;
307
+ if (target < 146) return Targets.USER;
308
+ if (target >= 163 && target <= 165) return Targets.GUILD_ONBOARDING_PROMPT; // !Todo
309
+ if (target >= 160 && target < 170) return Targets.GUILD_ONBOARDING; // !Todo
310
+ return Targets.UNKNOWN;
311
+ }
312
+
313
+ /**
314
+ * The action type of an entry, e.g. `CREATE`. Here are the available types:
315
+ * * CREATE
316
+ * * DELETE
317
+ * * UPDATE
318
+ * * ALL
319
+ * @typedef {string} AuditLogActionType
320
+ */
321
+
322
+ /**
323
+ * Finds the action type from the entry action.
324
+ * @param {AuditLogAction} action The action target
325
+ * @returns {AuditLogActionType}
326
+ */
327
+ static actionType(action) {
328
+ if (
329
+ [
330
+ Actions.CHANNEL_CREATE,
331
+ Actions.CHANNEL_OVERWRITE_CREATE,
332
+ Actions.MEMBER_BAN_REMOVE,
333
+ Actions.BOT_ADD,
334
+ Actions.ROLE_CREATE,
335
+ Actions.INVITE_CREATE,
336
+ Actions.WEBHOOK_CREATE,
337
+ Actions.EMOJI_CREATE,
338
+ Actions.MESSAGE_PIN,
339
+ Actions.INTEGRATION_CREATE,
340
+ Actions.STAGE_INSTANCE_CREATE,
341
+ Actions.STICKER_CREATE,
342
+ Actions.GUILD_SCHEDULED_EVENT_CREATE,
343
+ Actions.THREAD_CREATE,
344
+ Actions.AUTO_MODERATION_RULE_CREATE,
345
+ Actions.AUTO_MODERATION_BLOCK_MESSAGE,
346
+ ].includes(action)
347
+ ) {
348
+ return 'CREATE';
349
+ }
350
+
351
+ if (
352
+ [
353
+ Actions.CHANNEL_DELETE,
354
+ Actions.CHANNEL_OVERWRITE_DELETE,
355
+ Actions.MEMBER_KICK,
356
+ Actions.MEMBER_PRUNE,
357
+ Actions.MEMBER_BAN_ADD,
358
+ Actions.MEMBER_DISCONNECT,
359
+ Actions.ROLE_DELETE,
360
+ Actions.INVITE_DELETE,
361
+ Actions.WEBHOOK_DELETE,
362
+ Actions.EMOJI_DELETE,
363
+ Actions.MESSAGE_DELETE,
364
+ Actions.MESSAGE_BULK_DELETE,
365
+ Actions.MESSAGE_UNPIN,
366
+ Actions.INTEGRATION_DELETE,
367
+ Actions.STAGE_INSTANCE_DELETE,
368
+ Actions.STICKER_DELETE,
369
+ Actions.GUILD_SCHEDULED_EVENT_DELETE,
370
+ Actions.THREAD_DELETE,
371
+ Actions.AUTO_MODERATION_RULE_DELETE,
372
+ ].includes(action)
373
+ ) {
374
+ return 'DELETE';
375
+ }
376
+
377
+ if (
378
+ [
379
+ Actions.GUILD_UPDATE,
380
+ Actions.CHANNEL_UPDATE,
381
+ Actions.CHANNEL_OVERWRITE_UPDATE,
382
+ Actions.MEMBER_UPDATE,
383
+ Actions.MEMBER_ROLE_UPDATE,
384
+ Actions.MEMBER_MOVE,
385
+ Actions.ROLE_UPDATE,
386
+ Actions.INVITE_UPDATE,
387
+ Actions.WEBHOOK_UPDATE,
388
+ Actions.EMOJI_UPDATE,
389
+ Actions.INTEGRATION_UPDATE,
390
+ Actions.STAGE_INSTANCE_UPDATE,
391
+ Actions.STICKER_UPDATE,
392
+ Actions.GUILD_SCHEDULED_EVENT_UPDATE,
393
+ Actions.THREAD_UPDATE,
394
+ Actions.APPLICATION_COMMAND_PERMISSION_UPDATE,
395
+ Actions.AUTO_MODERATION_RULE_UPDATE,
396
+ ].includes(action)
397
+ ) {
398
+ return 'UPDATE';
399
+ }
400
+
401
+ return 'ALL';
402
+ }
403
+
404
+ toJSON() {
405
+ return Util.flatten(this);
406
+ }
407
+ }
408
+
409
+ /**
410
+ * Audit logs entry.
411
+ */
412
+ class GuildAuditLogsEntry {
413
+ constructor(guild, data, logs) {
414
+ const targetType = GuildAuditLogs.targetType(data.action_type);
415
+ /**
416
+ * The target type of this entry
417
+ * @type {AuditLogTargetType}
418
+ */
419
+ this.targetType = targetType;
420
+
421
+ /**
422
+ * The action type of this entry
423
+ * @type {AuditLogActionType}
424
+ */
425
+ this.actionType = GuildAuditLogs.actionType(data.action_type);
426
+
427
+ /**
428
+ * Specific action type of this entry in its string presentation
429
+ * @type {AuditLogAction}
430
+ */
431
+ this.action = Object.keys(Actions).find(k => Actions[k] === data.action_type);
432
+
433
+ /**
434
+ * The reason of this entry
435
+ * @type {?string}
436
+ */
437
+ this.reason = data.reason ?? null;
438
+
439
+ /**
440
+ * The id of the user that executed this entry
441
+ * @type {?Snowflake}
442
+ */
443
+ this.executorId = data.user_id;
444
+
445
+ /**
446
+ * The user that executed this entry
447
+ * @type {?User}
448
+ */
449
+ this.executor = data.user_id
450
+ ? guild.client.options.partials.includes(PartialTypes.USER)
451
+ ? guild.client.users._add({ id: data.user_id })
452
+ : guild.client.users.cache.get(data.user_id) ?? null
453
+ : null;
454
+
455
+ /**
456
+ * An entry in the audit log representing a specific change.
457
+ * @typedef {Object} AuditLogChange
458
+ * @property {string} key The property that was changed, e.g. `nick` for nickname changes
459
+ * @property {*} [old] The old value of the change, e.g. for nicknames, the old nickname
460
+ * @property {*} [new] The new value of the change, e.g. for nicknames, the new nickname
461
+ */
462
+
463
+ /**
464
+ * Specific property changes
465
+ * @type {AuditLogChange[]}
466
+ */
467
+ this.changes =
468
+ data.changes?.map(change => ({
469
+ key: change.key,
470
+ ...('old_value' in change ? { old: change.old_value } : {}),
471
+ ...('new_value' in change ? { new: change.new_value } : {}),
472
+ })) ?? [];
473
+
474
+ /**
475
+ * The entry's id
476
+ * @type {Snowflake}
477
+ */
478
+ this.id = data.id;
479
+
480
+ /**
481
+ * Any extra data from the entry
482
+ * @type {?(Object|Role|GuildMember)}
483
+ */
484
+ this.extra = null;
485
+ switch (data.action_type) {
486
+ case Actions.MEMBER_PRUNE:
487
+ this.extra = {
488
+ removed: Number(data.options.members_removed),
489
+ days: Number(data.options.delete_member_days),
490
+ };
491
+ break;
492
+
493
+ case Actions.MEMBER_MOVE:
494
+ case Actions.MESSAGE_DELETE:
495
+ this.extra = {
496
+ channel: guild.channels.cache.get(data.options.channel_id) ?? { id: data.options.channel_id },
497
+ count: Number(data.options.count),
498
+ };
499
+ break;
500
+ case Actions.MESSAGE_PIN:
501
+ case Actions.MESSAGE_UNPIN:
502
+ this.extra = {
503
+ channel: guild.client.channels.cache.get(data.options.channel_id) ?? { id: data.options.channel_id },
504
+ messageId: data.options.message_id,
505
+ };
506
+ break;
507
+
508
+ case Actions.MESSAGE_BULK_DELETE:
509
+ case Actions.MEMBER_DISCONNECT:
510
+ this.extra = {
511
+ count: Number(data.options.count),
512
+ };
513
+ break;
514
+
515
+ case Actions.CHANNEL_OVERWRITE_CREATE:
516
+ case Actions.CHANNEL_OVERWRITE_UPDATE:
517
+ case Actions.CHANNEL_OVERWRITE_DELETE:
518
+ switch (Number(data.options.type)) {
519
+ case OverwriteTypes.role:
520
+ this.extra = guild.roles.cache.get(data.options.id) ?? {
521
+ id: data.options.id,
522
+ name: data.options.role_name,
523
+ type: OverwriteTypes[OverwriteTypes.role],
524
+ };
525
+ break;
526
+
527
+ case OverwriteTypes.member:
528
+ this.extra = guild.members.cache.get(data.options.id) ?? {
529
+ id: data.options.id,
530
+ type: OverwriteTypes[OverwriteTypes.member],
531
+ };
532
+ break;
533
+
534
+ default:
535
+ break;
536
+ }
537
+ break;
538
+
539
+ case Actions.STAGE_INSTANCE_CREATE:
540
+ case Actions.STAGE_INSTANCE_DELETE:
541
+ case Actions.STAGE_INSTANCE_UPDATE:
542
+ this.extra = {
543
+ channel: guild.client.channels.cache.get(data.options?.channel_id) ?? { id: data.options?.channel_id },
544
+ };
545
+ break;
546
+ case Actions.APPLICATION_COMMAND_PERMISSION_UPDATE:
547
+ this.extra = {
548
+ applicationId: data.options.application_id,
549
+ };
550
+ break;
551
+ case Actions.AUTO_MODERATION_BLOCK_MESSAGE:
552
+ case Actions.AUTO_MODERATION_FLAG_TO_CHANNEL:
553
+ case Actions.AUTO_MODERATION_USER_COMMUNICATION_DISABLED:
554
+ this.extra = {
555
+ autoModerationRuleName: data.options.auto_moderation_rule_name,
556
+ autoModerationRuleTriggerType: AutoModerationRuleTriggerTypes[data.options.auto_moderation_rule_trigger_type],
557
+ channel: guild.client.channels.cache.get(data.options?.channel_id) ?? { id: data.options?.channel_id },
558
+ };
559
+ break;
560
+ default:
561
+ break;
562
+ }
563
+
564
+ /**
565
+ * The id of the target of this entry
566
+ * @type {?Snowflake}
567
+ */
568
+ this.targetId = data.target_id;
569
+
570
+ /**
571
+ * The target of this entry
572
+ * @type {?AuditLogEntryTarget}
573
+ */
574
+ this.target = null;
575
+ if (targetType === Targets.UNKNOWN) {
576
+ this.target = this.changes.reduce((o, c) => {
577
+ o[c.key] = c.new ?? c.old;
578
+ return o;
579
+ }, {});
580
+ this.target.id = data.target_id;
581
+ // MEMBER_DISCONNECT and similar types do not provide a target_id.
582
+ } else if (targetType === Targets.USER && data.target_id) {
583
+ this.target = guild.client.options.partials.includes(PartialTypes.USER)
584
+ ? guild.client.users._add({ id: data.target_id })
585
+ : guild.client.users.cache.get(data.target_id) ?? null;
586
+ } else if (targetType === Targets.GUILD) {
587
+ this.target = guild.client.guilds.cache.get(data.target_id);
588
+ } else if (targetType === Targets.WEBHOOK) {
589
+ this.target =
590
+ logs?.webhooks.get(data.target_id) ??
591
+ new Webhook(
592
+ guild.client,
593
+ this.changes.reduce(
594
+ (o, c) => {
595
+ o[c.key] = c.new ?? c.old;
596
+ return o;
597
+ },
598
+ {
599
+ id: data.target_id,
600
+ guild_id: guild.id,
601
+ },
602
+ ),
603
+ );
604
+ } else if (targetType === Targets.INVITE) {
605
+ let change = this.changes.find(c => c.key === 'code');
606
+ change = change.new ?? change.old;
607
+
608
+ this.target =
609
+ guild.invites.cache.get(change) ??
610
+ new Invite(
611
+ guild.client,
612
+ this.changes.reduce(
613
+ (o, c) => {
614
+ o[c.key] = c.new ?? c.old;
615
+ return o;
616
+ },
617
+ { guild },
618
+ ),
619
+ );
620
+ } else if (targetType === Targets.MESSAGE) {
621
+ // Discord sends a channel id for the MESSAGE_BULK_DELETE action type.
622
+ this.target =
623
+ data.action_type === Actions.MESSAGE_BULK_DELETE
624
+ ? guild.channels.cache.get(data.target_id) ?? { id: data.target_id }
625
+ : guild.client.users.cache.get(data.target_id) ?? null;
626
+ } else if (targetType === Targets.INTEGRATION) {
627
+ this.target =
628
+ logs?.integrations.get(data.target_id) ??
629
+ new Integration(
630
+ guild.client,
631
+ this.changes.reduce(
632
+ (o, c) => {
633
+ o[c.key] = c.new ?? c.old;
634
+ return o;
635
+ },
636
+ { id: data.target_id },
637
+ ),
638
+ guild,
639
+ );
640
+ } else if (targetType === Targets.CHANNEL || targetType === Targets.THREAD) {
641
+ this.target =
642
+ guild.channels.cache.get(data.target_id) ??
643
+ this.changes.reduce(
644
+ (o, c) => {
645
+ o[c.key] = c.new ?? c.old;
646
+ return o;
647
+ },
648
+ { id: data.target_id },
649
+ );
650
+ } else if (targetType === Targets.STAGE_INSTANCE) {
651
+ this.target =
652
+ guild.stageInstances.cache.get(data.target_id) ??
653
+ new StageInstance(
654
+ guild.client,
655
+ this.changes.reduce(
656
+ (o, c) => {
657
+ o[c.key] = c.new ?? c.old;
658
+ return o;
659
+ },
660
+ {
661
+ id: data.target_id,
662
+ channel_id: data.options?.channel_id,
663
+ guild_id: guild.id,
664
+ },
665
+ ),
666
+ );
667
+ } else if (targetType === Targets.STICKER) {
668
+ this.target =
669
+ guild.stickers.cache.get(data.target_id) ??
670
+ new Sticker(
671
+ guild.client,
672
+ this.changes.reduce(
673
+ (o, c) => {
674
+ o[c.key] = c.new ?? c.old;
675
+ return o;
676
+ },
677
+ { id: data.target_id },
678
+ ),
679
+ );
680
+ } else if (targetType === Targets.GUILD_SCHEDULED_EVENT) {
681
+ this.target =
682
+ guild.scheduledEvents.cache.get(data.target_id) ??
683
+ new GuildScheduledEvent(
684
+ guild.client,
685
+ this.changes.reduce(
686
+ (o, c) => {
687
+ o[c.key] = c.new ?? c.old;
688
+ return o;
689
+ },
690
+ { id: data.target_id, guild_id: guild.id },
691
+ ),
692
+ );
693
+ } else if (targetType === Targets.APPLICATION_COMMAND) {
694
+ this.target = logs?.applicationCommands.get(data.target_id) ?? { id: data.target_id };
695
+ } else if (targetType === Targets.AUTO_MODERATION) {
696
+ this.target =
697
+ guild.autoModerationRules.cache.get(data.target_id) ??
698
+ new AutoModerationRule(
699
+ guild.client,
700
+ this.changes.reduce(
701
+ (o, c) => {
702
+ o[c.key] = c.new ?? c.old;
703
+ return o;
704
+ },
705
+ { id: data.target_id, guild_id: guild.id },
706
+ ),
707
+ guild,
708
+ );
709
+ } else if (targetType === Targets.ROLE) {
710
+ this.target = guild.roles.cache.get(data.target_id) ?? { id: data.target_id };
711
+ } else if (targetType === Targets.EMOJI) {
712
+ this.target = guild.emojis.cache.get(data.target_id) ?? { id: data.target_id };
713
+ } else if (data.target_id) {
714
+ // Missing SoundboardSound & Onboarding
715
+ this.target = { id: data.target_id };
716
+ }
717
+ }
718
+
719
+ /**
720
+ * The timestamp this entry was created at
721
+ * @type {number}
722
+ * @readonly
723
+ */
724
+ get createdTimestamp() {
725
+ return SnowflakeUtil.timestampFrom(this.id);
726
+ }
727
+
728
+ /**
729
+ * The time this entry was created at
730
+ * @type {Date}
731
+ * @readonly
732
+ */
733
+ get createdAt() {
734
+ return new Date(this.createdTimestamp);
735
+ }
736
+
737
+ toJSON() {
738
+ return Util.flatten(this, { createdTimestamp: true });
739
+ }
740
+ }
741
+
742
+ GuildAuditLogs.Actions = Actions;
743
+ GuildAuditLogs.Targets = Targets;
744
+ GuildAuditLogs.Entry = GuildAuditLogsEntry;
745
+
746
+ module.exports = GuildAuditLogs;