djs-selfbot-v13 3.2.2 → 3.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (363) hide show
  1. package/README.md +37 -36
  2. package/package.json +89 -85
  3. package/src/WebSocket.js +39 -39
  4. package/src/client/BaseClient.js +86 -86
  5. package/src/client/Client.js +934 -836
  6. package/src/client/WebhookClient.js +61 -61
  7. package/src/client/actions/Action.js +116 -120
  8. package/src/client/actions/ActionsManager.js +80 -78
  9. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
  10. package/src/client/actions/AutoModerationActionExecution.js +27 -27
  11. package/src/client/actions/AutoModerationRuleCreate.js +28 -28
  12. package/src/client/actions/AutoModerationRuleDelete.js +32 -32
  13. package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
  14. package/src/client/actions/ChannelCreate.js +23 -23
  15. package/src/client/actions/ChannelDelete.js +39 -39
  16. package/src/client/actions/ChannelUpdate.js +43 -43
  17. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
  18. package/src/client/actions/GuildBanAdd.js +20 -20
  19. package/src/client/actions/GuildBanRemove.js +25 -25
  20. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
  21. package/src/client/actions/GuildDelete.js +65 -65
  22. package/src/client/actions/GuildEmojiCreate.js +20 -20
  23. package/src/client/actions/GuildEmojiDelete.js +21 -21
  24. package/src/client/actions/GuildEmojiUpdate.js +20 -20
  25. package/src/client/actions/GuildEmojisUpdate.js +34 -34
  26. package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
  27. package/src/client/actions/GuildMemberRemove.js +33 -32
  28. package/src/client/actions/GuildMemberUpdate.js +44 -43
  29. package/src/client/actions/GuildRoleCreate.js +25 -25
  30. package/src/client/actions/GuildRoleDelete.js +31 -31
  31. package/src/client/actions/GuildRoleUpdate.js +39 -39
  32. package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
  33. package/src/client/actions/GuildScheduledEventCreate.js +27 -27
  34. package/src/client/actions/GuildScheduledEventDelete.js +31 -31
  35. package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
  36. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
  37. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
  38. package/src/client/actions/GuildStickerCreate.js +20 -20
  39. package/src/client/actions/GuildStickerDelete.js +21 -21
  40. package/src/client/actions/GuildStickerUpdate.js +20 -20
  41. package/src/client/actions/GuildStickersUpdate.js +34 -34
  42. package/src/client/actions/GuildUpdate.js +33 -33
  43. package/src/client/actions/InviteCreate.js +28 -28
  44. package/src/client/actions/InviteDelete.js +30 -30
  45. package/src/client/actions/MessageCreate.js +50 -46
  46. package/src/client/actions/MessageDelete.js +32 -32
  47. package/src/client/actions/MessageDeleteBulk.js +46 -46
  48. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  49. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  50. package/src/client/actions/MessageReactionAdd.js +68 -56
  51. package/src/client/actions/MessageReactionRemove.js +50 -45
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -33
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
  54. package/src/client/actions/MessageUpdate.js +26 -26
  55. package/src/client/actions/PresenceUpdate.js +50 -46
  56. package/src/client/actions/StageInstanceCreate.js +28 -28
  57. package/src/client/actions/StageInstanceDelete.js +33 -33
  58. package/src/client/actions/StageInstanceUpdate.js +30 -30
  59. package/src/client/actions/ThreadCreate.js +24 -24
  60. package/src/client/actions/ThreadDelete.js +32 -32
  61. package/src/client/actions/ThreadListSync.js +59 -59
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -30
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -34
  64. package/src/client/actions/TypingStart.js +29 -29
  65. package/src/client/actions/UserUpdate.js +35 -35
  66. package/src/client/actions/VoiceStateUpdate.js +50 -57
  67. package/src/client/actions/WebhooksUpdate.js +20 -20
  68. package/src/client/voice/ClientVoiceManager.js +151 -51
  69. package/src/client/voice/VoiceConnection.js +1249 -0
  70. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  71. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  72. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  73. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  74. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  75. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  76. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  77. package/src/client/voice/player/MediaPlayer.js +321 -0
  78. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  79. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  80. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  81. package/src/client/voice/receiver/PacketHandler.js +260 -0
  82. package/src/client/voice/receiver/Receiver.js +96 -0
  83. package/src/client/voice/receiver/Recorder.js +173 -0
  84. package/src/client/voice/util/Function.js +116 -0
  85. package/src/client/voice/util/PlayInterface.js +122 -0
  86. package/src/client/voice/util/Secretbox.js +64 -0
  87. package/src/client/voice/util/Silence.js +16 -0
  88. package/src/client/voice/util/Socket.js +62 -0
  89. package/src/client/voice/util/VolumeInterface.js +104 -0
  90. package/src/client/websocket/WebSocketManager.js +392 -392
  91. package/src/client/websocket/WebSocketShard.js +907 -906
  92. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
  96. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
  97. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
  100. package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
  101. package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
  102. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
  103. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
  104. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
  105. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
  106. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
  108. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
  109. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
  110. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
  111. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
  112. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -52
  113. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
  114. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
  115. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
  116. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
  117. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -19
  118. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
  119. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
  120. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
  121. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
  122. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
  123. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
  128. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
  129. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
  130. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
  131. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
  132. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
  133. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
  134. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
  135. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
  136. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -22
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -12
  138. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
  142. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
  143. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
  144. package/src/client/websocket/handlers/READY.js +121 -120
  145. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
  146. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
  147. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
  148. package/src/client/websocket/handlers/RESUMED.js +14 -14
  149. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
  152. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
  153. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
  154. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
  155. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
  156. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
  157. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
  158. package/src/client/websocket/handlers/TYPING_START.js +5 -5
  159. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
  160. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
  161. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
  162. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
  163. package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
  164. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
  166. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
  167. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
  168. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
  169. package/src/client/websocket/handlers/index.js +84 -83
  170. package/src/errors/DJSError.js +61 -61
  171. package/src/errors/Messages.js +217 -183
  172. package/src/errors/index.js +4 -4
  173. package/src/index.js +172 -159
  174. package/src/managers/ApplicationCommandManager.js +264 -264
  175. package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
  176. package/src/managers/AutoModerationRuleManager.js +296 -296
  177. package/src/managers/BaseGuildEmojiManager.js +80 -80
  178. package/src/managers/BaseManager.js +19 -19
  179. package/src/managers/BillingManager.js +66 -66
  180. package/src/managers/CachedManager.js +71 -71
  181. package/src/managers/ChannelManager.js +148 -138
  182. package/src/managers/ClientUserSettingManager.js +372 -372
  183. package/src/managers/DataManager.js +61 -61
  184. package/src/managers/GuildBanManager.js +250 -250
  185. package/src/managers/GuildChannelManager.js +488 -488
  186. package/src/managers/GuildEmojiManager.js +171 -171
  187. package/src/managers/GuildEmojiRoleManager.js +118 -118
  188. package/src/managers/GuildForumThreadManager.js +108 -108
  189. package/src/managers/GuildInviteManager.js +213 -213
  190. package/src/managers/GuildManager.js +338 -304
  191. package/src/managers/GuildMemberManager.js +599 -597
  192. package/src/managers/GuildMemberRoleManager.js +195 -191
  193. package/src/managers/GuildScheduledEventManager.js +314 -296
  194. package/src/managers/GuildSettingManager.js +155 -155
  195. package/src/managers/GuildStickerManager.js +179 -179
  196. package/src/managers/GuildTextThreadManager.js +98 -98
  197. package/src/managers/InteractionManager.js +39 -39
  198. package/src/managers/MessageManager.js +423 -391
  199. package/src/managers/PermissionOverwriteManager.js +164 -166
  200. package/src/managers/PresenceManager.js +71 -58
  201. package/src/managers/ReactionManager.js +67 -67
  202. package/src/managers/ReactionUserManager.js +73 -71
  203. package/src/managers/RelationshipManager.js +278 -265
  204. package/src/managers/RoleManager.js +448 -352
  205. package/src/managers/SessionManager.js +66 -0
  206. package/src/managers/StageInstanceManager.js +162 -162
  207. package/src/managers/ThreadManager.js +175 -174
  208. package/src/managers/ThreadMemberManager.js +186 -186
  209. package/src/managers/UserManager.js +136 -146
  210. package/src/managers/UserNoteManager.js +53 -53
  211. package/src/managers/VoiceStateManager.js +59 -37
  212. package/src/rest/APIRequest.js +154 -160
  213. package/src/rest/APIRouter.js +53 -53
  214. package/src/rest/DiscordAPIError.js +119 -104
  215. package/src/rest/HTTPError.js +62 -62
  216. package/src/rest/RESTManager.js +67 -62
  217. package/src/rest/RateLimitError.js +55 -55
  218. package/src/rest/RequestHandler.js +466 -444
  219. package/src/sharding/Shard.js +444 -443
  220. package/src/sharding/ShardClientUtil.js +279 -275
  221. package/src/sharding/ShardingManager.js +319 -318
  222. package/src/structures/AnonymousGuild.js +98 -98
  223. package/src/structures/ApplicationCommand.js +593 -593
  224. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -48
  225. package/src/structures/AutoModerationActionExecution.js +89 -89
  226. package/src/structures/AutoModerationRule.js +294 -294
  227. package/src/structures/AutocompleteInteraction.js +107 -107
  228. package/src/structures/Base.js +43 -43
  229. package/src/structures/BaseCommandInteraction.js +211 -211
  230. package/src/structures/BaseGuild.js +116 -116
  231. package/src/structures/BaseGuildEmoji.js +56 -56
  232. package/src/structures/BaseGuildTextChannel.js +191 -191
  233. package/src/structures/BaseGuildVoiceChannel.js +241 -241
  234. package/src/structures/BaseMessageComponent.js +181 -114
  235. package/src/structures/ButtonInteraction.js +11 -11
  236. package/src/structures/CallState.js +63 -63
  237. package/src/structures/CategoryChannel.js +85 -85
  238. package/src/structures/Channel.js +284 -270
  239. package/src/structures/ClientPresence.js +77 -85
  240. package/src/structures/ClientUser.js +479 -448
  241. package/src/structures/CommandInteraction.js +41 -41
  242. package/src/structures/CommandInteractionOptionResolver.js +276 -276
  243. package/src/structures/ContainerComponent.js +68 -0
  244. package/src/structures/ContextMenuInteraction.js +65 -65
  245. package/src/structures/DMChannel.js +219 -217
  246. package/src/structures/DirectoryChannel.js +20 -20
  247. package/src/structures/Emoji.js +148 -148
  248. package/src/structures/FileComponent.js +49 -0
  249. package/src/structures/ForumChannel.js +31 -261
  250. package/src/structures/GroupDMChannel.js +394 -387
  251. package/src/structures/Guild.js +1643 -1608
  252. package/src/structures/GuildAuditLogs.js +746 -729
  253. package/src/structures/GuildBan.js +59 -59
  254. package/src/structures/GuildBoost.js +108 -108
  255. package/src/structures/GuildChannel.js +470 -468
  256. package/src/structures/GuildEmoji.js +161 -161
  257. package/src/structures/GuildMember.js +636 -568
  258. package/src/structures/GuildPreview.js +191 -191
  259. package/src/structures/GuildPreviewEmoji.js +27 -27
  260. package/src/structures/GuildScheduledEvent.js +536 -441
  261. package/src/structures/GuildTemplate.js +236 -236
  262. package/src/structures/Integration.js +188 -188
  263. package/src/structures/IntegrationApplication.js +96 -96
  264. package/src/structures/Interaction.js +290 -290
  265. package/src/structures/InteractionCollector.js +248 -248
  266. package/src/structures/InteractionWebhook.js +43 -43
  267. package/src/structures/Invite.js +358 -358
  268. package/src/structures/InviteGuild.js +23 -23
  269. package/src/structures/InviteStageInstance.js +86 -86
  270. package/src/structures/MediaChannel.js +11 -0
  271. package/src/structures/MediaGalleryComponent.js +41 -0
  272. package/src/structures/MediaGalleryItem.js +47 -0
  273. package/src/structures/Message.js +1252 -1227
  274. package/src/structures/MessageActionRow.js +105 -103
  275. package/src/structures/MessageAttachment.js +216 -204
  276. package/src/structures/MessageButton.js +166 -165
  277. package/src/structures/MessageCollector.js +146 -146
  278. package/src/structures/MessageComponentInteraction.js +120 -120
  279. package/src/structures/MessageContextMenuInteraction.js +20 -20
  280. package/src/structures/MessageEmbed.js +596 -586
  281. package/src/structures/MessageMentions.js +273 -273
  282. package/src/structures/MessagePayload.js +354 -318
  283. package/src/structures/MessageReaction.js +181 -171
  284. package/src/structures/MessageSelectMenu.js +141 -140
  285. package/src/structures/Modal.js +161 -161
  286. package/src/structures/ModalSubmitFieldsResolver.js +53 -53
  287. package/src/structures/ModalSubmitInteraction.js +119 -119
  288. package/src/structures/NewsChannel.js +32 -32
  289. package/src/structures/OAuth2Guild.js +28 -28
  290. package/src/structures/PermissionOverwrites.js +198 -196
  291. package/src/structures/Poll.js +108 -0
  292. package/src/structures/PollAnswer.js +88 -0
  293. package/src/structures/Presence.js +1105 -1101
  294. package/src/structures/ReactionCollector.js +229 -229
  295. package/src/structures/ReactionEmoji.js +31 -31
  296. package/src/structures/Role.js +590 -531
  297. package/src/structures/SectionComponent.js +48 -0
  298. package/src/structures/SelectMenuInteraction.js +21 -21
  299. package/src/structures/SeparatorComponent.js +48 -0
  300. package/src/structures/Session.js +81 -0
  301. package/src/structures/StageChannel.js +104 -104
  302. package/src/structures/StageInstance.js +208 -208
  303. package/src/structures/Sticker.js +310 -310
  304. package/src/structures/StickerPack.js +95 -95
  305. package/src/structures/StoreChannel.js +56 -56
  306. package/src/structures/Team.js +118 -118
  307. package/src/structures/TeamMember.js +80 -71
  308. package/src/structures/TextChannel.js +33 -33
  309. package/src/structures/TextDisplayComponent.js +40 -0
  310. package/src/structures/TextInputComponent.js +132 -131
  311. package/src/structures/ThreadChannel.js +605 -607
  312. package/src/structures/ThreadMember.js +105 -105
  313. package/src/structures/ThreadOnlyChannel.js +249 -0
  314. package/src/structures/ThumbnailComponent.js +57 -0
  315. package/src/structures/Typing.js +74 -74
  316. package/src/structures/UnfurledMediaItem.js +29 -0
  317. package/src/structures/User.js +640 -543
  318. package/src/structures/UserContextMenuInteraction.js +29 -29
  319. package/src/structures/VoiceChannel.js +110 -110
  320. package/src/structures/VoiceChannelEffect.js +69 -0
  321. package/src/structures/VoiceRegion.js +53 -53
  322. package/src/structures/VoiceState.js +354 -341
  323. package/src/structures/WebEmbed.js +373 -373
  324. package/src/structures/Webhook.js +478 -467
  325. package/src/structures/WelcomeChannel.js +60 -60
  326. package/src/structures/WelcomeScreen.js +48 -48
  327. package/src/structures/Widget.js +87 -87
  328. package/src/structures/WidgetMember.js +99 -99
  329. package/src/structures/interfaces/Application.js +825 -313
  330. package/src/structures/interfaces/Collector.js +300 -300
  331. package/src/structures/interfaces/InteractionResponses.js +313 -313
  332. package/src/structures/interfaces/TextBasedChannel.js +759 -719
  333. package/src/util/APITypes.js +59 -0
  334. package/src/util/ActivityFlags.js +44 -44
  335. package/src/util/ApplicationFlags.js +76 -76
  336. package/src/util/AttachmentFlags.js +38 -38
  337. package/src/util/BitField.js +170 -170
  338. package/src/util/ChannelFlags.js +45 -45
  339. package/src/util/Constants.js +1914 -1773
  340. package/src/util/DataResolver.js +146 -145
  341. package/src/util/Formatters.js +228 -228
  342. package/src/util/GuildMemberFlags.js +43 -43
  343. package/src/util/Intents.js +74 -74
  344. package/src/util/InviteFlags.js +34 -29
  345. package/src/util/LimitedCollection.js +131 -131
  346. package/src/util/MessageFlags.js +63 -54
  347. package/src/util/Options.js +358 -336
  348. package/src/util/Permissions.js +202 -202
  349. package/src/util/PremiumUsageFlags.js +31 -31
  350. package/src/util/PurchasedFlags.js +33 -33
  351. package/src/util/RemoteAuth.js +382 -379
  352. package/src/util/RoleFlags.js +37 -37
  353. package/src/util/SnowflakeUtil.js +92 -92
  354. package/src/util/Speaking.js +33 -0
  355. package/src/util/Sweepers.js +466 -466
  356. package/src/util/SystemChannelFlags.js +55 -55
  357. package/src/util/ThreadMemberFlags.js +30 -30
  358. package/src/util/UserFlags.js +104 -104
  359. package/src/util/Util.js +1048 -889
  360. package/typings/enums.d.ts +439 -297
  361. package/typings/index.d.ts +8247 -7432
  362. package/typings/rawDataTypes.d.ts +403 -342
  363. package/src/structures/MessagePoll.js +0 -238
