discord.js-selfbots-v13 0.0.1-security → 3.3.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of discord.js-selfbots-v13 might be problematic. Click here for more details.

Files changed (343) hide show
  1. package/LICENSE +674 -0
  2. package/README.md +127 -5
  3. package/package.json +101 -6
  4. package/src/WebSocket.js +39 -0
  5. package/src/client/BaseClient.js +87 -0
  6. package/src/client/Client.js +1154 -0
  7. package/src/client/WebhookClient.js +61 -0
  8. package/src/client/actions/Action.js +115 -0
  9. package/src/client/actions/ActionsManager.js +72 -0
  10. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  11. package/src/client/actions/AutoModerationActionExecution.js +26 -0
  12. package/src/client/actions/AutoModerationRuleCreate.js +27 -0
  13. package/src/client/actions/AutoModerationRuleDelete.js +31 -0
  14. package/src/client/actions/AutoModerationRuleUpdate.js +29 -0
  15. package/src/client/actions/ChannelCreate.js +23 -0
  16. package/src/client/actions/ChannelDelete.js +39 -0
  17. package/src/client/actions/ChannelUpdate.js +34 -0
  18. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
  19. package/src/client/actions/GuildBanAdd.js +20 -0
  20. package/src/client/actions/GuildBanRemove.js +25 -0
  21. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
  22. package/src/client/actions/GuildDelete.js +65 -0
  23. package/src/client/actions/GuildEmojiCreate.js +20 -0
  24. package/src/client/actions/GuildEmojiDelete.js +21 -0
  25. package/src/client/actions/GuildEmojiUpdate.js +20 -0
  26. package/src/client/actions/GuildEmojisUpdate.js +34 -0
  27. package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
  28. package/src/client/actions/GuildMemberRemove.js +33 -0
  29. package/src/client/actions/GuildMemberUpdate.js +44 -0
  30. package/src/client/actions/GuildRoleCreate.js +25 -0
  31. package/src/client/actions/GuildRoleDelete.js +31 -0
  32. package/src/client/actions/GuildRoleUpdate.js +39 -0
  33. package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
  34. package/src/client/actions/GuildScheduledEventCreate.js +27 -0
  35. package/src/client/actions/GuildScheduledEventDelete.js +31 -0
  36. package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
  37. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
  38. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
  39. package/src/client/actions/GuildStickerCreate.js +20 -0
  40. package/src/client/actions/GuildStickerDelete.js +21 -0
  41. package/src/client/actions/GuildStickerUpdate.js +20 -0
  42. package/src/client/actions/GuildStickersUpdate.js +34 -0
  43. package/src/client/actions/GuildUpdate.js +33 -0
  44. package/src/client/actions/InteractionCreate.js +115 -0
  45. package/src/client/actions/InviteCreate.js +28 -0
  46. package/src/client/actions/InviteDelete.js +30 -0
  47. package/src/client/actions/MessageCreate.js +50 -0
  48. package/src/client/actions/MessageDelete.js +32 -0
  49. package/src/client/actions/MessageDeleteBulk.js +46 -0
  50. package/src/client/actions/MessageReactionAdd.js +56 -0
  51. package/src/client/actions/MessageReactionRemove.js +45 -0
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  54. package/src/client/actions/MessageUpdate.js +26 -0
  55. package/src/client/actions/PresenceUpdate.js +45 -0
  56. package/src/client/actions/StageInstanceCreate.js +28 -0
  57. package/src/client/actions/StageInstanceDelete.js +33 -0
  58. package/src/client/actions/StageInstanceUpdate.js +30 -0
  59. package/src/client/actions/ThreadCreate.js +24 -0
  60. package/src/client/actions/ThreadDelete.js +32 -0
  61. package/src/client/actions/ThreadListSync.js +59 -0
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  64. package/src/client/actions/TypingStart.js +29 -0
  65. package/src/client/actions/UserUpdate.js +35 -0
  66. package/src/client/actions/VoiceStateUpdate.js +57 -0
  67. package/src/client/actions/WebhooksUpdate.js +20 -0
  68. package/src/client/voice/ClientVoiceManager.js +51 -0
  69. package/src/client/websocket/WebSocketManager.js +412 -0
  70. package/src/client/websocket/WebSocketShard.js +908 -0
  71. package/src/client/websocket/handlers/APPLICATION_COMMAND_AUTOCOMPLETE_RESPONSE.js +23 -0
  72. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  73. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  74. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  75. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  76. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  77. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  78. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  79. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  80. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  81. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  82. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  83. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  84. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  85. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  86. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +16 -0
  87. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  88. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  89. package/src/client/websocket/handlers/GUILD_APPLICATION_COMMANDS_UPDATE.js +11 -0
  90. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  91. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  92. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  93. package/src/client/websocket/handlers/GUILD_CREATE.js +46 -0
  94. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  95. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  96. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  97. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  98. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  99. package/src/client/websocket/handlers/GUILD_MEMBER_LIST_UPDATE.js +55 -0
  100. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  101. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  102. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  103. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  104. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  105. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  106. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  107. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  108. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  109. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  110. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  111. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  112. package/src/client/websocket/handlers/INTERACTION_CREATE.js +16 -0
  113. package/src/client/websocket/handlers/INTERACTION_FAILURE.js +18 -0
  114. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +11 -0
  115. package/src/client/websocket/handlers/INTERACTION_SUCCESS.js +30 -0
  116. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  117. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  118. package/src/client/websocket/handlers/MESSAGE_ACK.js +16 -0
  119. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  120. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  121. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  122. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
  123. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  124. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  125. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  126. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  127. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  128. package/src/client/websocket/handlers/READY.js +172 -0
  129. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +17 -0
  130. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +15 -0
  131. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +18 -0
  132. package/src/client/websocket/handlers/RESUMED.js +14 -0
  133. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  134. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  135. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  136. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  137. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  138. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  139. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  140. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  141. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  142. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  143. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +12 -0
  144. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  145. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +9 -0
  146. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  147. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  148. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  149. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  150. package/src/client/websocket/handlers/index.js +86 -0
  151. package/src/errors/DJSError.js +61 -0
  152. package/src/errors/Messages.js +227 -0
  153. package/src/errors/index.js +4 -0
  154. package/src/index.js +190 -0
  155. package/src/main.js +1 -0
  156. package/src/managers/ApplicationCommandManager.js +267 -0
  157. package/src/managers/ApplicationCommandPermissionsManager.js +425 -0
  158. package/src/managers/AutoModerationRuleManager.js +296 -0
  159. package/src/managers/BaseGuildEmojiManager.js +80 -0
  160. package/src/managers/BaseManager.js +19 -0
  161. package/src/managers/BillingManager.js +66 -0
  162. package/src/managers/CachedManager.js +71 -0
  163. package/src/managers/ChannelManager.js +139 -0
  164. package/src/managers/ClientUserSettingManager.js +490 -0
  165. package/src/managers/DataManager.js +61 -0
  166. package/src/managers/DeveloperPortalManager.js +104 -0
  167. package/src/managers/GuildApplicationCommandManager.js +28 -0
  168. package/src/managers/GuildBanManager.js +204 -0
  169. package/src/managers/GuildChannelManager.js +502 -0
  170. package/src/managers/GuildEmojiManager.js +171 -0
  171. package/src/managers/GuildEmojiRoleManager.js +118 -0
  172. package/src/managers/GuildFolderManager.js +24 -0
  173. package/src/managers/GuildForumThreadManager.js +114 -0
  174. package/src/managers/GuildInviteManager.js +213 -0
  175. package/src/managers/GuildManager.js +304 -0
  176. package/src/managers/GuildMemberManager.js +724 -0
  177. package/src/managers/GuildMemberRoleManager.js +191 -0
  178. package/src/managers/GuildScheduledEventManager.js +296 -0
  179. package/src/managers/GuildSettingManager.js +148 -0
  180. package/src/managers/GuildStickerManager.js +179 -0
  181. package/src/managers/GuildTextThreadManager.js +98 -0
  182. package/src/managers/InteractionManager.js +39 -0
  183. package/src/managers/MessageManager.js +393 -0
  184. package/src/managers/PermissionOverwriteManager.js +166 -0
  185. package/src/managers/PresenceManager.js +58 -0
  186. package/src/managers/ReactionManager.js +67 -0
  187. package/src/managers/ReactionUserManager.js +71 -0
  188. package/src/managers/RelationshipManager.js +258 -0
  189. package/src/managers/RoleManager.js +352 -0
  190. package/src/managers/SessionManager.js +57 -0
  191. package/src/managers/StageInstanceManager.js +162 -0
  192. package/src/managers/ThreadManager.js +207 -0
  193. package/src/managers/ThreadMemberManager.js +186 -0
  194. package/src/managers/UserManager.js +150 -0
  195. package/src/managers/VoiceStateManager.js +37 -0
  196. package/src/rest/APIRequest.js +136 -0
  197. package/src/rest/APIRouter.js +53 -0
  198. package/src/rest/CaptchaSolver.js +78 -0
  199. package/src/rest/DiscordAPIError.js +103 -0
  200. package/src/rest/HTTPError.js +62 -0
  201. package/src/rest/RESTManager.js +81 -0
  202. package/src/rest/RateLimitError.js +55 -0
  203. package/src/rest/RequestHandler.js +446 -0
  204. package/src/sharding/Shard.js +443 -0
  205. package/src/sharding/ShardClientUtil.js +275 -0
  206. package/src/sharding/ShardingManager.js +318 -0
  207. package/src/structures/AnonymousGuild.js +98 -0
  208. package/src/structures/ApplicationCommand.js +1028 -0
  209. package/src/structures/ApplicationRoleConnectionMetadata.js +45 -0
  210. package/src/structures/AutoModerationActionExecution.js +89 -0
  211. package/src/structures/AutoModerationRule.js +294 -0
  212. package/src/structures/AutocompleteInteraction.js +106 -0
  213. package/src/structures/Base.js +43 -0
  214. package/src/structures/BaseCommandInteraction.js +211 -0
  215. package/src/structures/BaseGuild.js +116 -0
  216. package/src/structures/BaseGuildEmoji.js +56 -0
  217. package/src/structures/BaseGuildTextChannel.js +193 -0
  218. package/src/structures/BaseGuildVoiceChannel.js +243 -0
  219. package/src/structures/BaseMessageComponent.js +114 -0
  220. package/src/structures/ButtonInteraction.js +11 -0
  221. package/src/structures/Call.js +58 -0
  222. package/src/structures/CategoryChannel.js +83 -0
  223. package/src/structures/Channel.js +271 -0
  224. package/src/structures/ClientApplication.js +204 -0
  225. package/src/structures/ClientPresence.js +84 -0
  226. package/src/structures/ClientUser.js +624 -0
  227. package/src/structures/CommandInteraction.js +41 -0
  228. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  229. package/src/structures/ContextMenuInteraction.js +65 -0
  230. package/src/structures/DMChannel.js +280 -0
  231. package/src/structures/DeveloperPortalApplication.js +520 -0
  232. package/src/structures/DirectoryChannel.js +20 -0
  233. package/src/structures/Emoji.js +148 -0
  234. package/src/structures/ForumChannel.js +271 -0
  235. package/src/structures/Guild.js +1744 -0
  236. package/src/structures/GuildAuditLogs.js +734 -0
  237. package/src/structures/GuildBan.js +59 -0
  238. package/src/structures/GuildBoost.js +108 -0
  239. package/src/structures/GuildChannel.js +454 -0
  240. package/src/structures/GuildEmoji.js +161 -0
  241. package/src/structures/GuildFolder.js +75 -0
  242. package/src/structures/GuildMember.js +686 -0
  243. package/src/structures/GuildPreview.js +191 -0
  244. package/src/structures/GuildPreviewEmoji.js +27 -0
  245. package/src/structures/GuildScheduledEvent.js +441 -0
  246. package/src/structures/GuildTemplate.js +236 -0
  247. package/src/structures/Integration.js +188 -0
  248. package/src/structures/IntegrationApplication.js +96 -0
  249. package/src/structures/Interaction.js +351 -0
  250. package/src/structures/InteractionCollector.js +248 -0
  251. package/src/structures/InteractionResponse.js +114 -0
  252. package/src/structures/InteractionWebhook.js +43 -0
  253. package/src/structures/Invite.js +375 -0
  254. package/src/structures/InviteGuild.js +23 -0
  255. package/src/structures/InviteStageInstance.js +86 -0
  256. package/src/structures/Message.js +1188 -0
  257. package/src/structures/MessageActionRow.js +103 -0
  258. package/src/structures/MessageAttachment.js +193 -0
  259. package/src/structures/MessageButton.js +231 -0
  260. package/src/structures/MessageCollector.js +146 -0
  261. package/src/structures/MessageComponentInteraction.js +120 -0
  262. package/src/structures/MessageContextMenuInteraction.js +20 -0
  263. package/src/structures/MessageEmbed.js +586 -0
  264. package/src/structures/MessageMentions.js +272 -0
  265. package/src/structures/MessagePayload.js +358 -0
  266. package/src/structures/MessageReaction.js +171 -0
  267. package/src/structures/MessageSelectMenu.js +391 -0
  268. package/src/structures/Modal.js +279 -0
  269. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  270. package/src/structures/ModalSubmitInteraction.js +119 -0
  271. package/src/structures/NewsChannel.js +32 -0
  272. package/src/structures/OAuth2Guild.js +28 -0
  273. package/src/structures/PartialGroupDMChannel.js +430 -0
  274. package/src/structures/PermissionOverwrites.js +196 -0
  275. package/src/structures/Presence.js +441 -0
  276. package/src/structures/ReactionCollector.js +229 -0
  277. package/src/structures/ReactionEmoji.js +31 -0
  278. package/src/structures/RichPresence.js +722 -0
  279. package/src/structures/Role.js +515 -0
  280. package/src/structures/SelectMenuInteraction.js +170 -0
  281. package/src/structures/Session.js +81 -0
  282. package/src/structures/StageChannel.js +104 -0
  283. package/src/structures/StageInstance.js +208 -0
  284. package/src/structures/Sticker.js +310 -0
  285. package/src/structures/StickerPack.js +95 -0
  286. package/src/structures/StoreChannel.js +56 -0
  287. package/src/structures/Team.js +167 -0
  288. package/src/structures/TeamMember.js +71 -0
  289. package/src/structures/TextChannel.js +33 -0
  290. package/src/structures/TextInputComponent.js +201 -0
  291. package/src/structures/ThreadChannel.js +626 -0
  292. package/src/structures/ThreadMember.js +105 -0
  293. package/src/structures/Typing.js +74 -0
  294. package/src/structures/User.js +697 -0
  295. package/src/structures/UserContextMenuInteraction.js +29 -0
  296. package/src/structures/VoiceChannel.js +110 -0
  297. package/src/structures/VoiceRegion.js +53 -0
  298. package/src/structures/VoiceState.js +306 -0
  299. package/src/structures/WebEmbed.js +401 -0
  300. package/src/structures/Webhook.js +461 -0
  301. package/src/structures/WelcomeChannel.js +60 -0
  302. package/src/structures/WelcomeScreen.js +48 -0
  303. package/src/structures/Widget.js +87 -0
  304. package/src/structures/WidgetMember.js +99 -0
  305. package/src/structures/interfaces/Application.js +190 -0
  306. package/src/structures/interfaces/Collector.js +300 -0
  307. package/src/structures/interfaces/InteractionResponses.js +313 -0
  308. package/src/structures/interfaces/TextBasedChannel.js +566 -0
  309. package/src/util/ActivityFlags.js +44 -0
  310. package/src/util/ApplicationFlags.js +74 -0
  311. package/src/util/BitField.js +170 -0
  312. package/src/util/ChannelFlags.js +45 -0
  313. package/src/util/Constants.js +1917 -0
  314. package/src/util/DataResolver.js +145 -0
  315. package/src/util/Formatters.js +214 -0
  316. package/src/util/GuildMemberFlags.js +43 -0
  317. package/src/util/Intents.js +74 -0
  318. package/src/util/LimitedCollection.js +131 -0
  319. package/src/util/MessageFlags.js +54 -0
  320. package/src/util/Options.js +360 -0
  321. package/src/util/Permissions.js +187 -0
  322. package/src/util/PremiumUsageFlags.js +31 -0
  323. package/src/util/PurchasedFlags.js +31 -0
  324. package/src/util/RemoteAuth.js +522 -0
  325. package/src/util/SnowflakeUtil.js +92 -0
  326. package/src/util/Sweepers.js +466 -0
  327. package/src/util/SystemChannelFlags.js +55 -0
  328. package/src/util/ThreadMemberFlags.js +30 -0
  329. package/src/util/UserFlags.js +104 -0
  330. package/src/util/Util.js +741 -0
  331. package/src/util/Voice.js +1456 -0
  332. package/src/util/arRPC/index.js +229 -0
  333. package/src/util/arRPC/process/detectable.json +1 -0
  334. package/src/util/arRPC/process/index.js +102 -0
  335. package/src/util/arRPC/process/native/index.js +5 -0
  336. package/src/util/arRPC/process/native/linux.js +37 -0
  337. package/src/util/arRPC/process/native/win32.js +25 -0
  338. package/src/util/arRPC/transports/ipc.js +281 -0
  339. package/src/util/arRPC/transports/websocket.js +128 -0
  340. package/typings/enums.d.ts +346 -0
  341. package/typings/index.d.ts +7725 -0
  342. package/typings/index.test-d.ts +0 -0
  343. package/typings/rawDataTypes.d.ts +283 -0
