safeness-sb-new 0.0.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 (343) hide show
  1. package/README.md +115 -0
  2. package/package.json +96 -0
  3. package/src/WebSocket.js +39 -0
  4. package/src/client/BaseClient.js +86 -0
  5. package/src/client/Client.js +836 -0
  6. package/src/client/WebhookClient.js +61 -0
  7. package/src/client/actions/Action.js +120 -0
  8. package/src/client/actions/ActionsManager.js +78 -0
  9. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
  10. package/src/client/actions/AutoModerationActionExecution.js +27 -0
  11. package/src/client/actions/AutoModerationRuleCreate.js +28 -0
  12. package/src/client/actions/AutoModerationRuleDelete.js +32 -0
  13. package/src/client/actions/AutoModerationRuleUpdate.js +30 -0
  14. package/src/client/actions/ChannelCreate.js +23 -0
  15. package/src/client/actions/ChannelDelete.js +39 -0
  16. package/src/client/actions/ChannelUpdate.js +43 -0
  17. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
  18. package/src/client/actions/GuildBanAdd.js +20 -0
  19. package/src/client/actions/GuildBanRemove.js +25 -0
  20. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
  21. package/src/client/actions/GuildDelete.js +65 -0
  22. package/src/client/actions/GuildEmojiCreate.js +20 -0
  23. package/src/client/actions/GuildEmojiDelete.js +21 -0
  24. package/src/client/actions/GuildEmojiUpdate.js +20 -0
  25. package/src/client/actions/GuildEmojisUpdate.js +34 -0
  26. package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
  27. package/src/client/actions/GuildMemberRemove.js +33 -0
  28. package/src/client/actions/GuildMemberUpdate.js +44 -0
  29. package/src/client/actions/GuildRoleCreate.js +25 -0
  30. package/src/client/actions/GuildRoleDelete.js +31 -0
  31. package/src/client/actions/GuildRoleUpdate.js +39 -0
  32. package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
  33. package/src/client/actions/GuildScheduledEventCreate.js +27 -0
  34. package/src/client/actions/GuildScheduledEventDelete.js +31 -0
  35. package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
  36. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
  37. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
  38. package/src/client/actions/GuildStickerCreate.js +20 -0
  39. package/src/client/actions/GuildStickerDelete.js +21 -0
  40. package/src/client/actions/GuildStickerUpdate.js +20 -0
  41. package/src/client/actions/GuildStickersUpdate.js +34 -0
  42. package/src/client/actions/GuildUpdate.js +33 -0
  43. package/src/client/actions/InviteCreate.js +28 -0
  44. package/src/client/actions/InviteDelete.js +30 -0
  45. package/src/client/actions/MessageCreate.js +46 -0
  46. package/src/client/actions/MessageDelete.js +32 -0
  47. package/src/client/actions/MessageDeleteBulk.js +46 -0
  48. package/src/client/actions/MessageReactionAdd.js +56 -0
  49. package/src/client/actions/MessageReactionRemove.js +45 -0
  50. package/src/client/actions/MessageReactionRemoveAll.js +33 -0
  51. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
  52. package/src/client/actions/MessageUpdate.js +26 -0
  53. package/src/client/actions/PresenceUpdate.js +46 -0
  54. package/src/client/actions/StageInstanceCreate.js +28 -0
  55. package/src/client/actions/StageInstanceDelete.js +33 -0
  56. package/src/client/actions/StageInstanceUpdate.js +30 -0
  57. package/src/client/actions/ThreadCreate.js +24 -0
  58. package/src/client/actions/ThreadDelete.js +32 -0
  59. package/src/client/actions/ThreadListSync.js +59 -0
  60. package/src/client/actions/ThreadMemberUpdate.js +30 -0
  61. package/src/client/actions/ThreadMembersUpdate.js +34 -0
  62. package/src/client/actions/TypingStart.js +29 -0
  63. package/src/client/actions/UserUpdate.js +35 -0
  64. package/src/client/actions/VoiceStateUpdate.js +57 -0
  65. package/src/client/actions/WebhooksUpdate.js +20 -0
  66. package/src/client/voice/ClientVoiceManager.js +150 -0
  67. package/src/client/voice/VoiceConnection.js +849 -0
  68. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  69. package/src/client/voice/dispatcher/AudioDispatcher.js +115 -0
  70. package/src/client/voice/dispatcher/BaseDispatcher.js +405 -0
  71. package/src/client/voice/dispatcher/VPxDispatcher.js +52 -0
  72. package/src/client/voice/dispatcher/VideoDispatcher.js +31 -0
  73. package/src/client/voice/networking/VoiceUDPClient.js +188 -0
  74. package/src/client/voice/networking/VoiceWebSocket.js +280 -0
  75. package/src/client/voice/player/MediaPlayer.js +294 -0
  76. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  77. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  78. package/src/client/voice/receiver/PacketHandler.js +170 -0
  79. package/src/client/voice/receiver/Receiver.js +82 -0
  80. package/src/client/voice/receiver/video/IvfJoinner.js +106 -0
  81. package/src/client/voice/util/Function.js +14 -0
  82. package/src/client/voice/util/PlayInterface.js +122 -0
  83. package/src/client/voice/util/Secretbox.js +42 -0
  84. package/src/client/voice/util/Silence.js +16 -0
  85. package/src/client/voice/util/Socket.js +62 -0
  86. package/src/client/voice/util/VolumeInterface.js +104 -0
  87. package/src/client/websocket/WebSocketManager.js +392 -0
  88. package/src/client/websocket/WebSocketShard.js +906 -0
  89. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
  90. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
  91. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
  92. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
  93. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
  94. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
  95. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
  96. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
  97. package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
  98. package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
  99. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
  100. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
  101. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
  102. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
  103. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -0
  104. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
  105. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
  106. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
  107. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
  108. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
  109. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -0
  110. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
  111. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
  112. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
  113. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
  114. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
  115. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
  116. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
  117. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
  118. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
  119. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
  120. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
  121. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
  122. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
  123. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
  125. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
  126. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
  127. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -0
  128. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
  129. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
  130. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
  131. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
  132. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
  133. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +22 -0
  134. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +12 -0
  135. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
  136. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
  137. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
  138. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
  139. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
  140. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
  141. package/src/client/websocket/handlers/READY.js +120 -0
  142. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -0
  143. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -0
  144. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -0
  145. package/src/client/websocket/handlers/RESUMED.js +14 -0
  146. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
  147. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
  148. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
  149. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
  150. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
  151. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
  152. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
  153. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
  154. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
  155. package/src/client/websocket/handlers/TYPING_START.js +5 -0
  156. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -0
  157. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
  158. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -0
  159. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -0
  160. package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
  161. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -0
  162. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
  163. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
  164. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
  165. package/src/client/websocket/handlers/index.js +83 -0
  166. package/src/errors/DJSError.js +61 -0
  167. package/src/errors/Messages.js +208 -0
  168. package/src/errors/index.js +4 -0
  169. package/src/index.js +159 -0
  170. package/src/managers/ApplicationCommandManager.js +264 -0
  171. package/src/managers/ApplicationCommandPermissionsManager.js +417 -0
  172. package/src/managers/AutoModerationRuleManager.js +296 -0
  173. package/src/managers/BaseGuildEmojiManager.js +80 -0
  174. package/src/managers/BaseManager.js +19 -0
  175. package/src/managers/BillingManager.js +66 -0
  176. package/src/managers/CachedManager.js +71 -0
  177. package/src/managers/ChannelManager.js +138 -0
  178. package/src/managers/ClientUserSettingManager.js +372 -0
  179. package/src/managers/DataManager.js +61 -0
  180. package/src/managers/GuildBanManager.js +204 -0
  181. package/src/managers/GuildChannelManager.js +488 -0
  182. package/src/managers/GuildEmojiManager.js +171 -0
  183. package/src/managers/GuildEmojiRoleManager.js +118 -0
  184. package/src/managers/GuildForumThreadManager.js +108 -0
  185. package/src/managers/GuildInviteManager.js +213 -0
  186. package/src/managers/GuildManager.js +304 -0
  187. package/src/managers/GuildMemberManager.js +597 -0
  188. package/src/managers/GuildMemberRoleManager.js +191 -0
  189. package/src/managers/GuildScheduledEventManager.js +296 -0
  190. package/src/managers/GuildSettingManager.js +155 -0
  191. package/src/managers/GuildStickerManager.js +179 -0
  192. package/src/managers/GuildTextThreadManager.js +98 -0
  193. package/src/managers/InteractionManager.js +39 -0
  194. package/src/managers/MessageManager.js +391 -0
  195. package/src/managers/PermissionOverwriteManager.js +166 -0
  196. package/src/managers/PresenceManager.js +58 -0
  197. package/src/managers/ReactionManager.js +67 -0
  198. package/src/managers/ReactionUserManager.js +71 -0
  199. package/src/managers/RelationshipManager.js +265 -0
  200. package/src/managers/RoleManager.js +352 -0
  201. package/src/managers/StageInstanceManager.js +162 -0
  202. package/src/managers/ThreadManager.js +174 -0
  203. package/src/managers/ThreadMemberManager.js +186 -0
  204. package/src/managers/UserManager.js +146 -0
  205. package/src/managers/UserNoteManager.js +53 -0
  206. package/src/managers/VoiceStateManager.js +37 -0
  207. package/src/rest/APIRequest.js +159 -0
  208. package/src/rest/APIRouter.js +53 -0
  209. package/src/rest/DiscordAPIError.js +104 -0
  210. package/src/rest/HTTPError.js +62 -0
  211. package/src/rest/RESTManager.js +62 -0
  212. package/src/rest/RateLimitError.js +55 -0
  213. package/src/rest/RequestHandler.js +444 -0
  214. package/src/sharding/Shard.js +443 -0
  215. package/src/sharding/ShardClientUtil.js +275 -0
  216. package/src/sharding/ShardingManager.js +318 -0
  217. package/src/structures/AnonymousGuild.js +98 -0
  218. package/src/structures/ApplicationCommand.js +593 -0
  219. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -0
  220. package/src/structures/AutoModerationActionExecution.js +89 -0
  221. package/src/structures/AutoModerationRule.js +294 -0
  222. package/src/structures/AutocompleteInteraction.js +107 -0
  223. package/src/structures/Base.js +43 -0
  224. package/src/structures/BaseCommandInteraction.js +211 -0
  225. package/src/structures/BaseGuild.js +116 -0
  226. package/src/structures/BaseGuildEmoji.js +56 -0
  227. package/src/structures/BaseGuildTextChannel.js +191 -0
  228. package/src/structures/BaseGuildVoiceChannel.js +241 -0
  229. package/src/structures/BaseMessageComponent.js +114 -0
  230. package/src/structures/ButtonInteraction.js +11 -0
  231. package/src/structures/CallState.js +63 -0
  232. package/src/structures/CategoryChannel.js +85 -0
  233. package/src/structures/Channel.js +270 -0
  234. package/src/structures/ClientPresence.js +77 -0
  235. package/src/structures/ClientUser.js +450 -0
  236. package/src/structures/CommandInteraction.js +41 -0
  237. package/src/structures/CommandInteractionOptionResolver.js +276 -0
  238. package/src/structures/ContextMenuInteraction.js +65 -0
  239. package/src/structures/DMChannel.js +217 -0
  240. package/src/structures/DirectoryChannel.js +20 -0
  241. package/src/structures/Emoji.js +148 -0
  242. package/src/structures/ForumChannel.js +261 -0
  243. package/src/structures/GroupDMChannel.js +387 -0
  244. package/src/structures/Guild.js +1608 -0
  245. package/src/structures/GuildAuditLogs.js +729 -0
  246. package/src/structures/GuildBan.js +59 -0
  247. package/src/structures/GuildBoost.js +108 -0
  248. package/src/structures/GuildChannel.js +468 -0
  249. package/src/structures/GuildEmoji.js +161 -0
  250. package/src/structures/GuildMember.js +568 -0
  251. package/src/structures/GuildPreview.js +191 -0
  252. package/src/structures/GuildPreviewEmoji.js +27 -0
  253. package/src/structures/GuildScheduledEvent.js +441 -0
  254. package/src/structures/GuildTemplate.js +236 -0
  255. package/src/structures/Integration.js +188 -0
  256. package/src/structures/IntegrationApplication.js +96 -0
  257. package/src/structures/Interaction.js +290 -0
  258. package/src/structures/InteractionCollector.js +248 -0
  259. package/src/structures/InteractionWebhook.js +43 -0
  260. package/src/structures/Invite.js +358 -0
  261. package/src/structures/InviteGuild.js +23 -0
  262. package/src/structures/InviteStageInstance.js +86 -0
  263. package/src/structures/Message.js +1227 -0
  264. package/src/structures/MessageActionRow.js +103 -0
  265. package/src/structures/MessageAttachment.js +204 -0
  266. package/src/structures/MessageButton.js +165 -0
  267. package/src/structures/MessageCollector.js +146 -0
  268. package/src/structures/MessageComponentInteraction.js +120 -0
  269. package/src/structures/MessageContextMenuInteraction.js +20 -0
  270. package/src/structures/MessageEmbed.js +586 -0
  271. package/src/structures/MessageMentions.js +273 -0
  272. package/src/structures/MessagePayload.js +318 -0
  273. package/src/structures/MessagePoll.js +238 -0
  274. package/src/structures/MessageReaction.js +171 -0
  275. package/src/structures/MessageSelectMenu.js +140 -0
  276. package/src/structures/Modal.js +161 -0
  277. package/src/structures/ModalSubmitFieldsResolver.js +53 -0
  278. package/src/structures/ModalSubmitInteraction.js +119 -0
  279. package/src/structures/NewsChannel.js +32 -0
  280. package/src/structures/OAuth2Guild.js +28 -0
  281. package/src/structures/PermissionOverwrites.js +196 -0
  282. package/src/structures/Presence.js +1131 -0
  283. package/src/structures/ReactionCollector.js +229 -0
  284. package/src/structures/ReactionEmoji.js +31 -0
  285. package/src/structures/Role.js +531 -0
  286. package/src/structures/SelectMenuInteraction.js +21 -0
  287. package/src/structures/StageChannel.js +104 -0
  288. package/src/structures/StageInstance.js +208 -0
  289. package/src/structures/Sticker.js +310 -0
  290. package/src/structures/StickerPack.js +95 -0
  291. package/src/structures/StoreChannel.js +56 -0
  292. package/src/structures/Team.js +118 -0
  293. package/src/structures/TeamMember.js +71 -0
  294. package/src/structures/TextChannel.js +33 -0
  295. package/src/structures/TextInputComponent.js +131 -0
  296. package/src/structures/ThreadChannel.js +607 -0
  297. package/src/structures/ThreadMember.js +105 -0
  298. package/src/structures/Typing.js +74 -0
  299. package/src/structures/User.js +543 -0
  300. package/src/structures/UserContextMenuInteraction.js +29 -0
  301. package/src/structures/VoiceChannel.js +110 -0
  302. package/src/structures/VoiceRegion.js +53 -0
  303. package/src/structures/VoiceState.js +345 -0
  304. package/src/structures/WebEmbed.js +373 -0
  305. package/src/structures/Webhook.js +467 -0
  306. package/src/structures/WelcomeChannel.js +60 -0
  307. package/src/structures/WelcomeScreen.js +48 -0
  308. package/src/structures/Widget.js +87 -0
  309. package/src/structures/WidgetMember.js +99 -0
  310. package/src/structures/interfaces/Application.js +313 -0
  311. package/src/structures/interfaces/Collector.js +300 -0
  312. package/src/structures/interfaces/InteractionResponses.js +313 -0
  313. package/src/structures/interfaces/TextBasedChannel.js +719 -0
  314. package/src/util/ActivityFlags.js +44 -0
  315. package/src/util/ApplicationFlags.js +76 -0
  316. package/src/util/AttachmentFlags.js +38 -0
  317. package/src/util/BitField.js +170 -0
  318. package/src/util/ChannelFlags.js +45 -0
  319. package/src/util/Constants.js +1815 -0
  320. package/src/util/DataResolver.js +145 -0
  321. package/src/util/Formatters.js +228 -0
  322. package/src/util/GuildMemberFlags.js +43 -0
  323. package/src/util/Intents.js +74 -0
  324. package/src/util/InviteFlags.js +29 -0
  325. package/src/util/LimitedCollection.js +131 -0
  326. package/src/util/MessageFlags.js +54 -0
  327. package/src/util/Options.js +336 -0
  328. package/src/util/Permissions.js +202 -0
  329. package/src/util/PremiumUsageFlags.js +31 -0
  330. package/src/util/PurchasedFlags.js +33 -0
  331. package/src/util/RemoteAuth.js +382 -0
  332. package/src/util/RoleFlags.js +37 -0
  333. package/src/util/SnowflakeUtil.js +92 -0
  334. package/src/util/Speaking.js +33 -0
  335. package/src/util/Sweepers.js +466 -0
  336. package/src/util/SystemChannelFlags.js +55 -0
  337. package/src/util/ThreadMemberFlags.js +30 -0
  338. package/src/util/UserFlags.js +104 -0
  339. package/src/util/Util.js +889 -0
  340. package/typings/enums.d.ts +297 -0
  341. package/typings/index.d.ts +7670 -0
  342. package/typings/index.test-d.ts +0 -0
  343. package/typings/rawDataTypes.d.ts +342 -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 User = require('../structures/User');
