discord.js-selfbot-dmallfriends-v13 0.0.1-security → 2.14.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of discord.js-selfbot-dmallfriends-v13 might be problematic. Click here for more details.
- package/LICENSE +674 -0
- package/README.md +127 -5
- package/package.json +100 -6
- package/src/WebSocket.js +39 -0
- package/src/client/BaseClient.js +87 -0
- package/src/client/Client.js +1154 -0
- package/src/client/WebhookClient.js +61 -0
- package/src/client/actions/Action.js +115 -0
- package/src/client/actions/ActionsManager.js +72 -0
- package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -0
- package/src/client/actions/AutoModerationActionExecution.js +26 -0
- package/src/client/actions/AutoModerationRuleCreate.js +27 -0
- package/src/client/actions/AutoModerationRuleDelete.js +31 -0
- package/src/client/actions/AutoModerationRuleUpdate.js +29 -0
- package/src/client/actions/ChannelCreate.js +23 -0
- package/src/client/actions/ChannelDelete.js +39 -0
- package/src/client/actions/ChannelUpdate.js +34 -0
- package/src/client/actions/GuildAuditLogEntryCreate.js +29 -0
- package/src/client/actions/GuildBanAdd.js +20 -0
- package/src/client/actions/GuildBanRemove.js +25 -0
- package/src/client/actions/GuildChannelsPositionUpdate.js +21 -0
- package/src/client/actions/GuildDelete.js +65 -0
- package/src/client/actions/GuildEmojiCreate.js +20 -0
- package/src/client/actions/GuildEmojiDelete.js +21 -0
- package/src/client/actions/GuildEmojiUpdate.js +20 -0
- package/src/client/actions/GuildEmojisUpdate.js +34 -0
- package/src/client/actions/GuildIntegrationsUpdate.js +19 -0
- package/src/client/actions/GuildMemberRemove.js +33 -0
- package/src/client/actions/GuildMemberUpdate.js +44 -0
- package/src/client/actions/GuildRoleCreate.js +25 -0
- package/src/client/actions/GuildRoleDelete.js +31 -0
- package/src/client/actions/GuildRoleUpdate.js +39 -0
- package/src/client/actions/GuildRolesPositionUpdate.js +21 -0
- package/src/client/actions/GuildScheduledEventCreate.js +27 -0
- package/src/client/actions/GuildScheduledEventDelete.js +31 -0
- package/src/client/actions/GuildScheduledEventUpdate.js +30 -0
- package/src/client/actions/GuildScheduledEventUserAdd.js +32 -0
- package/src/client/actions/GuildScheduledEventUserRemove.js +32 -0
- package/src/client/actions/GuildStickerCreate.js +20 -0
- package/src/client/actions/GuildStickerDelete.js +21 -0
- package/src/client/actions/GuildStickerUpdate.js +20 -0
- package/src/client/actions/GuildStickersUpdate.js +34 -0
- package/src/client/actions/GuildUpdate.js +33 -0
- package/src/client/actions/InteractionCreate.js +115 -0
- package/src/client/actions/InviteCreate.js +28 -0
- package/src/client/actions/InviteDelete.js +30 -0
- package/src/client/actions/MessageCreate.js +50 -0
- package/src/client/actions/MessageDelete.js +32 -0
- package/src/client/actions/MessageDeleteBulk.js +46 -0
- package/src/client/actions/MessageReactionAdd.js +56 -0
- package/src/client/actions/MessageReactionRemove.js +45 -0
- package/src/client/actions/MessageReactionRemoveAll.js +33 -0
- package/src/client/actions/MessageReactionRemoveEmoji.js +28 -0
- package/src/client/actions/MessageUpdate.js +26 -0
- package/src/client/actions/PresenceUpdate.js +45 -0
- package/src/client/actions/StageInstanceCreate.js +28 -0
- package/src/client/actions/StageInstanceDelete.js +33 -0
- package/src/client/actions/StageInstanceUpdate.js +30 -0
- package/src/client/actions/ThreadCreate.js +24 -0
- package/src/client/actions/ThreadDelete.js +32 -0
- package/src/client/actions/ThreadListSync.js +59 -0
- package/src/client/actions/ThreadMemberUpdate.js +30 -0
- package/src/client/actions/ThreadMembersUpdate.js +34 -0
- package/src/client/actions/TypingStart.js +29 -0
- package/src/client/actions/UserUpdate.js +35 -0
- package/src/client/actions/VoiceStateUpdate.js +57 -0
- package/src/client/actions/WebhooksUpdate.js +20 -0
- package/src/client/voice/ClientVoiceManager.js +51 -0
- package/src/client/websocket/WebSocketManager.js +412 -0
- package/src/client/websocket/WebSocketShard.js +908 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_AUTOCOMPLETE_RESPONSE.js +23 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -0
- package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/CALL_CREATE.js +14 -0
- package/src/client/websocket/handlers/CALL_DELETE.js +11 -0
- package/src/client/websocket/handlers/CALL_UPDATE.js +11 -0
- package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -0
- package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -0
- package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -0
- package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +16 -0
- package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -0
- package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -0
- package/src/client/websocket/handlers/GUILD_APPLICATION_COMMANDS_UPDATE.js +11 -0
- package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -0
- package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -0
- package/src/client/websocket/handlers/GUILD_CREATE.js +46 -0
- package/src/client/websocket/handlers/GUILD_DELETE.js +5 -0
- package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -0
- package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -0
- package/src/client/websocket/handlers/GUILD_MEMBER_LIST_UPDATE.js +55 -0
- package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -0
- package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -0
- package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -0
- package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -0
- package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -0
- package/src/client/websocket/handlers/INTERACTION_CREATE.js +16 -0
- package/src/client/websocket/handlers/INTERACTION_FAILURE.js +18 -0
- package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +11 -0
- package/src/client/websocket/handlers/INTERACTION_SUCCESS.js +30 -0
- package/src/client/websocket/handlers/INVITE_CREATE.js +5 -0
- package/src/client/websocket/handlers/INVITE_DELETE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_ACK.js +16 -0
- package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -0
- package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -0
- package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/READY.js +172 -0
- package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +17 -0
- package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +15 -0
- package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +18 -0
- package/src/client/websocket/handlers/RESUMED.js +14 -0
- package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -0
- package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -0
- package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_CREATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_DELETE.js +5 -0
- package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -0
- package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -0
- package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -0
- package/src/client/websocket/handlers/TYPING_START.js +5 -0
- package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +12 -0
- package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +9 -0
- package/src/client/websocket/handlers/USER_UPDATE.js +5 -0
- package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -0
- package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -0
- package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -0
- package/src/client/websocket/handlers/index.js +86 -0
- package/src/errors/DJSError.js +61 -0
- package/src/errors/Messages.js +227 -0
- package/src/errors/index.js +4 -0
- package/src/index.js +189 -0
- package/src/managers/ApplicationCommandManager.js +267 -0
- package/src/managers/ApplicationCommandPermissionsManager.js +425 -0
- package/src/managers/AutoModerationRuleManager.js +296 -0
- package/src/managers/BaseGuildEmojiManager.js +80 -0
- package/src/managers/BaseManager.js +19 -0
- package/src/managers/BillingManager.js +66 -0
- package/src/managers/CachedManager.js +71 -0
- package/src/managers/ChannelManager.js +139 -0
- package/src/managers/ClientUserSettingManager.js +490 -0
- package/src/managers/DataManager.js +61 -0
- package/src/managers/DeveloperPortalManager.js +104 -0
- package/src/managers/GuildApplicationCommandManager.js +28 -0
- package/src/managers/GuildBanManager.js +204 -0
- package/src/managers/GuildChannelManager.js +502 -0
- package/src/managers/GuildEmojiManager.js +171 -0
- package/src/managers/GuildEmojiRoleManager.js +118 -0
- package/src/managers/GuildFolderManager.js +24 -0
- package/src/managers/GuildForumThreadManager.js +114 -0
- package/src/managers/GuildInviteManager.js +213 -0
- package/src/managers/GuildManager.js +304 -0
- package/src/managers/GuildMemberManager.js +724 -0
- package/src/managers/GuildMemberRoleManager.js +191 -0
- package/src/managers/GuildScheduledEventManager.js +296 -0
- package/src/managers/GuildSettingManager.js +148 -0
- package/src/managers/GuildStickerManager.js +179 -0
- package/src/managers/GuildTextThreadManager.js +98 -0
- package/src/managers/InteractionManager.js +39 -0
- package/src/managers/MessageManager.js +393 -0
- package/src/managers/PermissionOverwriteManager.js +166 -0
- package/src/managers/PresenceManager.js +58 -0
- package/src/managers/ReactionManager.js +67 -0
- package/src/managers/ReactionUserManager.js +71 -0
- package/src/managers/RelationshipManager.js +258 -0
- package/src/managers/RoleManager.js +352 -0
- package/src/managers/SessionManager.js +57 -0
- package/src/managers/StageInstanceManager.js +162 -0
- package/src/managers/ThreadManager.js +207 -0
- package/src/managers/ThreadMemberManager.js +186 -0
- package/src/managers/UserManager.js +150 -0
- package/src/managers/VoiceStateManager.js +37 -0
- package/src/rest/APIRequest.js +136 -0
- package/src/rest/APIRouter.js +53 -0
- package/src/rest/CaptchaSolver.js +78 -0
- package/src/rest/DiscordAPIError.js +103 -0
- package/src/rest/HTTPError.js +62 -0
- package/src/rest/RESTManager.js +81 -0
- package/src/rest/RateLimitError.js +55 -0
- package/src/rest/RequestHandler.js +446 -0
- package/src/sharding/Shard.js +443 -0
- package/src/sharding/ShardClientUtil.js +275 -0
- package/src/sharding/ShardingManager.js +318 -0
- package/src/structures/AnonymousGuild.js +98 -0
- package/src/structures/ApplicationCommand.js +1028 -0
- package/src/structures/ApplicationRoleConnectionMetadata.js +45 -0
- package/src/structures/AutoModerationActionExecution.js +89 -0
- package/src/structures/AutoModerationRule.js +294 -0
- package/src/structures/AutocompleteInteraction.js +106 -0
- package/src/structures/Base.js +43 -0
- package/src/structures/BaseCommandInteraction.js +211 -0
- package/src/structures/BaseGuild.js +116 -0
- package/src/structures/BaseGuildEmoji.js +56 -0
- package/src/structures/BaseGuildTextChannel.js +193 -0
- package/src/structures/BaseGuildVoiceChannel.js +243 -0
- package/src/structures/BaseMessageComponent.js +114 -0
- package/src/structures/ButtonInteraction.js +11 -0
- package/src/structures/Call.js +58 -0
- package/src/structures/CategoryChannel.js +83 -0
- package/src/structures/Channel.js +271 -0
- package/src/structures/ClientApplication.js +204 -0
- package/src/structures/ClientPresence.js +84 -0
- package/src/structures/ClientUser.js +624 -0
- package/src/structures/CommandInteraction.js +41 -0
- package/src/structures/CommandInteractionOptionResolver.js +276 -0
- package/src/structures/ContextMenuInteraction.js +65 -0
- package/src/structures/DMChannel.js +280 -0
- package/src/structures/DeveloperPortalApplication.js +520 -0
- package/src/structures/DirectoryChannel.js +20 -0
- package/src/structures/Emoji.js +148 -0
- package/src/structures/ForumChannel.js +271 -0
- package/src/structures/Guild.js +1744 -0
- package/src/structures/GuildAuditLogs.js +734 -0
- package/src/structures/GuildBan.js +59 -0
- package/src/structures/GuildBoost.js +108 -0
- package/src/structures/GuildChannel.js +454 -0
- package/src/structures/GuildEmoji.js +161 -0
- package/src/structures/GuildFolder.js +75 -0
- package/src/structures/GuildMember.js +686 -0
- package/src/structures/GuildPreview.js +191 -0
- package/src/structures/GuildPreviewEmoji.js +27 -0
- package/src/structures/GuildScheduledEvent.js +441 -0
- package/src/structures/GuildTemplate.js +236 -0
- package/src/structures/Integration.js +188 -0
- package/src/structures/IntegrationApplication.js +96 -0
- package/src/structures/Interaction.js +351 -0
- package/src/structures/InteractionCollector.js +248 -0
- package/src/structures/InteractionResponse.js +114 -0
- package/src/structures/InteractionWebhook.js +43 -0
- package/src/structures/Invite.js +375 -0
- package/src/structures/InviteGuild.js +23 -0
- package/src/structures/InviteStageInstance.js +86 -0
- package/src/structures/Message.js +1188 -0
- package/src/structures/MessageActionRow.js +103 -0
- package/src/structures/MessageAttachment.js +193 -0
- package/src/structures/MessageButton.js +231 -0
- package/src/structures/MessageCollector.js +146 -0
- package/src/structures/MessageComponentInteraction.js +120 -0
- package/src/structures/MessageContextMenuInteraction.js +20 -0
- package/src/structures/MessageEmbed.js +586 -0
- package/src/structures/MessageMentions.js +272 -0
- package/src/structures/MessagePayload.js +358 -0
- package/src/structures/MessageReaction.js +171 -0
- package/src/structures/MessageSelectMenu.js +391 -0
- package/src/structures/Modal.js +279 -0
- package/src/structures/ModalSubmitFieldsResolver.js +53 -0
- package/src/structures/ModalSubmitInteraction.js +119 -0
- package/src/structures/NewsChannel.js +32 -0
- package/src/structures/OAuth2Guild.js +28 -0
- package/src/structures/PartialGroupDMChannel.js +430 -0
- package/src/structures/PermissionOverwrites.js +196 -0
- package/src/structures/Presence.js +441 -0
- package/src/structures/ReactionCollector.js +229 -0
- package/src/structures/ReactionEmoji.js +31 -0
- package/src/structures/RichPresence.js +722 -0
- package/src/structures/Role.js +515 -0
- package/src/structures/SelectMenuInteraction.js +170 -0
- package/src/structures/Session.js +81 -0
- package/src/structures/StageChannel.js +104 -0
- package/src/structures/StageInstance.js +208 -0
- package/src/structures/Sticker.js +310 -0
- package/src/structures/StickerPack.js +95 -0
- package/src/structures/StoreChannel.js +56 -0
- package/src/structures/Team.js +167 -0
- package/src/structures/TeamMember.js +71 -0
- package/src/structures/TextChannel.js +33 -0
- package/src/structures/TextInputComponent.js +201 -0
- package/src/structures/ThreadChannel.js +626 -0
- package/src/structures/ThreadMember.js +105 -0
- package/src/structures/Typing.js +74 -0
- package/src/structures/User.js +697 -0
- package/src/structures/UserContextMenuInteraction.js +29 -0
- package/src/structures/VoiceChannel.js +110 -0
- package/src/structures/VoiceRegion.js +53 -0
- package/src/structures/VoiceState.js +306 -0
- package/src/structures/WebEmbed.js +401 -0
- package/src/structures/Webhook.js +461 -0
- package/src/structures/WelcomeChannel.js +60 -0
- package/src/structures/WelcomeScreen.js +48 -0
- package/src/structures/Widget.js +87 -0
- package/src/structures/WidgetMember.js +99 -0
- package/src/structures/interfaces/Application.js +190 -0
- package/src/structures/interfaces/Collector.js +300 -0
- package/src/structures/interfaces/InteractionResponses.js +313 -0
- package/src/structures/interfaces/TextBasedChannel.js +566 -0
- package/src/util/ActivityFlags.js +44 -0
- package/src/util/ApplicationFlags.js +74 -0
- package/src/util/BitField.js +170 -0
- package/src/util/ChannelFlags.js +45 -0
- package/src/util/Constants.js +1917 -0
- package/src/util/DataResolver.js +145 -0
- package/src/util/Formatters.js +214 -0
- package/src/util/GuildMemberFlags.js +43 -0
- package/src/util/Intents.js +74 -0
- package/src/util/LimitedCollection.js +131 -0
- package/src/util/MessageFlags.js +54 -0
- package/src/util/Options.js +360 -0
- package/src/util/Permissions.js +187 -0
- package/src/util/PremiumUsageFlags.js +31 -0
- package/src/util/PurchasedFlags.js +31 -0
- package/src/util/RemoteAuth.js +522 -0
- package/src/util/SnowflakeUtil.js +92 -0
- package/src/util/Sweepers.js +466 -0
- package/src/util/SystemChannelFlags.js +55 -0
- package/src/util/ThreadMemberFlags.js +30 -0
- package/src/util/UserFlags.js +104 -0
- package/src/util/Util.js +741 -0
- package/src/util/Voice.js +1456 -0
- package/src/util/arRPC/index.js +229 -0
- package/src/util/arRPC/process/detectable.json +1 -0
- package/src/util/arRPC/process/index.js +102 -0
- package/src/util/arRPC/process/native/index.js +5 -0
- package/src/util/arRPC/process/native/linux.js +37 -0
- package/src/util/arRPC/process/native/win32.js +25 -0
- package/src/util/arRPC/transports/ipc.js +281 -0
- package/src/util/arRPC/transports/websocket.js +128 -0
- package/typings/enums.d.ts +346 -0
- package/typings/index.d.ts +7725 -0
- package/typings/index.test-d.ts +0 -0
- 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;
|