@@ -0,0 +1,71 @@
1
+ 'use strict';
2
+
3
+ const { Collection } = require('@discordjs/collection');
4
+ const CachedManager = require('./CachedManager');
5
+ const { Error } = require('../errors');
6
+ const { lazy } = require('../util/Util');
7
+ const User = lazy(() => require('../structures/User'));
8
+ /**
9
+ * Manages API methods for users who reacted to a reaction and stores their cache.
10
+ * @extends {CachedManager}
11
+ */
12
+ class ReactionUserManager extends CachedManager {
13
+ constructor(reaction, iterable) {
14
+ super(reaction.client, User(), iterable);
15
+
16
+ /**
17
+ * The reaction that this manager belongs to
18
+ * @type {MessageReaction}
19
+ */
20
+ this.reaction = reaction;
21
+ }
22
+
23
+ /**
24
+ * The cache of this manager
25
+ * @type {Collection<Snowflake, Discord.User>}
26
+ * @name ReactionUserManager#cache
27
+ */
28
+
29
+ /**
30
+ * Options used to fetch users who gave a reaction.
31
+ * @typedef {Object} FetchReactionUsersOptions
32
+ * @property {number} [limit=100] The maximum amount of users to fetch, defaults to `100`
33
+ * @property {Snowflake} [after] Limit fetching users to those with an id greater than the supplied id
34
+ */
35
+
36
+ /**
37
+ * Fetches all the users that gave this reaction. Resolves with a collection of users, mapped by their ids.
38
+ * @param {FetchReactionUsersOptions} [options] Options for fetching the users
39
+ * @returns {Promise<Collection<Snowflake, Discord.User>>}
40
+ */
41
+ async fetch({ limit = 100, after } = {}) {
42
+ const message = this.reaction.message;
43
+ const data = await this.client.api.channels[message.channelId].messages[message.id].reactions[
44
+ this.reaction.emoji.identifier
45
+ ].get({ query: { limit, after } });
46
+ const users = new Collection();
47
+ for (const rawUser of data) {
48
+ const user = this.client.users._add(rawUser);
49
+ this.cache.set(user.id, user);
50
+ users.set(user.id, user);
51
+ }
52
+ return users;
53
+ }
54
+
55
+ /**
56
+ * Removes a user from this reaction.
57
+ * @param {UserResolvable} [user=this.client.user] The user to remove the reaction of
58
+ * @returns {Promise<MessageReaction>}
59
+ */
60
+ async remove(user = this.client.user) {
61
+ const userId = this.client.users.resolveId(user);
62
+ if (!userId) throw new Error('REACTION_RESOLVE_USER');
63
+ const message = this.reaction.message;
64
+ await this.client.api.channels[message.channelId].messages[message.id].reactions[this.reaction.emoji.identifier][
65
+ userId === this.client.user.id ? '@me' : userId
66
+ ].delete();
67
+ return this.reaction;
68
+ }
69
+ }
70
+
71
+ module.exports = ReactionUserManager;
@@ -0,0 +1,258 @@
1
+ 'use strict';
2
+
3
+ const Buffer = require('node:buffer').Buffer;
4
+ const { Collection } = require('@discordjs/collection');
5
+ const { GuildMember } = require('../structures/GuildMember');
6
+ const { Message } = require('../structures/Message');
7
+ const ThreadMember = require('../structures/ThreadMember');
8
+ const User = require('../structures/User');
9
+ const { RelationshipTypes } = require('../util/Constants');
10
+
11
+ /**
12
+ * Manages API methods for Relationships and stores their cache.
13
+ */
14
+ class RelationshipManager {
15
+ constructor(client, users) {
16
+ /**
17
+ * The client that instantiated this manager.
18
+ * @type {Client}
19
+ */
20
+ this.client = client;
21
+ /**
22
+ * A collection of users this manager is caching. (Type: Number)
23
+ * @type {Collection<Snowflake, RelationshipTypes>}
24
+ * @readonly
25
+ */
26
+ this.cache = new Collection();
27
+ this._setup(users);
28
+ }
29
+
30
+ /**
31
+ * Get all friends
32
+ * @type {Collection<Snowflake, User>}
33
+ * @readonly
34
+ */
35
+ get friendCache() {
36
+ const users = this.cache
37
+ .filter(value => value === RelationshipTypes.FRIEND)
38
+ .map((value, key) => [key, this.client.users.cache.get(key)]);
39
+ return new Collection(users);
40
+ }
41
+
42
+ /**
43
+ * Get all blocked users
44
+ * @type {Collection<Snowflake, User>}
45
+ * @readonly
46
+ */
47
+ get blockedCache() {
48
+ const users = this.cache
49
+ .filter(value => value === RelationshipTypes.BLOCKED)
50
+ .map((value, key) => [key, this.client.users.cache.get(key)]);
51
+ return new Collection(users);
52
+ }
53
+
54
+ /**
55
+ * Get all incoming friend requests
56
+ * @type {Collection<Snowflake, User>}
57
+ * @readonly
58
+ */
59
+ get incomingCache() {
60
+ const users = this.cache
61
+ .filter(value => value === RelationshipTypes.PENDING_INCOMING)
62
+ .map((value, key) => [key, this.client.users.cache.get(key)]);
63
+ return new Collection(users);
64
+ }
65
+
66
+ /**
67
+ * Get all outgoing friend requests
68
+ * @type {Collection<Snowflake, User>}
69
+ * @readonly
70
+ */
71
+ get outgoingCache() {
72
+ const users = this.cache
73
+ .filter(value => value === RelationshipTypes.PENDING_OUTGOING)
74
+ .map((value, key) => [key, this.client.users.cache.get(key)]);
75
+ return new Collection(users);
76
+ }
77
+
78
+ /**
79
+ * Return array of cache
80
+ * @returns {Array<{id: Snowflake, type: RelationshipTypes}>}
81
+ */
82
+ toArray() {
83
+ return this.cache.map((value, key) => ({ id: key, type: RelationshipTypes[value] }));
84
+ }
85
+
86
+ /**
87
+ * @private
88
+ * @param {Array<User>} users An array of users to add to the cache
89
+ * @returns {void}
90
+ */
91
+ _setup(users) {
92
+ if (!Array.isArray(users)) return;
93
+ for (const relationShip of users) {
94
+ this.client.user.friendNicknames.set(relationShip.id, relationShip.nickname);
95
+ this.cache.set(relationShip.id, relationShip.type);
96
+ }
97
+ }
98
+
99
+ /**
100
+ * Resolves a {@link UserResolvable} to a {@link User} id.
101
+ * @param {UserResolvable} user The UserResolvable to identify
102
+ * @returns {?Snowflake}
103
+ */
104
+ resolveId(user) {
105
+ if (user instanceof ThreadMember) return user.id;
106
+ if (user instanceof GuildMember) return user.user.id;
107
+ if (user instanceof Message) return user.author.id;
108
+ if (user instanceof User) return user.id;
109
+ return user;
110
+ }
111
+
112
+ /**
113
+ * Obtains a user from Discord, or the user cache if it's already available.
114
+ * @param {UserResolvable} [user] The user to fetch
115
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
116
+ * @returns {Promise<RelationshipTypes|RelationshipManager>}
117
+ */
118
+ async fetch(user, { force = false } = {}) {
119
+ if (user) {
120
+ const id = this.resolveId(user);
121
+ if (!force) {
122
+ const existing = this.cache.get(id);
123
+ if (existing && !existing.partial) return existing;
124
+ }
125
+ const data = await this.client.api.users['@me'].relationships.get();
126
+ await this._setup(data);
127
+ return this.cache.get(id);
128
+ } else {
129
+ const data = await this.client.api.users['@me'].relationships.get();
130
+ await this._setup(data);
131
+ return this;
132
+ }
133
+ }
134
+
135
+ /**
136
+ * Deletes a friend relationship with a client user.
137
+ * @param {UserResolvable} user Target
138
+ * @returns {Promise<boolean>}
139
+ */
140
+ deleteFriend(user) {
141
+ const id = this.resolveId(user);
142
+ // Check if already friends
143
+ if (this.cache.get(id) !== RelationshipTypes.FRIEND) return false;
144
+ return this.__cancel(id);
145
+ }
146
+
147
+ /**
148
+ * Deletes a blocked relationship with a client user.
149
+ * @param {UserResolvable} user Target
150
+ * @returns {Promise<boolean>}
151
+ */
152
+ deleteBlocked(user) {
153
+ const id = this.resolveId(user);
154
+ // Check if already blocked
155
+ if (this.cache.get(id) !== RelationshipTypes.BLOCKED) return false;
156
+ return this.__cancel(id);
157
+ }
158
+
159
+ /**
160
+ * Sends a friend request.
161
+ * @param {string} username Username of the user to send the request to
162
+ * @param {number} discriminator Discriminator of the user to send the request to
163
+ * @returns {Promise<boolean>}
164
+ */
165
+ async sendFriendRequest(username, discriminator) {
166
+ await this.client.api.users('@me').relationships.post({
167
+ data: {
168
+ username,
169
+ discriminator: parseInt(discriminator),
170
+ },
171
+ headers: {
172
+ 'X-Context-Properties': Buffer.from(JSON.stringify({ location: 'Add Friend' }), 'utf8').toString('base64'),
173
+ },
174
+ });
175
+ return true;
176
+ }
177
+
178
+ /**
179
+ * Cancels a friend request.
180
+ * @param {UserResolvable} user the user you want to delete
181
+ * @returns {Promise<boolean>}
182
+ */
183
+ cancelFriendRequest(user) {
184
+ const id = this.resolveId(user);
185
+ if (this.cache.get(id) !== RelationshipTypes.PENDING_OUTGOING) return false;
186
+ return this.__cancel(id);
187
+ }
188
+
189
+ async __cancel(id) {
190
+ await this.client.api.users['@me'].relationships[id].delete({
191
+ headers: {
192
+ 'X-Context-Properties': Buffer.from(JSON.stringify({ location: 'Friends' }), 'utf8').toString('base64'),
193
+ },
194
+ });
195
+ return true;
196
+ }
197
+
198
+ /**
199
+ * Accepts a friend request.
200
+ * @param {UserResolvable} user The user to add as a friend
201
+ * @returns {Promise<boolean>}
202
+ */
203
+ async addFriend(user) {
204
+ const id = this.resolveId(user);
205
+ // Check if already friends
206
+ if (this.cache.get(id) === RelationshipTypes.FRIEND) return false;
207
+ // Check if outgoing request
208
+ if (this.cache.get(id) === RelationshipTypes.PENDING_OUTGOING) return false;
209
+ await this.client.api.users['@me'].relationships[id].put({
210
+ data: {
211
+ type: RelationshipTypes.FRIEND,
212
+ },
213
+ headers: {
214
+ 'X-Context-Properties': Buffer.from(JSON.stringify({ location: 'Friends' }), 'utf8').toString('base64'),
215
+ },
216
+ });
217
+ return true;
218
+ }
219
+
220
+ /**
221
+ * Changes the nickname of a friend.
222
+ * @param {UserResolvable} user The user to change the nickname
223
+ * @param {?string} nickname New nickname
224
+ * @returns {Promise<boolean>}
225
+ */
226
+ async setNickname(user, nickname) {
227
+ const id = this.resolveId(user);
228
+ if (this.cache.get(id) !== RelationshipTypes.FRIEND) return false;
229
+ await this.client.api.users['@me'].relationships[id].patch({
230
+ data: {
231
+ nickname: typeof nickname === 'string' ? nickname : null,
232
+ },
233
+ });
234
+ return true;
235
+ }
236
+
237
+ /**
238
+ * Blocks a user.
239
+ * @param {UserResolvable} user User to block
240
+ * @returns {Promise<boolean>}
241
+ */
242
+ async addBlocked(user) {
243
+ const id = this.resolveId(user);
244
+ // Check
245
+ if (this.cache.get(id) === RelationshipTypes.BLOCKED) return false;
246
+ await this.client.api.users['@me'].relationships[id].put({
247
+ data: {
248
+ type: RelationshipTypes.BLOCKED,
249
+ },
250
+ headers: {
251
+ 'X-Context-Properties': Buffer.from(JSON.stringify({ location: 'ContextMenu' }), 'utf8').toString('base64'),
252
+ },
253
+ });
254
+ return true;
255
+ }
256
+ }
257
+
258
+ module.exports = RelationshipManager;
@@ -0,0 +1,352 @@
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;