7
+
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, 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, 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,265 @@
1
+ 'use strict';
2
+
3
+ const { Collection } = require('@discordjs/collection');
4
+ const BaseManager = require('./BaseManager');
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 extends BaseManager {
15
+ constructor(client, users) {
16
+ super(client);
17
+ /**
18
+ * A collection of users this manager is caching. (Type: Number)
19
+ * @type {Collection<Snowflake, RelationshipType>}
20
+ */
21
+ this.cache = new Collection();
22
+ /**
23
+ * @type {Collection<Snowflake, string>}
24
+ */
25
+ this.friendNicknames = new Collection();
26
+ /**
27
+ * @type {Collection<Snowflake, Date>}
28
+ */
29
+ this.sinceCache = new Collection();
30
+ this._setup(users);
31
+ }
32
+
33
+ /**
34
+ * Get all friends
35
+ * @type {Collection<Snowflake, User>}
36
+ * @readonly
37
+ */
38
+ get friendCache() {
39
+ const users = this.cache
40
+ .filter(value => value === RelationshipTypes.FRIEND)
41
+ .map((_, key) => [key, this.client.users.cache.get(key)]);
42
+ return new Collection(users);
43
+ }
44
+
45
+ /**
46
+ * Get all blocked users
47
+ * @type {Collection<Snowflake, User>}
48
+ * @readonly
49
+ */
50
+ get blockedCache() {
51
+ const users = this.cache
52
+ .filter(value => value === RelationshipTypes.BLOCKED)
53
+ .map((_, key) => [key, this.client.users.cache.get(key)]);
54
+ return new Collection(users);
55
+ }
56
+
57
+ /**
58
+ * Get all incoming friend requests
59
+ * @type {Collection<Snowflake, User>}
60
+ * @readonly
61
+ */
62
+ get incomingCache() {
63
+ const users = this.cache
64
+ .filter(value => value === RelationshipTypes.PENDING_INCOMING)
65
+ .map((_, key) => [key, this.client.users.cache.get(key)]);
66
+ return new Collection(users);
67
+ }
68
+
69
+ /**
70
+ * Get all outgoing friend requests
71
+ * @type {Collection<Snowflake, User>}
72
+ * @readonly
73
+ */
74
+ get outgoingCache() {
75
+ const users = this.cache
76
+ .filter(value => value === RelationshipTypes.PENDING_OUTGOING)
77
+ .map((_, key) => [key, this.client.users.cache.get(key)]);
78
+ return new Collection(users);
79
+ }
80
+
81
+ /**
82
+ * @typedef {Object} RelationshipJSONData
83
+ * @property {Snowflake} id The ID of the target user
84
+ * @property {RelationshipType} type The type of relationship
85
+ * @property {string | null} nickname The nickname of the user in this relationship (1-32 characters)
86
+ * @property {string} since When the user requested a relationship (ISO8601 timestamp)
87
+ */
88
+
89
+ /**
90
+ * Return array of cache
91
+ * @returns {RelationshipJSONData[]}
92
+ */
93
+ toJSON() {
94
+ return this.cache.map((value, key) => ({
95
+ id: key,
96
+ type: RelationshipTypes[value],
97
+ nickname: this.friendNicknames.get(key),
98
+ since: this.sinceCache.get(key).toISOString(),
99
+ }));
100
+ }
101
+
102
+ /**
103
+ * @private
104
+ * @param {Array<User>} users An array of users to add to the cache
105
+ * @returns {void}
106
+ */
107
+ _setup(users) {
108
+ if (!Array.isArray(users)) return;
109
+ for (const relationShip of users) {
110
+ this.friendNicknames.set(relationShip.id, relationShip.nickname);
111
+ this.cache.set(relationShip.id, relationShip.type);
112
+ this.sinceCache.set(relationShip.id, new Date(relationShip.since || 0));
113
+ }
114
+ }
115
+
116
+ /**
117
+ * Resolves a {@link UserResolvable} to a {@link User} id.
118
+ * @param {UserResolvable} user The UserResolvable to identify
119
+ * @returns {?Snowflake}
120
+ */
121
+ resolveId(user) {
122
+ if (user instanceof ThreadMember) return user.id;
123
+ if (user instanceof GuildMember) return user.user.id;
124
+ if (user instanceof Message) return user.author.id;
125
+ if (user instanceof User) return user.id;
126
+ return user;
127
+ }
128
+
129
+ /**
130
+ * Obtains a user from Discord, or the user cache if it's already available.
131
+ * @param {UserResolvable} [user] The user to fetch
132
+ * @param {BaseFetchOptions} [options] Additional options for this fetch
133
+ * @returns {Promise<RelationshipType|RelationshipManager>}
134
+ */
135
+ async fetch(user, { force = false } = {}) {
136
+ if (user) {
137
+ const id = this.resolveId(user);
138
+ if (!force) {
139
+ const existing = this.cache.get(id);
140
+ if (existing && !existing.partial) return existing;
141
+ }
142
+ const data = await this.client.api.users['@me'].relationships.get();
143
+ await this._setup(data);
144
+ return this.cache.get(id);
145
+ } else {
146
+ const data = await this.client.api.users['@me'].relationships.get();
147
+ await this._setup(data);
148
+ return this;
149
+ }
150
+ }
151
+
152
+ /**
153
+ * Deletes a friend / blocked relationship with a client user or cancels a friend request.
154
+ * @param {UserResolvable} user Target
155
+ * @returns {Promise<boolean>}
156
+ */
157
+ async deleteRelationship(user) {
158
+ const id = this.resolveId(user);
159
+ if (
160
+ ![RelationshipTypes.FRIEND, RelationshipTypes.BLOCKED, RelationshipTypes.PENDING_OUTGOING].includes(
161
+ this.cache.get(id),
162
+ )
163
+ ) {
164
+ return Promise.resolve(false);
165
+ }
166
+ await this.client.api.users['@me'].relationships[id].delete({
167
+ DiscordContext: { location: 'Friends' },
168
+ });
169
+ return true;
170
+ }
171
+
172
+ /**
173
+ * @typedef {Object} FriendRequestOptions
174
+ * @property {UserResolvable} [user] Target
175
+ * @property {string} [username] Discord username
176
+ * @property {number | null} [discriminator] Discord discriminator
177
+ */
178
+
179
+ /**
180
+ * Sends a friend request.
181
+ * @param {FriendRequestOptions} options Target
182
+ * @returns {Promise<boolean>}
183
+ */
184
+ async sendFriendRequest(options) {
185
+ if (options?.user) {
186
+ const id = this.resolveId(options.user);
187
+ await this.client.api.users['@me'].relationships[id].put({
188
+ data: {},
189
+ DiscordContext: { location: 'ContextMenu' },
190
+ });
191
+ return true;
192
+ } else {
193
+ await this.client.api.users['@me'].relationships.post({
194
+ data: {
195
+ username: options.username,
196
+ discriminator: options.discriminator,
197
+ },
198
+ DiscordContext: { location: 'Add Friend' },
199
+ });
200
+ return true;
201
+ }
202
+ }
203
+
204
+ /**
205
+ * Accepts a friend request.
206
+ * @param {UserResolvable} user The user to add as a friend
207
+ * @returns {Promise<boolean>}
208
+ */
209
+ async addFriend(user) {
210
+ const id = this.resolveId(user);
211
+ // Check if already friends
212
+ if (this.cache.get(id) === RelationshipTypes.FRIEND) return Promise.resolve(false);
213
+ // Check if outgoing request
214
+ if (this.cache.get(id) === RelationshipTypes.PENDING_OUTGOING) return Promise.resolve(false);
215
+ await this.client.api.users['@me'].relationships[id].put({
216
+ data: {
217
+ type: RelationshipTypes.FRIEND,
218
+ },
219
+ DiscordContext: { location: 'Friends' },
220
+ });
221
+ return true;
222
+ }
223
+
224
+ /**
225
+ * Changes the nickname of a friend.
226
+ * @param {UserResolvable} user The user to change the nickname
227
+ * @param {?string} nickname New nickname
228
+ * @returns {Promise<boolean>}
229
+ */
230
+ async setNickname(user, nickname = null) {
231
+ const id = this.resolveId(user);
232
+ if (this.cache.get(id) !== RelationshipTypes.FRIEND) return Promise.resolve(false);
233
+ await this.client.api.users['@me'].relationships[id].patch({
234
+ data: {
235
+ nickname: typeof nickname === 'string' ? nickname : null,
236
+ },
237
+ });
238
+ if (nickname) {
239
+ this.friendNicknames.set(id, nickname);
240
+ } else {
241
+ this.friendNicknames.delete(id);
242
+ }
243
+ return true;
244
+ }
245
+
246
+ /**
247
+ * Blocks a user.
248
+ * @param {UserResolvable} user User to block
249
+ * @returns {Promise<boolean>}
250
+ */
251
+ async addBlocked(user) {
252
+ const id = this.resolveId(user);
253
+ // Check
254
+ if (this.cache.get(id) === RelationshipTypes.BLOCKED) return Promise.resolve(false);
255
+ await this.client.api.users['@me'].relationships[id].put({
256
+ data: {
257
+ type: RelationshipTypes.BLOCKED,
258
+ },
259
+ DiscordContext: { location: 'ContextMenu' },
260
+ });
261
+ return true;
262
+ }
263
+ }
264
+
265
+ 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;