@@ -1,352 +1,448 @@
1
- 'use strict';
2
-
3
- const process = require('node:process');
4
- const { Collection } = require('@discordjs/collection');
5
- const CachedManager = require('./CachedManager');
6
- const { TypeError } = require('../errors');
7
- const { Role } = require('../structures/Role');
8
- const DataResolver = require('../util/DataResolver');
9
- const Permissions = require('../util/Permissions');
10
- const { resolveColor } = require('../util/Util');
11
- const Util = require('../util/Util');
12
-
13
- let cacheWarningEmitted = false;
14
-
15
- /**
16
- * Manages API methods for roles and stores their cache.
17
- * @extends {CachedManager}
18
- */
19
- class RoleManager extends CachedManager {
20
- constructor(guild, iterable) {
21
- super(guild.client, Role, iterable);
22
- if (!cacheWarningEmitted && this._cache.constructor.name !== 'Collection') {
23
- cacheWarningEmitted = true;
24
- process.emitWarning(
25
- `Overriding the cache handling for ${this.constructor.name} is unsupported and breaks functionality.`,
26
- 'UnsupportedCacheOverwriteWarning',
27
- );
28
- }
29
-
30
- /**
31
- * The guild belonging to this manager
32
- * @type {Guild}
33
- */
34
- this.guild = guild;
35
- }
36
-
37
- /**
38
- * The role cache of this manager
39
- * @type {Collection<Snowflake, Role>}
40
- * @name RoleManager#cache
41
- */
42
-
43
- _add(data, cache) {
44
- return super._add(data, cache, { extras: [this.guild] });
45
- }
46
-
47
- /**
48
- * Obtains a role from Discord, or the role cache if they're already available.
49
- * @param {Snowflake} [id] The role's id
50
- * @param {BaseFetchOptions} [options] Additional options for this fetch
51
- * @returns {Promise<?Role|Collection<Snowflake, Role>>}
52
- * @example
53
- * // Fetch all roles from the guild
54
- * message.guild.roles.fetch()
55
- * .then(roles => console.log(`There are ${roles.size} roles.`))
56
- * .catch(console.error);
57
- * @example
58
- * // Fetch a single role
59
- * message.guild.roles.fetch('222078108977594368')
60
- * .then(role => console.log(`The role color is: ${role.color}`))
61
- * .catch(console.error);
62
- */
63
- async fetch(id, { cache = true, force = false } = {}) {
64
- if (id && !force) {
65
- const existing = this.cache.get(id);
66
- if (existing) return existing;
67
- }
68
-
69
- // We cannot fetch a single role, as of this commit's date, Discord API throws with 405
70
- const data = await this.client.api.guilds(this.guild.id).roles.get();
71
- const roles = new Collection();
72
- for (const role of data) roles.set(role.id, this._add(role, cache));
73
- return id ? roles.get(id) ?? null : roles;
74
- }
75
-
76
- /**
77
- * Data that can be resolved to a Role object. This can be:
78
- * * A Role
79
- * * A Snowflake
80
- * @typedef {Role|Snowflake} RoleResolvable
81
- */
82
-
83
- /**
84
- * Resolves a {@link RoleResolvable} to a {@link Role} object.
85
- * @method resolve
86
- * @memberof RoleManager
87
- * @instance
88
- * @param {RoleResolvable} role The role resolvable to resolve
89
- * @returns {?Role}
90
- */
91
-
92
- /**
93
- * Resolves a {@link RoleResolvable} to a {@link Role} id.
94
- * @method resolveId
95
- * @memberof RoleManager
96
- * @instance
97
- * @param {RoleResolvable} role The role resolvable to resolve
98
- * @returns {?Snowflake}
99
- */
100
-
101
- /**
102
- * Options used to create a new role.
103
- * @typedef {Object} CreateRoleOptions
104
- * @property {string} [name] The name of the new role
105
- * @property {ColorResolvable} [color] The data to create the role with
106
- * @property {boolean} [hoist] Whether or not the new role should be hoisted
107
- * @property {PermissionResolvable} [permissions] The permissions for the new role
108
- * @property {number} [position] The position of the new role
109
- * @property {boolean} [mentionable] Whether or not the new role should be mentionable
110
- * @property {?(BufferResolvable|Base64Resolvable|EmojiResolvable)} [icon] The icon for the role
111
- * <warn>The `EmojiResolvable` should belong to the same guild as the role.
112
- * If not, pass the emoji's URL directly</warn>
113
- * @property {?string} [unicodeEmoji] The unicode emoji for the role
114
- * @property {string} [reason] The reason for creating this role
115
- */
116
-
117
- /**
118
- * Creates a new role in the guild with given information.
119
- * <warn>The position will silently reset to 1 if an invalid one is provided, or none.</warn>
120
- * @param {CreateRoleOptions} [options] Options for creating the new role
121
- * @returns {Promise<Role>}
122
- * @example
123
- * // Create a new role
124
- * guild.roles.create()
125
- * .then(console.log)
126
- * .catch(console.error);
127
- * @example
128
- * // Create a new role with data and a reason
129
- * guild.roles.create({
130
- * name: 'Super Cool Blue People',
131
- * color: 'BLUE',
132
- * reason: 'we needed a role for Super Cool People',
133
- * })
134
- * .then(console.log)
135
- * .catch(console.error);
136
- */
137
- async create(options = {}) {
138
- let { name, color, hoist, permissions, position, mentionable, reason, icon, unicodeEmoji } = options;
139
- color &&= resolveColor(color);
140
- if (typeof permissions !== 'undefined') permissions = new Permissions(permissions);
141
- if (icon) {
142
- const guildEmojiURL = this.guild.emojis.resolve(icon)?.url;
143
- icon = guildEmojiURL ? await DataResolver.resolveImage(guildEmojiURL) : await DataResolver.resolveImage(icon);
144
- if (typeof icon !== 'string') icon = undefined;
145
- }
146
-
147
- const data = await this.client.api.guilds(this.guild.id).roles.post({
148
- data: {
149
- name,
150
- color,
151
- hoist,
152
- permissions,
153
- mentionable,
154
- icon,
155
- unicode_emoji: unicodeEmoji,
156
- },
157
- reason,
158
- });
159
- const { role } = this.client.actions.GuildRoleCreate.handle({
160
- guild_id: this.guild.id,
161
- role: data,
162
- });
163
- if (position) return this.setPosition(role, position, { reason });
164
- return role;
165
- }
166
-
167
- /**
168
- * Edits a role of the guild.
169
- * @param {RoleResolvable} role The role to edit
170
- * @param {RoleData} data The new data for the role
171
- * @param {string} [reason] Reason for editing this role
172
- * @returns {Promise<Role>}
173
- * @example
174
- * // Edit a role
175
- * guild.roles.edit('222079219327434752', { name: 'buddies' })
176
- * .then(updated => console.log(`Edited role name to ${updated.name}`))
177
- * .catch(console.error);
178
- */
179
- async edit(role, data, reason) {
180
- role = this.resolve(role);
181
- if (!role) throw new TypeError('INVALID_TYPE', 'role', 'RoleResolvable');
182
-
183
- if (typeof data.position === 'number') await this.setPosition(role, data.position, { reason });
184
-
185
- let icon = data.icon;
186
- if (icon) {
187
- const guildEmojiURL = this.guild.emojis.resolve(icon)?.url;
188
- icon = guildEmojiURL ? await DataResolver.resolveImage(guildEmojiURL) : await DataResolver.resolveImage(icon);
189
- if (typeof icon !== 'string') icon = undefined;
190
- }
191
-
192
- const _data = {
193
- name: data.name,
194
- color: typeof data.color === 'undefined' ? undefined : resolveColor(data.color),
195
- hoist: data.hoist,
196
- permissions: typeof data.permissions === 'undefined' ? undefined : new Permissions(data.permissions),
197
- mentionable: data.mentionable,
198
- icon,
199
- unicode_emoji: data.unicodeEmoji,
200
- };
201
-
202
- const d = await this.client.api.guilds(this.guild.id).roles(role.id).patch({ data: _data, reason });
203
-
204
- const clone = role._clone();
205
- clone._patch(d);
206
- return clone;
207
- }
208
-
209
- /**
210
- * Deletes a role.
211
- * @param {RoleResolvable} role The role to delete
212
- * @param {string} [reason] Reason for deleting the role
213
- * @returns {Promise<void>}
214
- * @example
215
- * // Delete a role
216
- * guild.roles.delete('222079219327434752', 'The role needed to go')
217
- * .then(() => console.log('Deleted the role.'))
218
- * .catch(console.error);
219
- */
220
- async delete(role, reason) {
221
- const id = this.resolveId(role);
222
- await this.client.api.guilds[this.guild.id].roles[id].delete({ reason });
223
- this.client.actions.GuildRoleDelete.handle({ guild_id: this.guild.id, role_id: id });
224
- }
225
-
226
- /**
227
- * Sets the new position of the role.
228
- * @param {RoleResolvable} role The role to change the position of
229
- * @param {number} position The new position for the role
230
- * @param {SetRolePositionOptions} [options] Options for setting the position
231
- * @returns {Promise<Role>}
232
- * @example
233
- * // Set the position of the role
234
- * guild.roles.setPosition('222197033908436994', 1)
235
- * .then(updated => console.log(`Role position: ${updated.position}`))
236
- * .catch(console.error);
237
- */
238
- async setPosition(role, position, { relative, reason } = {}) {
239
- role = this.resolve(role);
240
- if (!role) throw new TypeError('INVALID_TYPE', 'role', 'RoleResolvable');
241
- const updatedRoles = await Util.setPosition(
242
- role,
243
- position,
244
- relative,
245
- this.guild._sortedRoles(),
246
- this.client.api.guilds(this.guild.id).roles,
247
- reason,
248
- );
249
-
250
- this.client.actions.GuildRolesPositionUpdate.handle({
251
- guild_id: this.guild.id,
252
- roles: updatedRoles,
253
- });
254
- return role;
255
- }
256
-
257
- /**
258
- * The data needed for updating a guild role's position
259
- * @typedef {Object} GuildRolePosition
260
- * @property {RoleResolvable} role The role's id
261
- * @property {number} position The position to update
262
- */
263
-
264
- /**
265
- * Batch-updates the guild's role positions
266
- * @param {GuildRolePosition[]} rolePositions Role positions to update
267
- * @returns {Promise<Guild>}
268
- * @example
269
- * guild.roles.setPositions([{ role: roleId, position: updatedRoleIndex }])
270
- * .then(guild => console.log(`Role positions updated for ${guild}`))
271
- * .catch(console.error);
272
- */
273
- async setPositions(rolePositions) {
274
- // Make sure rolePositions are prepared for API
275
- rolePositions = rolePositions.map(o => ({
276
- id: this.resolveId(o.role),
277
- position: o.position,
278
- }));
279
-
280
- // Call the API to update role positions
281
- await this.client.api.guilds(this.guild.id).roles.patch({
282
- data: rolePositions,
283
- });
284
- return this.client.actions.GuildRolesPositionUpdate.handle({
285
- guild_id: this.guild.id,
286
- roles: rolePositions,
287
- }).guild;
288
- }
289
-
290
- /**
291
- * Compares the positions of two roles.
292
- * @param {RoleResolvable} role1 First role to compare
293
- * @param {RoleResolvable} role2 Second role to compare
294
- * @returns {number} Negative number if the first role's position is lower (second role's is higher),
295
- * positive number if the first's is higher (second's is lower), 0 if equal
296
- */
297
- comparePositions(role1, role2) {
298
- const resolvedRole1 = this.resolve(role1);
299
- const resolvedRole2 = this.resolve(role2);
300
- if (!resolvedRole1 || !resolvedRole2) throw new TypeError('INVALID_TYPE', 'role', 'Role nor a Snowflake');
301
-
302
- const role1Position = resolvedRole1.position;
303
- const role2Position = resolvedRole2.position;
304
-
305
- if (role1Position === role2Position) {
306
- return Number(BigInt(resolvedRole2.id) - BigInt(resolvedRole1.id));
307
- }
308
-
309
- return role1Position - role2Position;
310
- }
311
-
312
- /**
313
- * Gets the managed role a user created when joining the guild, if any
314
- * <info>Only ever available for bots</info>
315
- * @param {UserResolvable} user The user to access the bot role for
316
- * @returns {?Role}
317
- */
318
- botRoleFor(user) {
319
- const userId = this.client.users.resolveId(user);
320
- if (!userId) return null;
321
- return this.cache.find(role => role.tags?.botId === userId) ?? null;
322
- }
323
-
324
- /**
325
- * The `@everyone` role of the guild
326
- * @type {Role}
327
- * @readonly
328
- */
329
- get everyone() {
330
- return this.cache.get(this.guild.id);
331
- }
332
-
333
- /**
334
- * The premium subscriber role of the guild, if any
335
- * @type {?Role}
336
- * @readonly
337
- */
338
- get premiumSubscriberRole() {
339
- return this.cache.find(role => role.tags?.premiumSubscriberRole) ?? null;
340
- }
341
-
342
- /**
343
- * The role with the highest position in the cache
344
- * @type {Role}
345
- * @readonly
346
- */
347
- get highest() {
348
- return this.cache.reduce((prev, role) => (role.comparePositionTo(prev) > 0 ? role : prev), this.cache.first());
349
- }
350
- }
351
-
352
- module.exports = RoleManager;
1
+ 'use strict';
2
+
3
+ const process = require('node:process');
4
+ const { Collection } = require('@discordjs/collection');
5
+ const CachedManager = require('./CachedManager');
6
+ const { TypeError } = require('../errors');
7
+ const { Role } = require('../structures/Role');
8
+ const DataResolver = require('../util/DataResolver');
9
+ const Permissions = require('../util/Permissions');
10
+ const { resolveColor } = require('../util/Util');
11
+ const Util = require('../util/Util');
12
+
13
+ let cacheWarningEmitted = false;
14
+ let deprecationEmittedForCreate = false;
15
+ let deprecationEmittedForEdit = false;
16
+
17
+ /**
18
+ * Manages API methods for roles and stores their cache.
19
+ * @extends {CachedManager}
20
+ */
21
+ class RoleManager extends CachedManager {
22
+ constructor(guild, iterable) {
23
+ super(guild.client, Role, iterable);
24
+ if (!cacheWarningEmitted && this._cache.constructor.name !== 'Collection') {
25
+ cacheWarningEmitted = true;
26
+ process.emitWarning(
27
+ `Overriding the cache handling for ${this.constructor.name} is unsupported and breaks functionality.`,
28
+ 'UnsupportedCacheOverwriteWarning',
29
+ );
30
+ }
31
+
32
+ /**
33
+ * The guild belonging to this manager
34
+ * @type {Guild}
35
+ */
36
+ this.guild = guild;
37
+ }
38
+
39
+ /**
40
+ * The role cache of this manager
41
+ * @type {Collection<Snowflake, Role>}
42
+ * @name RoleManager#cache
43
+ */
44
+
45
+ _add(data, cache) {
46
+ return super._add(data, cache, { extras: [this.guild] });
47
+ }
48
+
49
+ /**
50
+ * Obtains a role from Discord, or the role cache if they're already available.
51
+ * @param {Snowflake} [id] The role's id
52
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
53
+ * @returns {Promise<?Role|Collection<Snowflake, Role>>}
54
+ * @example
55
+ * // Fetch all roles from the guild
56
+ * message.guild.roles.fetch()
57
+ * .then(roles => console.log(`There are ${roles.size} roles.`))
58
+ * .catch(console.error);
59
+ * @example
60
+ * // Fetch a single role
61
+ * message.guild.roles.fetch('222078108977594368')
62
+ * .then(role => console.log(`The role color is: ${role.colors.primaryColor}`))
63
+ * .catch(console.error);
64
+ */
65
+ async fetch(id, { cache = true, force = false } = {}) {
66
+ if (id && !force) {
67
+ const existing = this.cache.get(id);
68
+ if (existing) return existing;
69
+ }
70
+
71
+ // We cannot fetch a single role, as of this commit's date, Discord API throws with 405
72
+ const data = await this.client.api.guilds(this.guild.id).roles.get();
73
+ const roles = new Collection();
74
+ for (const role of data) roles.set(role.id, this._add(role, cache));
75
+ return id ? roles.get(id) ?? null : roles;
76
+ }
77
+
78
+ /**
79
+ * Fetches the member counts for each role in the guild.
80
+ * @returns {Promise<Record<Snowflake, number>>}
81
+ */
82
+ async fetchMemberCounts() {
83
+ const data = await this.client.api.guilds(this.guild.id).roles('member-counts').get();
84
+
85
+ return data;
86
+ }
87
+
88
+ /**
89
+ * Fetches the member ids for a role in the guild.
90
+ * <info>This only returns 100 member ids</info>
91
+ * @param {RoleResolvable} role The role to fetch member ids for
92
+ * @returns {Promise<Snowflake[]>}
93
+ */
94
+ async fetchMemberIds(role) {
95
+ const id = this.resolveId(role);
96
+ if (!id) throw new TypeError('INVALID_TYPE', 'role', 'RoleResolvable');
97
+
98
+ const data = await this.client.api.guilds(this.guild.id).roles(id, 'member-ids').get();
99
+
100
+ return data;
101
+ }
102
+
103
+ /**
104
+ * Data that can be resolved to a Role object. This can be:
105
+ * * A Role
106
+ * * A Snowflake
107
+ * @typedef {Role|Snowflake} RoleResolvable
108
+ */
109
+
110
+ /**
111
+ * Resolves a {@link RoleResolvable} to a {@link Role} object.
112
+ * @method resolve
113
+ * @memberof RoleManager
114
+ * @instance
115
+ * @param {RoleResolvable} role The role resolvable to resolve
116
+ * @returns {?Role}
117
+ */
118
+
119
+ /**
120
+ * Resolves a {@link RoleResolvable} to a {@link Role} id.
121
+ * @method resolveId
122
+ * @memberof RoleManager
123
+ * @instance
124
+ * @param {RoleResolvable} role The role resolvable to resolve
125
+ * @returns {?Snowflake}
126
+ */
127
+
128
+ /**
129
+ * @typedef {Object} RoleColorsResolvable
130
+ * @property {ColorResolvable} primaryColor The primary color of the role
131
+ * @property {ColorResolvable} [secondaryColor] The secondary color of the role.
132
+ * This will make the role a gradient between the other provided colors
133
+ * @property {ColorResolvable} [tertiaryColor] The tertiary color of the role.
134
+ * When sending `tertiaryColor` the API enforces the role color to be a holographic style
135
+ * with values of `primaryColor = 11127295`, `secondaryColor = 16759788`, and `tertiaryColor = 16761760`.
136
+ * These values are available as a constant: `Constants.HolographicStyle`
137
+ */
138
+
139
+ /**
140
+ * Options used to create a new role.
141
+ * @typedef {Object} CreateRoleOptions
142
+ * @property {string} [name] The name of the new role
143
+ * @property {ColorResolvable} [color] The data to create the role with
144
+ * <warn>This property is deprecated. Use `colors` instead.</warn>
145
+ * @property {RoleColorsResolvable} [colors] The colors to create the role with
146
+ * @property {boolean} [hoist] Whether or not the new role should be hoisted
147
+ * @property {PermissionResolvable} [permissions] The permissions for the new role
148
+ * @property {number} [position] The position of the new role
149
+ * @property {boolean} [mentionable] Whether or not the new role should be mentionable
150
+ * @property {?(BufferResolvable|Base64Resolvable|EmojiResolvable)} [icon] The icon for the role
151
+ * <warn>The `EmojiResolvable` should belong to the same guild as the role.
152
+ * If not, pass the emoji's URL directly</warn>
153
+ * @property {?string} [unicodeEmoji] The unicode emoji for the role
154
+ * @property {string} [reason] The reason for creating this role
155
+ */
156
+
157
+ /**
158
+ * Creates a new role in the guild with given information.
159
+ * <warn>The position will silently reset to 1 if an invalid one is provided, or none.</warn>
160
+ * @param {CreateRoleOptions} [options] Options for creating the new role
161
+ * @returns {Promise<Role>}
162
+ * @example
163
+ * // Create a new role
164
+ * guild.roles.create()
165
+ * .then(console.log)
166
+ * .catch(console.error);
167
+ * @example
168
+ * // Create a new role with data and a reason
169
+ * guild.roles.create({
170
+ * name: 'Super Cool Blue People',
171
+ * colors: {
172
+ * primaryColor: 'BLUE',
173
+ * },
174
+ * reason: 'we needed a role for Super Cool People',
175
+ * })
176
+ * .then(console.log)
177
+ * .catch(console.error);
178
+ * @example
179
+ * // Create a role with holographic colors
180
+ * guild.roles.create({
181
+ * name: 'Holographic Role',
182
+ * reason: 'Creating a role with holographic effect',
183
+ * colors: {
184
+ * primaryColor: Constants.HolographicStyles.PRIMARY,
185
+ * secondaryColor: Constants.HolographicStyles.SECONDARY,
186
+ * tertiaryColor: Constants.HolographicStyles.TERTIARY,
187
+ * },
188
+ * })
189
+ * .then(console.log)
190
+ * .catch(console.error);
191
+ */
192
+ async create(options = {}) {
193
+ let { permissions, icon } = options;
194
+ const { name, color, hoist, position, mentionable, reason, unicodeEmoji } = options;
195
+
196
+ if (typeof permissions !== 'undefined') permissions = new Permissions(permissions);
197
+ if (icon) {
198
+ const guildEmojiURL = this.guild.emojis.resolve(icon)?.url;
199
+ icon = guildEmojiURL ? await DataResolver.resolveImage(guildEmojiURL) : await DataResolver.resolveImage(icon);
200
+ if (typeof icon !== 'string') icon = undefined;
201
+ }
202
+
203
+ let colors = options.colors && {
204
+ primary_color: resolveColor(options.colors.primaryColor),
205
+ secondary_color: options.colors.secondaryColor && resolveColor(options.colors.secondaryColor),
206
+ tertiary_color: options.colors.tertiaryColor && resolveColor(options.colors.tertiaryColor),
207
+ };
208
+
209
+ if (color !== undefined) {
210
+ if (!deprecationEmittedForCreate) {
211
+ process.emitWarning(`Passing "color" to RoleManager#create() is deprecated. Use "colors" instead.`);
212
+ }
213
+
214
+ deprecationEmittedForCreate = true;
215
+
216
+ colors = {
217
+ primary_color: resolveColor(color),
218
+ secondary_color: null,
219
+ tertiary_color: null,
220
+ };
221
+ }
222
+
223
+ const data = await this.client.api.guilds(this.guild.id).roles.post({
224
+ data: {
225
+ name,
226
+ colors,
227
+ hoist,
228
+ permissions,
229
+ mentionable,
230
+ icon,
231
+ unicode_emoji: unicodeEmoji,
232
+ },
233
+ reason,
234
+ });
235
+ const { role } = this.client.actions.GuildRoleCreate.handle({
236
+ guild_id: this.guild.id,
237
+ role: data,
238
+ });
239
+ if (position) return this.setPosition(role, position, { reason });
240
+ return role;
241
+ }
242
+
243
+ /**
244
+ * Edits a role of the guild.
245
+ * @param {RoleResolvable} role The role to edit
246
+ * @param {RoleData} data The new data for the role
247
+ * @param {string} [reason] Reason for editing this role
248
+ * @returns {Promise<Role>}
249
+ * @example
250
+ * // Edit a role
251
+ * guild.roles.edit('222079219327434752', { name: 'buddies' })
252
+ * .then(updated => console.log(`Edited role name to ${updated.name}`))
253
+ * .catch(console.error);
254
+ */
255
+ async edit(role, data, reason) {
256
+ role = this.resolve(role);
257
+ if (!role) throw new TypeError('INVALID_TYPE', 'role', 'RoleResolvable');
258
+
259
+ if (typeof data.position === 'number') await this.setPosition(role, data.position, { reason });
260
+
261
+ let icon = data.icon;
262
+ if (icon) {
263
+ const guildEmojiURL = this.guild.emojis.resolve(icon)?.url;
264
+ icon = guildEmojiURL ? await DataResolver.resolveImage(guildEmojiURL) : await DataResolver.resolveImage(icon);
265
+ if (typeof icon !== 'string') icon = undefined;
266
+ }
267
+
268
+ let colors = data.colors && {
269
+ primary_color: resolveColor(data.colors.primaryColor),
270
+ secondary_color: data.colors.secondaryColor && resolveColor(data.colors.secondaryColor),
271
+ tertiary_color: data.colors.tertiaryColor && resolveColor(data.colors.tertiaryColor),
272
+ };
273
+
274
+ if (data.color !== undefined) {
275
+ if (!deprecationEmittedForEdit) {
276
+ process.emitWarning(`Passing "color" to RoleManager#edit() is deprecated. Use "colors" instead.`);
277
+ }
278
+
279
+ deprecationEmittedForEdit = true;
280
+
281
+ colors = {
282
+ primary_color: resolveColor(data.color),
283
+ secondary_color: null,
284
+ tertiary_color: null,
285
+ };
286
+ }
287
+
288
+ const _data = {
289
+ name: data.name,
290
+ colors,
291
+ hoist: data.hoist,
292
+ permissions: typeof data.permissions === 'undefined' ? undefined : new Permissions(data.permissions),
293
+ mentionable: data.mentionable,
294
+ icon,
295
+ unicode_emoji: data.unicodeEmoji,
296
+ };
297
+
298
+ const d = await this.client.api.guilds(this.guild.id).roles(role.id).patch({ data: _data, reason });
299
+
300
+ const clone = role._clone();
301
+ clone._patch(d);
302
+ return clone;
303
+ }
304
+
305
+ /**
306
+ * Deletes a role.
307
+ * @param {RoleResolvable} role The role to delete
308
+ * @param {string} [reason] Reason for deleting the role
309
+ * @returns {Promise<void>}
310
+ * @example
311
+ * // Delete a role
312
+ * guild.roles.delete('222079219327434752', 'The role needed to go')
313
+ * .then(() => console.log('Deleted the role.'))
314
+ * .catch(console.error);
315
+ */
316
+ async delete(role, reason) {
317
+ const id = this.resolveId(role);
318
+ await this.client.api.guilds[this.guild.id].roles[id].delete({ reason });
319
+ this.client.actions.GuildRoleDelete.handle({ guild_id: this.guild.id, role_id: id });
320
+ }
321
+
322
+ /**
323
+ * Sets the new position of the role.
324
+ * @param {RoleResolvable} role The role to change the position of
325
+ * @param {number} position The new position for the role
326
+ * @param {SetRolePositionOptions} [options] Options for setting the position
327
+ * @returns {Promise<Role>}
328
+ * @example
329
+ * // Set the position of the role
330
+ * guild.roles.setPosition('222197033908436994', 1)
331
+ * .then(updated => console.log(`Role position: ${updated.position}`))
332
+ * .catch(console.error);
333
+ */
334
+ async setPosition(role, position, { relative, reason } = {}) {
335
+ role = this.resolve(role);
336
+ if (!role) throw new TypeError('INVALID_TYPE', 'role', 'RoleResolvable');
337
+ const updatedRoles = await Util.setPosition(
338
+ role,
339
+ position,
340
+ relative,
341
+ this.guild._sortedRoles(),
342
+ this.client.api.guilds(this.guild.id).roles,
343
+ reason,
344
+ );
345
+
346
+ this.client.actions.GuildRolesPositionUpdate.handle({
347
+ guild_id: this.guild.id,
348
+ roles: updatedRoles,
349
+ });
350
+ return role;
351
+ }
352
+
353
+ /**
354
+ * The data needed for updating a guild role's position
355
+ * @typedef {Object} GuildRolePosition
356
+ * @property {RoleResolvable} role The role's id
357
+ * @property {number} position The position to update
358
+ */
359
+
360
+ /**
361
+ * Batch-updates the guild's role positions
362
+ * @param {GuildRolePosition[]} rolePositions Role positions to update
363
+ * @returns {Promise<Guild>}
364
+ * @example
365
+ * guild.roles.setPositions([{ role: roleId, position: updatedRoleIndex }])
366
+ * .then(guild => console.log(`Role positions updated for ${guild}`))
367
+ * .catch(console.error);
368
+ */
369
+ async setPositions(rolePositions) {
370
+ // Make sure rolePositions are prepared for API
371
+ rolePositions = rolePositions.map(o => ({
372
+ id: this.resolveId(o.role),
373
+ position: o.position,
374
+ }));
375
+
376
+ // Call the API to update role positions
377
+ await this.client.api.guilds(this.guild.id).roles.patch({
378
+ data: rolePositions,
379
+ });
380
+ return this.client.actions.GuildRolesPositionUpdate.handle({
381
+ guild_id: this.guild.id,
382
+ roles: rolePositions,
383
+ }).guild;
384
+ }
385
+
386
+ /**
387
+ * Compares the positions of two roles.
388
+ * @param {RoleResolvable} role1 First role to compare
389
+ * @param {RoleResolvable} role2 Second role to compare
390
+ * @returns {number} Negative number if the first role's position is lower (second role's is higher),
391
+ * positive number if the first's is higher (second's is lower), 0 if equal
392
+ */
393
+ comparePositions(role1, role2) {
394
+ const resolvedRole1 = this.resolve(role1);
395
+ const resolvedRole2 = this.resolve(role2);
396
+ if (!resolvedRole1 || !resolvedRole2) throw new TypeError('INVALID_TYPE', 'role', 'Role nor a Snowflake');
397
+
398
+ const role1Position = resolvedRole1.position;
399
+ const role2Position = resolvedRole2.position;
400
+
401
+ if (role1Position === role2Position) {
402
+ return Number(BigInt(resolvedRole2.id) - BigInt(resolvedRole1.id));
403
+ }
404
+
405
+ return role1Position - role2Position;
406
+ }
407
+
408
+ /**
409
+ * Gets the managed role a user created when joining the guild, if any
410
+ * <info>Only ever available for bots</info>
411
+ * @param {UserResolvable} user The user to access the bot role for
412
+ * @returns {?Role}
413
+ */
414
+ botRoleFor(user) {
415
+ const userId = this.client.users.resolveId(user);
416
+ if (!userId) return null;
417
+ return this.cache.find(role => role.tags?.botId === userId) ?? null;
418
+ }
419
+
420
+ /**
421
+ * The `@everyone` role of the guild
422
+ * @type {Role}
423
+ * @readonly
424
+ */
425
+ get everyone() {
426
+ return this.cache.get(this.guild.id);
427
+ }
428
+
429
+ /**
430
+ * The premium subscriber role of the guild, if any
431
+ * @type {?Role}
432
+ * @readonly
433
+ */
434
+ get premiumSubscriberRole() {
435
+ return this.cache.find(role => role.tags?.premiumSubscriberRole) ?? null;
436
+ }
437
+
438
+ /**
439
+ * The role with the highest position in the cache
440
+ * @type {Role}
441
+ * @readonly
442
+ */
443
+ get highest() {
444
+ return this.cache.reduce((prev, role) => (role.comparePositionTo(prev) > 0 ? role : prev), this.cache.first());
445
+ }
446
+ }
447
+
448
+ module.exports = RoleManager;