djs-selfbot-v13 3.2.2 → 3.7.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (364) hide show
  1. package/README.md +63 -36
  2. package/package.json +89 -85
  3. package/src/WebSocket.js +39 -39
  4. package/src/client/BaseClient.js +86 -86
  5. package/src/client/Client.js +941 -836
  6. package/src/client/WebhookClient.js +61 -61
  7. package/src/client/actions/Action.js +116 -120
  8. package/src/client/actions/ActionsManager.js +80 -78
  9. package/src/client/actions/ApplicationCommandPermissionsUpdate.js +34 -34
  10. package/src/client/actions/AutoModerationActionExecution.js +27 -27
  11. package/src/client/actions/AutoModerationRuleCreate.js +28 -28
  12. package/src/client/actions/AutoModerationRuleDelete.js +32 -32
  13. package/src/client/actions/AutoModerationRuleUpdate.js +30 -30
  14. package/src/client/actions/ChannelCreate.js +23 -23
  15. package/src/client/actions/ChannelDelete.js +39 -39
  16. package/src/client/actions/ChannelUpdate.js +43 -43
  17. package/src/client/actions/GuildAuditLogEntryCreate.js +29 -29
  18. package/src/client/actions/GuildBanAdd.js +20 -20
  19. package/src/client/actions/GuildBanRemove.js +25 -25
  20. package/src/client/actions/GuildChannelsPositionUpdate.js +21 -21
  21. package/src/client/actions/GuildDelete.js +65 -65
  22. package/src/client/actions/GuildEmojiCreate.js +20 -20
  23. package/src/client/actions/GuildEmojiDelete.js +21 -21
  24. package/src/client/actions/GuildEmojiUpdate.js +20 -20
  25. package/src/client/actions/GuildEmojisUpdate.js +34 -34
  26. package/src/client/actions/GuildIntegrationsUpdate.js +19 -19
  27. package/src/client/actions/GuildMemberRemove.js +33 -32
  28. package/src/client/actions/GuildMemberUpdate.js +44 -43
  29. package/src/client/actions/GuildRoleCreate.js +25 -25
  30. package/src/client/actions/GuildRoleDelete.js +31 -31
  31. package/src/client/actions/GuildRoleUpdate.js +39 -39
  32. package/src/client/actions/GuildRolesPositionUpdate.js +21 -21
  33. package/src/client/actions/GuildScheduledEventCreate.js +27 -27
  34. package/src/client/actions/GuildScheduledEventDelete.js +31 -31
  35. package/src/client/actions/GuildScheduledEventUpdate.js +30 -30
  36. package/src/client/actions/GuildScheduledEventUserAdd.js +32 -32
  37. package/src/client/actions/GuildScheduledEventUserRemove.js +32 -32
  38. package/src/client/actions/GuildStickerCreate.js +20 -20
  39. package/src/client/actions/GuildStickerDelete.js +21 -21
  40. package/src/client/actions/GuildStickerUpdate.js +20 -20
  41. package/src/client/actions/GuildStickersUpdate.js +34 -34
  42. package/src/client/actions/GuildUpdate.js +33 -33
  43. package/src/client/actions/InviteCreate.js +28 -28
  44. package/src/client/actions/InviteDelete.js +30 -30
  45. package/src/client/actions/MessageCreate.js +50 -46
  46. package/src/client/actions/MessageDelete.js +32 -32
  47. package/src/client/actions/MessageDeleteBulk.js +46 -46
  48. package/src/client/actions/MessagePollVoteAdd.js +33 -0
  49. package/src/client/actions/MessagePollVoteRemove.js +33 -0
  50. package/src/client/actions/MessageReactionAdd.js +68 -56
  51. package/src/client/actions/MessageReactionRemove.js +50 -45
  52. package/src/client/actions/MessageReactionRemoveAll.js +33 -33
  53. package/src/client/actions/MessageReactionRemoveEmoji.js +28 -28
  54. package/src/client/actions/MessageUpdate.js +26 -26
  55. package/src/client/actions/PresenceUpdate.js +50 -46
  56. package/src/client/actions/StageInstanceCreate.js +28 -28
  57. package/src/client/actions/StageInstanceDelete.js +33 -33
  58. package/src/client/actions/StageInstanceUpdate.js +30 -30
  59. package/src/client/actions/ThreadCreate.js +24 -24
  60. package/src/client/actions/ThreadDelete.js +32 -32
  61. package/src/client/actions/ThreadListSync.js +59 -59
  62. package/src/client/actions/ThreadMemberUpdate.js +30 -30
  63. package/src/client/actions/ThreadMembersUpdate.js +34 -34
  64. package/src/client/actions/TypingStart.js +29 -29
  65. package/src/client/actions/UserUpdate.js +35 -35
  66. package/src/client/actions/VoiceStateUpdate.js +50 -57
  67. package/src/client/actions/WebhooksUpdate.js +20 -20
  68. package/src/client/voice/ClientVoiceManager.js +151 -51
  69. package/src/client/voice/VoiceConnection.js +1249 -0
  70. package/src/client/voice/dispatcher/AnnexBDispatcher.js +120 -0
  71. package/src/client/voice/dispatcher/AudioDispatcher.js +145 -0
  72. package/src/client/voice/dispatcher/BaseDispatcher.js +459 -0
  73. package/src/client/voice/dispatcher/VPxDispatcher.js +54 -0
  74. package/src/client/voice/dispatcher/VideoDispatcher.js +68 -0
  75. package/src/client/voice/networking/VoiceUDPClient.js +173 -0
  76. package/src/client/voice/networking/VoiceWebSocket.js +286 -0
  77. package/src/client/voice/player/MediaPlayer.js +321 -0
  78. package/src/client/voice/player/processing/AnnexBNalSplitter.js +244 -0
  79. package/src/client/voice/player/processing/IvfSplitter.js +106 -0
  80. package/src/client/voice/player/processing/PCMInsertSilence.js +37 -0
  81. package/src/client/voice/receiver/PacketHandler.js +260 -0
  82. package/src/client/voice/receiver/Receiver.js +96 -0
  83. package/src/client/voice/receiver/Recorder.js +173 -0
  84. package/src/client/voice/util/Function.js +116 -0
  85. package/src/client/voice/util/PlayInterface.js +122 -0
  86. package/src/client/voice/util/Secretbox.js +64 -0
  87. package/src/client/voice/util/Silence.js +16 -0
  88. package/src/client/voice/util/Socket.js +62 -0
  89. package/src/client/voice/util/VolumeInterface.js +104 -0
  90. package/src/client/websocket/WebSocketManager.js +392 -392
  91. package/src/client/websocket/WebSocketShard.js +907 -906
  92. package/src/client/websocket/handlers/APPLICATION_COMMAND_CREATE.js +18 -18
  93. package/src/client/websocket/handlers/APPLICATION_COMMAND_DELETE.js +20 -20
  94. package/src/client/websocket/handlers/APPLICATION_COMMAND_PERMISSIONS_UPDATE.js +5 -5
  95. package/src/client/websocket/handlers/APPLICATION_COMMAND_UPDATE.js +20 -20
  96. package/src/client/websocket/handlers/AUTO_MODERATION_ACTION_EXECUTION.js +5 -5
  97. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_CREATE.js +5 -5
  98. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_DELETE.js +5 -5
  99. package/src/client/websocket/handlers/AUTO_MODERATION_RULE_UPDATE.js +5 -5
  100. package/src/client/websocket/handlers/CALL_CREATE.js +14 -14
  101. package/src/client/websocket/handlers/CALL_DELETE.js +11 -11
  102. package/src/client/websocket/handlers/CALL_UPDATE.js +11 -11
  103. package/src/client/websocket/handlers/CHANNEL_CREATE.js +5 -5
  104. package/src/client/websocket/handlers/CHANNEL_DELETE.js +5 -5
  105. package/src/client/websocket/handlers/CHANNEL_PINS_UPDATE.js +22 -22
  106. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +19 -19
  107. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +16 -16
  108. package/src/client/websocket/handlers/CHANNEL_UPDATE.js +16 -16
  109. package/src/client/websocket/handlers/GUILD_AUDIT_LOG_ENTRY_CREATE.js +5 -5
  110. package/src/client/websocket/handlers/GUILD_BAN_ADD.js +5 -5
  111. package/src/client/websocket/handlers/GUILD_BAN_REMOVE.js +5 -5
  112. package/src/client/websocket/handlers/GUILD_CREATE.js +52 -52
  113. package/src/client/websocket/handlers/GUILD_DELETE.js +5 -5
  114. package/src/client/websocket/handlers/GUILD_EMOJIS_UPDATE.js +5 -5
  115. package/src/client/websocket/handlers/GUILD_INTEGRATIONS_UPDATE.js +5 -5
  116. package/src/client/websocket/handlers/GUILD_MEMBERS_CHUNK.js +39 -39
  117. package/src/client/websocket/handlers/GUILD_MEMBER_ADD.js +20 -19
  118. package/src/client/websocket/handlers/GUILD_MEMBER_REMOVE.js +5 -5
  119. package/src/client/websocket/handlers/GUILD_MEMBER_UPDATE.js +5 -5
  120. package/src/client/websocket/handlers/GUILD_ROLE_CREATE.js +5 -5
  121. package/src/client/websocket/handlers/GUILD_ROLE_DELETE.js +5 -5
  122. package/src/client/websocket/handlers/GUILD_ROLE_UPDATE.js +5 -5
  123. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_CREATE.js +5 -5
  124. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_DELETE.js +5 -5
  125. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_UPDATE.js +5 -5
  126. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_ADD.js +5 -5
  127. package/src/client/websocket/handlers/GUILD_SCHEDULED_EVENT_USER_REMOVE.js +5 -5
  128. package/src/client/websocket/handlers/GUILD_STICKERS_UPDATE.js +5 -5
  129. package/src/client/websocket/handlers/GUILD_UPDATE.js +5 -5
  130. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +12 -12
  131. package/src/client/websocket/handlers/INVITE_CREATE.js +5 -5
  132. package/src/client/websocket/handlers/INVITE_DELETE.js +5 -5
  133. package/src/client/websocket/handlers/MESSAGE_CREATE.js +5 -5
  134. package/src/client/websocket/handlers/MESSAGE_DELETE.js +5 -5
  135. package/src/client/websocket/handlers/MESSAGE_DELETE_BULK.js +5 -5
  136. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_ADD.js +5 -22
  137. package/src/client/websocket/handlers/MESSAGE_POLL_VOTE_REMOVE.js +5 -12
  138. package/src/client/websocket/handlers/MESSAGE_REACTION_ADD.js +5 -5
  139. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE.js +5 -5
  140. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_ALL.js +5 -5
  141. package/src/client/websocket/handlers/MESSAGE_REACTION_REMOVE_EMOJI.js +5 -5
  142. package/src/client/websocket/handlers/MESSAGE_UPDATE.js +16 -16
  143. package/src/client/websocket/handlers/PRESENCE_UPDATE.js +5 -5
  144. package/src/client/websocket/handlers/READY.js +121 -120
  145. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +19 -19
  146. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +17 -17
  147. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +41 -41
  148. package/src/client/websocket/handlers/RESUMED.js +14 -14
  149. package/src/client/websocket/handlers/STAGE_INSTANCE_CREATE.js +5 -5
  150. package/src/client/websocket/handlers/STAGE_INSTANCE_DELETE.js +5 -5
  151. package/src/client/websocket/handlers/STAGE_INSTANCE_UPDATE.js +5 -5
  152. package/src/client/websocket/handlers/THREAD_CREATE.js +5 -5
  153. package/src/client/websocket/handlers/THREAD_DELETE.js +5 -5
  154. package/src/client/websocket/handlers/THREAD_LIST_SYNC.js +5 -5
  155. package/src/client/websocket/handlers/THREAD_MEMBERS_UPDATE.js +5 -5
  156. package/src/client/websocket/handlers/THREAD_MEMBER_UPDATE.js +5 -5
  157. package/src/client/websocket/handlers/THREAD_UPDATE.js +16 -16
  158. package/src/client/websocket/handlers/TYPING_START.js +5 -5
  159. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +6 -6
  160. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +5 -5
  161. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -78
  162. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +5 -5
  163. package/src/client/websocket/handlers/USER_UPDATE.js +5 -5
  164. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +16 -0
  165. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -12
  166. package/src/client/websocket/handlers/VOICE_SERVER_UPDATE.js +6 -6
  167. package/src/client/websocket/handlers/VOICE_STATE_UPDATE.js +5 -5
  168. package/src/client/websocket/handlers/WEBHOOKS_UPDATE.js +5 -5
  169. package/src/client/websocket/handlers/index.js +84 -83
  170. package/src/errors/DJSError.js +61 -61
  171. package/src/errors/Messages.js +217 -183
  172. package/src/errors/index.js +4 -4
  173. package/src/index.js +172 -159
  174. package/src/managers/ApplicationCommandManager.js +264 -264
  175. package/src/managers/ApplicationCommandPermissionsManager.js +417 -417
  176. package/src/managers/AutoModerationRuleManager.js +296 -296
  177. package/src/managers/BaseGuildEmojiManager.js +80 -80
  178. package/src/managers/BaseManager.js +19 -19
  179. package/src/managers/BillingManager.js +66 -66
  180. package/src/managers/CachedManager.js +71 -71
  181. package/src/managers/ChannelManager.js +148 -138
  182. package/src/managers/ClientUserSettingManager.js +372 -372
  183. package/src/managers/DataManager.js +61 -61
  184. package/src/managers/GuildBanManager.js +250 -250
  185. package/src/managers/GuildChannelManager.js +488 -488
  186. package/src/managers/GuildEmojiManager.js +171 -171
  187. package/src/managers/GuildEmojiRoleManager.js +118 -118
  188. package/src/managers/GuildForumThreadManager.js +108 -108
  189. package/src/managers/GuildInviteManager.js +213 -213
  190. package/src/managers/GuildManager.js +338 -304
  191. package/src/managers/GuildMemberManager.js +599 -597
  192. package/src/managers/GuildMemberRoleManager.js +195 -191
  193. package/src/managers/GuildScheduledEventManager.js +314 -296
  194. package/src/managers/GuildSettingManager.js +155 -155
  195. package/src/managers/GuildStickerManager.js +179 -179
  196. package/src/managers/GuildTextThreadManager.js +98 -98
  197. package/src/managers/InteractionManager.js +39 -39
  198. package/src/managers/MessageManager.js +423 -391
  199. package/src/managers/PermissionOverwriteManager.js +164 -166
  200. package/src/managers/PresenceManager.js +71 -58
  201. package/src/managers/QuestManager.js +376 -0
  202. package/src/managers/ReactionManager.js +67 -67
  203. package/src/managers/ReactionUserManager.js +73 -71
  204. package/src/managers/RelationshipManager.js +278 -265
  205. package/src/managers/RoleManager.js +448 -352
  206. package/src/managers/SessionManager.js +66 -0
  207. package/src/managers/StageInstanceManager.js +162 -162
  208. package/src/managers/ThreadManager.js +175 -174
  209. package/src/managers/ThreadMemberManager.js +186 -186
  210. package/src/managers/UserManager.js +136 -146
  211. package/src/managers/UserNoteManager.js +53 -53
  212. package/src/managers/VoiceStateManager.js +59 -37
  213. package/src/rest/APIRequest.js +154 -160
  214. package/src/rest/APIRouter.js +53 -53
  215. package/src/rest/DiscordAPIError.js +119 -104
  216. package/src/rest/HTTPError.js +62 -62
  217. package/src/rest/RESTManager.js +67 -62
  218. package/src/rest/RateLimitError.js +55 -55
  219. package/src/rest/RequestHandler.js +466 -444
  220. package/src/sharding/Shard.js +444 -443
  221. package/src/sharding/ShardClientUtil.js +279 -275
  222. package/src/sharding/ShardingManager.js +319 -318
  223. package/src/structures/AnonymousGuild.js +98 -98
  224. package/src/structures/ApplicationCommand.js +593 -593
  225. package/src/structures/ApplicationRoleConnectionMetadata.js +48 -48
  226. package/src/structures/AutoModerationActionExecution.js +89 -89
  227. package/src/structures/AutoModerationRule.js +294 -294
  228. package/src/structures/AutocompleteInteraction.js +107 -107
  229. package/src/structures/Base.js +43 -43
  230. package/src/structures/BaseCommandInteraction.js +211 -211
  231. package/src/structures/BaseGuild.js +116 -116
  232. package/src/structures/BaseGuildEmoji.js +56 -56
  233. package/src/structures/BaseGuildTextChannel.js +191 -191
  234. package/src/structures/BaseGuildVoiceChannel.js +241 -241
  235. package/src/structures/BaseMessageComponent.js +181 -114
  236. package/src/structures/ButtonInteraction.js +11 -11
  237. package/src/structures/CallState.js +63 -63
  238. package/src/structures/CategoryChannel.js +85 -85
  239. package/src/structures/Channel.js +284 -270
  240. package/src/structures/ClientPresence.js +77 -85
  241. package/src/structures/ClientUser.js +653 -448
  242. package/src/structures/CommandInteraction.js +41 -41
  243. package/src/structures/CommandInteractionOptionResolver.js +276 -276
  244. package/src/structures/ContainerComponent.js +68 -0
  245. package/src/structures/ContextMenuInteraction.js +65 -65
  246. package/src/structures/DMChannel.js +219 -217
  247. package/src/structures/DirectoryChannel.js +20 -20
  248. package/src/structures/Emoji.js +148 -148
  249. package/src/structures/FileComponent.js +49 -0
  250. package/src/structures/ForumChannel.js +31 -261
  251. package/src/structures/GroupDMChannel.js +394 -387
  252. package/src/structures/Guild.js +1697 -1608
  253. package/src/structures/GuildAuditLogs.js +746 -729
  254. package/src/structures/GuildBan.js +59 -59
  255. package/src/structures/GuildBoost.js +108 -108
  256. package/src/structures/GuildChannel.js +470 -468
  257. package/src/structures/GuildEmoji.js +161 -161
  258. package/src/structures/GuildMember.js +636 -568
  259. package/src/structures/GuildPreview.js +191 -191
  260. package/src/structures/GuildPreviewEmoji.js +27 -27
  261. package/src/structures/GuildScheduledEvent.js +536 -441
  262. package/src/structures/GuildTemplate.js +236 -236
  263. package/src/structures/Integration.js +188 -188
  264. package/src/structures/IntegrationApplication.js +96 -96
  265. package/src/structures/Interaction.js +290 -290
  266. package/src/structures/InteractionCollector.js +248 -248
  267. package/src/structures/InteractionWebhook.js +43 -43
  268. package/src/structures/Invite.js +358 -358
  269. package/src/structures/InviteGuild.js +23 -23
  270. package/src/structures/InviteStageInstance.js +86 -86
  271. package/src/structures/MediaChannel.js +11 -0
  272. package/src/structures/MediaGalleryComponent.js +41 -0
  273. package/src/structures/MediaGalleryItem.js +47 -0
  274. package/src/structures/Message.js +1252 -1227
  275. package/src/structures/MessageActionRow.js +105 -103
  276. package/src/structures/MessageAttachment.js +216 -204
  277. package/src/structures/MessageButton.js +166 -165
  278. package/src/structures/MessageCollector.js +146 -146
  279. package/src/structures/MessageComponentInteraction.js +120 -120
  280. package/src/structures/MessageContextMenuInteraction.js +20 -20
  281. package/src/structures/MessageEmbed.js +596 -586
  282. package/src/structures/MessageMentions.js +273 -273
  283. package/src/structures/MessagePayload.js +354 -318
  284. package/src/structures/MessageReaction.js +181 -171
  285. package/src/structures/MessageSelectMenu.js +141 -140
  286. package/src/structures/Modal.js +161 -161
  287. package/src/structures/ModalSubmitFieldsResolver.js +53 -53
  288. package/src/structures/ModalSubmitInteraction.js +119 -119
  289. package/src/structures/NewsChannel.js +32 -32
  290. package/src/structures/OAuth2Guild.js +28 -28
  291. package/src/structures/PermissionOverwrites.js +198 -196
  292. package/src/structures/Poll.js +108 -0
  293. package/src/structures/PollAnswer.js +88 -0
  294. package/src/structures/Presence.js +1137 -1101
  295. package/src/structures/ReactionCollector.js +229 -229
  296. package/src/structures/ReactionEmoji.js +31 -31
  297. package/src/structures/Role.js +590 -531
  298. package/src/structures/SectionComponent.js +48 -0
  299. package/src/structures/SelectMenuInteraction.js +21 -21
  300. package/src/structures/SeparatorComponent.js +48 -0
  301. package/src/structures/Session.js +81 -0
  302. package/src/structures/StageChannel.js +104 -104
  303. package/src/structures/StageInstance.js +208 -208
  304. package/src/structures/Sticker.js +310 -310
  305. package/src/structures/StickerPack.js +95 -95
  306. package/src/structures/StoreChannel.js +56 -56
  307. package/src/structures/Team.js +118 -118
  308. package/src/structures/TeamMember.js +80 -71
  309. package/src/structures/TextChannel.js +33 -33
  310. package/src/structures/TextDisplayComponent.js +40 -0
  311. package/src/structures/TextInputComponent.js +132 -131
  312. package/src/structures/ThreadChannel.js +605 -607
  313. package/src/structures/ThreadMember.js +105 -105
  314. package/src/structures/ThreadOnlyChannel.js +249 -0
  315. package/src/structures/ThumbnailComponent.js +57 -0
  316. package/src/structures/Typing.js +74 -74
  317. package/src/structures/UnfurledMediaItem.js +29 -0
  318. package/src/structures/User.js +640 -543
  319. package/src/structures/UserContextMenuInteraction.js +29 -29
  320. package/src/structures/VoiceChannel.js +110 -110
  321. package/src/structures/VoiceChannelEffect.js +69 -0
  322. package/src/structures/VoiceRegion.js +53 -53
  323. package/src/structures/VoiceState.js +354 -341
  324. package/src/structures/WebEmbed.js +373 -373
  325. package/src/structures/Webhook.js +478 -467
  326. package/src/structures/WelcomeChannel.js +60 -60
  327. package/src/structures/WelcomeScreen.js +48 -48
  328. package/src/structures/Widget.js +87 -87
  329. package/src/structures/WidgetMember.js +99 -99
  330. package/src/structures/interfaces/Application.js +825 -313
  331. package/src/structures/interfaces/Collector.js +300 -300
  332. package/src/structures/interfaces/InteractionResponses.js +313 -313
  333. package/src/structures/interfaces/TextBasedChannel.js +759 -719
  334. package/src/util/APITypes.js +59 -0
  335. package/src/util/ActivityFlags.js +44 -44
  336. package/src/util/ApplicationFlags.js +76 -76
  337. package/src/util/AttachmentFlags.js +38 -38
  338. package/src/util/BitField.js +170 -170
  339. package/src/util/ChannelFlags.js +45 -45
  340. package/src/util/Constants.js +1914 -1773
  341. package/src/util/DataResolver.js +146 -145
  342. package/src/util/Formatters.js +228 -228
  343. package/src/util/GuildMemberFlags.js +43 -43
  344. package/src/util/Intents.js +74 -74
  345. package/src/util/InviteFlags.js +34 -29
  346. package/src/util/LimitedCollection.js +131 -131
  347. package/src/util/MessageFlags.js +63 -54
  348. package/src/util/Options.js +358 -336
  349. package/src/util/Permissions.js +202 -202
  350. package/src/util/PremiumUsageFlags.js +31 -31
  351. package/src/util/PurchasedFlags.js +33 -33
  352. package/src/util/RemoteAuth.js +382 -379
  353. package/src/util/RoleFlags.js +37 -37
  354. package/src/util/SnowflakeUtil.js +92 -92
  355. package/src/util/Speaking.js +33 -0
  356. package/src/util/Sweepers.js +466 -466
  357. package/src/util/SystemChannelFlags.js +55 -55
  358. package/src/util/ThreadMemberFlags.js +30 -30
  359. package/src/util/UserFlags.js +104 -104
  360. package/src/util/Util.js +1048 -889
  361. package/typings/enums.d.ts +439 -297
  362. package/typings/index.d.ts +8392 -7432
  363. package/typings/rawDataTypes.d.ts +403 -342
  364. package/src/structures/MessagePoll.js +0 -238
@@ -1,448 +1,653 @@
1
- 'use strict';
2
-
3
- const { setInterval } = require('node:timers');
4
- const { Collection } = require('@discordjs/collection');
5
- const Invite = require('./Invite');
6
- const User = require('./User');
7
- const DataResolver = require('../util/DataResolver');
8
- const PremiumUsageFlags = require('../util/PremiumUsageFlags');
9
- const PurchasedFlags = require('../util/PurchasedFlags');
10
- const Util = require('../util/Util');
11
-
12
- /**
13
- * Represents the logged in client's Discord user.
14
- * @extends {User}
15
- */
16
- class ClientUser extends User {
17
- #packageName = null;
18
- #intervalSamsungPresence = setInterval(() => {
19
- this.client.emit('debug', `[UPDATE] Samsung Presence: ${this.#packageName}`);
20
- if (!this.#packageName) return;
21
- this.setSamsungActivity(this.#packageName, 'UPDATE');
22
- }, 1000 * 60 * 10).unref();
23
-
24
- _patch(data) {
25
- super._patch(data);
26
-
27
- if ('verified' in data) {
28
- /**
29
- * Whether or not this account has been verified
30
- * @type {boolean}
31
- */
32
- this.verified = data.verified;
33
- }
34
-
35
- if ('mfa_enabled' in data) {
36
- /**
37
- * If the bot's {@link Application#owner Owner} has MFA enabled on their account
38
- * @type {?boolean}
39
- */
40
- this.mfaEnabled = typeof data.mfa_enabled === 'boolean' ? data.mfa_enabled : null;
41
- } else {
42
- this.mfaEnabled ??= null;
43
- }
44
-
45
- if ('token' in data) this.client.token = data.token;
46
-
47
- if ('purchased_flags' in data) {
48
- /**
49
- * Purchased state of the client user.
50
- * @type {Readonly<PurchasedFlags>}
51
- */
52
- this.purchasedFlags = new PurchasedFlags(data.purchased_flags || 0).freeze();
53
- } else {
54
- this.purchasedFlags = new PurchasedFlags().freeze();
55
- }
56
-
57
- if ('premium_usage_flags' in data) {
58
- /**
59
- * Premium usage state of the client user.
60
- * @type {Readonly<PremiumUsageFlags>}
61
- */
62
- this.premiumUsageFlags = new PremiumUsageFlags(data.premium_usage_flags || 0);
63
- } else {
64
- this.premiumUsageFlags = new PremiumUsageFlags().freeze();
65
- }
66
-
67
- if ('phone' in data) {
68
- /**
69
- * Phone number of the client user.
70
- * @type {?string}
71
- */
72
- this.phone = data.phone;
73
- }
74
-
75
- if ('nsfw_allowed' in data) {
76
- /**
77
- * Whether or not the client user is allowed to send NSFW messages [iOS device].
78
- * @type {?boolean}
79
- */
80
- this.nsfwAllowed = data.nsfw_allowed;
81
- }
82
-
83
- if ('email' in data) {
84
- /**
85
- * Email address of the client user.
86
- * @type {?string}
87
- */
88
- this.email = data.email;
89
- }
90
-
91
- if ('bio' in data) {
92
- /**
93
- * About me (User)
94
- * <info>The user must be force fetched for this property to be present or be updated</info>
95
- * @type {?string}
96
- */
97
- this.bio = data.bio;
98
- }
99
-
100
- if ('pronouns' in data) {
101
- /**
102
- * Pronouns (User)
103
- * <info>The user must be force fetched for this property to be present or be updated</info>
104
- * @type {?string}
105
- */
106
- this.pronouns = data.pronouns;
107
- }
108
-
109
- if ('premium_type' in data) {
110
- /**
111
- * Premium types denote the level of premium a user has.
112
- * @type {number}
113
- * @see {@link https://discord-userdoccers.vercel.app/resources/user#premium-type}
114
- */
115
- this.premiumType = data.premium_type;
116
- }
117
- }
118
-
119
- /**
120
- * Represents the client user's presence
121
- * @type {ClientPresence}
122
- * @readonly
123
- */
124
- get presence() {
125
- return this.client.presence;
126
- }
127
-
128
- /**
129
- * Data used to edit the logged in client
130
- * @typedef {Object} ClientUserEditData
131
- * @property {string} [username] The new username
132
- * @property {?(BufferResolvable|Base64Resolvable)} [avatar] The new avatar
133
- * @property {?(BufferResolvable|Base64Resolvable)} [banner] The new banner
134
- * @property {?string} [bio] The new bio
135
- */
136
-
137
- /**
138
- * Edits the logged in client.
139
- * @param {ClientUserEditData} options The new data
140
- * @returns {Promise<ClientUser>}
141
- */
142
- async edit(options = {}) {
143
- const data = await this.client.api.users('@me').patch({ data: options });
144
- this.client.token = data.token;
145
- const { updated } = this.client.actions.UserUpdate.handle(data);
146
- return updated ?? this;
147
- }
148
-
149
- /**
150
- * Sets the username of the logged in client.
151
- * <info>Changing usernames in Discord is heavily rate limited, with only 2 requests
152
- * every hour. Use this sparingly!</info>
153
- * @param {string} username The new username
154
- * @param {string} password Current Password
155
- * @returns {Promise<ClientUser>}
156
- * @example
157
- * // Set username
158
- * client.user.setUsername('discordjs', 'passw@rd')
159
- * .then(user => console.log(`My new username is ${user.username}`))
160
- * .catch(console.error);
161
- */
162
- setUsername(username, password) {
163
- return this.edit({ username, password });
164
- }
165
-
166
- /**
167
- * Sets the avatar of the logged in client.
168
- * @param {?(BufferResolvable|Base64Resolvable)} avatar The new avatar
169
- * @returns {Promise<ClientUser>}
170
- * @example
171
- * // Set avatar
172
- * client.user.setAvatar('./avatar.png')
173
- * .then(user => console.log(`New avatar set!`))
174
- * .catch(console.error);
175
- */
176
- async setAvatar(avatar) {
177
- avatar = avatar && (await DataResolver.resolveImage(avatar));
178
- return this.edit({ avatar });
179
- }
180
-
181
- /**
182
- * Options for setting activities
183
- * @typedef {Object} ActivitiesOptions
184
- * @property {string} name Name of the activity
185
- * @property {string} [state] State of the activity
186
- * @property {ActivityType|number} [type] Type of the activity
187
- * @property {string} [url] Twitch / YouTube stream URL
188
- */
189
-
190
- /**
191
- * Data resembling a raw Discord presence.
192
- * @typedef {Object} PresenceData
193
- * @property {PresenceStatusData} [status] Status of the user
194
- * @property {boolean} [afk] Whether the user is AFK
195
- * @property {ActivitiesOptions[]|CustomStatus[]|RichPresence[]|SpotifyRPC[]} [activities] Activity the user is playing
196
- * @property {number|number[]} [shardId] Shard id(s) to have the activity set on
197
- */
198
-
199
- /**
200
- * Sets the full presence of the client user.
201
- * @param {PresenceData} data Data for the presence
202
- * @returns {ClientPresence}
203
- * @example
204
- * // Set the client user's presence
205
- * client.user.setPresence({ activities: [{ name: 'with discord.js' }], status: 'idle' });
206
- */
207
- setPresence(data) {
208
- return this.client.presence.set(data);
209
- }
210
-
211
- /**
212
- * A user's status. Must be one of:
213
- * * `online`
214
- * * `idle`
215
- * * `invisible`
216
- * * `dnd` (do not disturb)
217
- * @typedef {string} PresenceStatusData
218
- */
219
-
220
- /**
221
- * Sets the status of the client user.
222
- * @param {PresenceStatusData} status Status to change to
223
- * @param {number|number[]} [shardId] Shard id(s) to have the activity set on
224
- * @returns {ClientPresence}
225
- * @example
226
- * // Set the client user's status
227
- * client.user.setStatus('idle');
228
- */
229
- setStatus(status, shardId) {
230
- return this.setPresence({ status, shardId });
231
- }
232
-
233
- /**
234
- * Options for setting an activity.
235
- * @typedef {Object} ActivityOptions
236
- * @property {string} name Name of the activity
237
- * @property {string} [url] Twitch / YouTube stream URL
238
- * @property {ActivityType|number} [type] Type of the activity
239
- * @property {number|number[]} [shardId] Shard Id(s) to have the activity set on
240
- */
241
-
242
- /**
243
- * Sets the activity the client user is playing.
244
- * @param {string|ActivityOptions} name Activity being played, or options for setting the activity
245
- * @param {ActivityOptions} [options] Options for setting the activity
246
- * @returns {ClientPresence}
247
- * @example
248
- * // Set the client user's activity
249
- * client.user.setActivity('discord.js', { type: 'WATCHING' });
250
- */
251
- setActivity(name, options = {}) {
252
- if (!name) return this.setPresence({ activities: [], shardId: options.shardId });
253
-
254
- const activity = Object.assign({}, options, typeof name === 'object' ? name : { name });
255
- return this.setPresence({ activities: [activity], shardId: activity.shardId });
256
- }
257
-
258
- /**
259
- * Sets/removes the AFK flag for the client user.
260
- * @param {boolean} [afk=true] Whether or not the user is AFK
261
- * @param {number|number[]} [shardId] Shard Id(s) to have the AFK flag set on
262
- * @returns {ClientPresence}
263
- */
264
- setAFK(afk = true, shardId) {
265
- return this.setPresence({ afk, shardId });
266
- }
267
-
268
- /**
269
- * Sets the banner of the logged in client.
270
- * @param {?(BufferResolvable|Base64Resolvable)} banner The new banner
271
- * @returns {Promise<ClientUser>}
272
- * @example
273
- * // Set banner
274
- * client.user.setBanner('./banner.png')
275
- * .then(user => console.log(`New banner set!`))
276
- * .catch(console.error);
277
- */
278
- async setBanner(banner) {
279
- banner = banner && (await DataResolver.resolveImage(banner));
280
- return this.edit({ banner });
281
- }
282
-
283
- /**
284
- * Set HyperSquad House
285
- * @param {string|number} type
286
- * * `LEAVE`: 0
287
- * * `HOUSE_BRAVERY`: 1
288
- * * `HOUSE_BRILLIANCE`: 2
289
- * * `HOUSE_BALANCE`: 3
290
- * @returns {Promise<void>}
291
- * @example
292
- * // Set HyperSquad HOUSE_BRAVERY
293
- * client.user.setHypeSquad(1); || client.user.setHypeSquad('HOUSE_BRAVERY');
294
- * // Leave
295
- * client.user.setHypeSquad(0);
296
- */
297
- setHypeSquad(type) {
298
- switch (type) {
299
- case 'LEAVE': {
300
- type = 0;
301
- break;
302
- }
303
- case 'HOUSE_BRAVERY': {
304
- type = 1;
305
- break;
306
- }
307
- case 'HOUSE_BRILLIANCE': {
308
- type = 2;
309
- break;
310
- }
311
- case 'HOUSE_BALANCE': {
312
- type = 3;
313
- break;
314
- }
315
- }
316
- if (type == 0) {
317
- return this.client.api.hypesquad.online.delete();
318
- } else {
319
- return this.client.api.hypesquad.online.post({
320
- data: { house_id: type },
321
- });
322
- }
323
- }
324
-
325
- /**
326
- * Set Accent color
327
- * @param {ColorResolvable} color Color to set
328
- * @returns {Promise<ClientUser>}
329
- */
330
- setAccentColor(color = null) {
331
- return this.edit({ accent_color: color ? Util.resolveColor(color) : null });
332
- }
333
-
334
- /**
335
- * Set About me
336
- * @param {string} [bio=null] Bio to set
337
- * @returns {Promise<ClientUser>}
338
- */
339
- setAboutMe(bio = null) {
340
- return this.edit({ bio });
341
- }
342
-
343
- /**
344
- * Create an invite [Friend Invites]
345
- * maxAge: 604800 | maxUses: 1
346
- * @returns {Promise<Invite>}
347
- * @see {@link https://github.com/13-05/hidden-disc-docs#js-snippet-for-creating-friend-invites}
348
- * @example
349
- * // Options not working
350
- * client.user.createFriendInvite();
351
- * .then(console.log)
352
- * .catch(console.error);
353
- */
354
- async createFriendInvite() {
355
- const data = await this.client.api.users['@me'].invites.post({
356
- data: {},
357
- });
358
- return new Invite(this.client, data);
359
- }
360
-
361
- /**
362
- * Get all friend invites
363
- * @returns {Promise<Collection<string, Invite>>}
364
- */
365
- async getAllFriendInvites() {
366
- const data = await this.client.api.users['@me'].invites.get();
367
- const collection = new Collection();
368
- for (const invite of data) {
369
- collection.set(invite.code, new Invite(this.client, invite));
370
- }
371
- return collection;
372
- }
373
-
374
- /**
375
- * Revoke all friend invites
376
- * @returns {Promise<void>}
377
- */
378
- revokeAllFriendInvites() {
379
- return this.client.api.users['@me'].invites.delete();
380
- }
381
-
382
- /**
383
- * Sets Discord Playing status to "Playing on Samsung Galaxy". Only selected gamss from discords database works
384
- * @param {string} packageName Android package name
385
- * @param {?string} type Must be START, UPDATE, or STOP
386
- * @returns {Promise<ClientUser>}
387
- * @example
388
- * // Set the client user's status
389
- * client.user.setSamsungActivity('com.YostarJP.BlueArchive', 'START');
390
- * // Update
391
- * client.user.setSamsungActivity('com.miHoYo.bh3oversea', 'UPDATE');
392
- * // Stop
393
- * client.user.setSamsungActivity('com.miHoYo.GenshinImpact', 'STOP');
394
- */
395
- async setSamsungActivity(packageName, type = 'START') {
396
- type = type.toUpperCase();
397
- if (!packageName || typeof packageName !== 'string') throw new Error('Package name is required.');
398
- if (!['START', 'UPDATE', 'STOP'].includes(type)) throw new Error('Invalid type (Must be START, UPDATE, or STOP)');
399
- await this.client.api.presences.post({
400
- data: {
401
- package_name: packageName,
402
- update: type,
403
- },
404
- });
405
- if (type !== 'STOP') this.#packageName = packageName;
406
- else this.#packageName = null;
407
- return this;
408
- }
409
-
410
- /**
411
- * Stop ringing
412
- * @param {ChannelResolvable} channel DMChannel | GroupDMChannel
413
- * @returns {Promise<void>}
414
- */
415
- stopRinging(channel) {
416
- return this.client.api.channels(this.client.channels.resolveId(channel)).call['stop-ringing'].post({
417
- data: {},
418
- });
419
- }
420
-
421
- /**
422
- * Super Reactions
423
- * @returns {Promise<number>}
424
- */
425
- fetchBurstCredit() {
426
- return this.client.api.users['@me']['burst-credits'].get().then(d => d.amount);
427
- }
428
-
429
- /**
430
- * Set global display name
431
- * @param {string} globalName The new display name
432
- * @returns {Promise<ClientUser>}
433
- */
434
- setGlobalName(globalName = '') {
435
- return this.edit({ global_name: globalName });
436
- }
437
-
438
- /**
439
- * Set pronouns
440
- * @param {?string} pronouns Your pronouns
441
- * @returns {Promise<ClientUser>}
442
- */
443
- setPronouns(pronouns = '') {
444
- return this.edit({ pronouns });
445
- }
446
- }
447
-
448
- module.exports = ClientUser;
1
+ 'use strict';
2
+
3
+ const { setInterval } = require('node:timers');
4
+ const { Collection } = require('@discordjs/collection');
5
+ const Invite = require('./Invite');
6
+ const User = require('./User');
7
+ const DataResolver = require('../util/DataResolver');
8
+ const PremiumUsageFlags = require('../util/PremiumUsageFlags');
9
+ const PurchasedFlags = require('../util/PurchasedFlags');
10
+ const { Error, TypeError } = require('../errors');
11
+ const Util = require('../util/Util');
12
+
13
+ /**
14
+ * Represents the logged in client's Discord user.
15
+ * @extends {User}
16
+ */
17
+ class ClientUser extends User {
18
+ #packageName = null;
19
+ #intervalSamsungPresence = setInterval(() => {
20
+ this.client.emit('debug', `[UPDATE] Samsung Presence: ${this.#packageName}`);
21
+ if (!this.#packageName) return;
22
+ this.setSamsungActivity(this.#packageName, 'UPDATE');
23
+ }, 1000 * 60 * 10).unref();
24
+
25
+ _patch(data) {
26
+ super._patch(data);
27
+
28
+ if ('verified' in data) {
29
+ /**
30
+ * Whether or not this account has been verified
31
+ * @type {boolean}
32
+ */
33
+ this.verified = data.verified;
34
+ }
35
+
36
+ if ('mfa_enabled' in data) {
37
+ /**
38
+ * If the bot's {@link Application#owner Owner} has MFA enabled on their account
39
+ * @type {?boolean}
40
+ */
41
+ this.mfaEnabled = typeof data.mfa_enabled === 'boolean' ? data.mfa_enabled : null;
42
+ } else {
43
+ this.mfaEnabled ??= null;
44
+ }
45
+
46
+ if ('token' in data) this.client.token = data.token;
47
+
48
+ if ('purchased_flags' in data) {
49
+ /**
50
+ * Purchased state of the client user.
51
+ * @type {Readonly<PurchasedFlags>}
52
+ */
53
+ this.purchasedFlags = new PurchasedFlags(data.purchased_flags || 0).freeze();
54
+ } else {
55
+ this.purchasedFlags = new PurchasedFlags().freeze();
56
+ }
57
+
58
+ if ('premium_usage_flags' in data) {
59
+ /**
60
+ * Premium usage state of the client user.
61
+ * @type {Readonly<PremiumUsageFlags>}
62
+ */
63
+ this.premiumUsageFlags = new PremiumUsageFlags(data.premium_usage_flags || 0);
64
+ } else {
65
+ this.premiumUsageFlags = new PremiumUsageFlags().freeze();
66
+ }
67
+
68
+ if ('phone' in data) {
69
+ /**
70
+ * Phone number of the client user.
71
+ * @type {?string}
72
+ */
73
+ this.phone = data.phone;
74
+ }
75
+
76
+ if ('nsfw_allowed' in data) {
77
+ /**
78
+ * Whether or not the client user is allowed to send NSFW messages [iOS device].
79
+ * @type {?boolean}
80
+ */
81
+ this.nsfwAllowed = data.nsfw_allowed;
82
+ }
83
+
84
+ if ('email' in data) {
85
+ /**
86
+ * Email address of the client user.
87
+ * @type {?string}
88
+ */
89
+ this.email = data.email;
90
+ }
91
+
92
+ if ('bio' in data) {
93
+ /**
94
+ * About me (User)
95
+ * <info>The user must be force fetched for this property to be present or be updated</info>
96
+ * @type {?string}
97
+ */
98
+ this.bio = data.bio;
99
+ }
100
+
101
+ if ('pronouns' in data) {
102
+ /**
103
+ * Pronouns (User)
104
+ * <info>The user must be force fetched for this property to be present or be updated</info>
105
+ * @type {?string}
106
+ */
107
+ this.pronouns = data.pronouns;
108
+ }
109
+
110
+ if ('premium_type' in data) {
111
+ /**
112
+ * Premium types denote the level of premium a user has.
113
+ * @type {number}
114
+ * @see {@link https://discord-userdoccers.vercel.app/resources/user#premium-type}
115
+ */
116
+ this.premiumType = data.premium_type;
117
+ }
118
+ }
119
+
120
+ /**
121
+ * Represents the client user's presence
122
+ * @type {ClientPresence}
123
+ * @readonly
124
+ */
125
+ get presence() {
126
+ return this.client.presence;
127
+ }
128
+
129
+ /**
130
+ * Data used to edit the logged in client
131
+ * @typedef {Object} ClientUserEditData
132
+ * @property {string} [username] The new username
133
+ * @property {?(BufferResolvable|Base64Resolvable)} [avatar] The new avatar
134
+ * @property {?(BufferResolvable|Base64Resolvable)} [banner] The new banner
135
+ * @property {?string} [bio] The new bio
136
+ */
137
+
138
+ /**
139
+ * Edits the logged in client.
140
+ * @param {ClientUserEditData} options The new data
141
+ * @returns {Promise<ClientUser>}
142
+ */
143
+ async edit(options = {}) {
144
+ const data = await this.client.api.users('@me').patch({ data: options });
145
+ const { updated } = this.client.actions.UserUpdate.handle(data);
146
+ return updated ?? this;
147
+ }
148
+
149
+ /**
150
+ * Sets the username of the logged in client.
151
+ * <info>Changing usernames in Discord is heavily rate limited, with only 2 requests
152
+ * every hour. Use this sparingly!</info>
153
+ * @param {string} username The new username
154
+ * @param {string} password Current Password
155
+ * @returns {Promise<ClientUser>}
156
+ * @example
157
+ * // Set username
158
+ * client.user.setUsername('discordjs', 'passw@rd')
159
+ * .then(user => console.log(`My new username is ${user.username}`))
160
+ * .catch(console.error);
161
+ */
162
+ setUsername(username, password) {
163
+ return this.edit({ username, password });
164
+ }
165
+
166
+ /**
167
+ * Sets the avatar of the logged in client.
168
+ * @param {?(BufferResolvable|Base64Resolvable)} avatar The new avatar
169
+ * @returns {Promise<ClientUser>}
170
+ * @example
171
+ * // Set avatar
172
+ * client.user.setAvatar('./avatar.png')
173
+ * .then(user => console.log(`New avatar set!`))
174
+ * .catch(console.error);
175
+ */
176
+ async setAvatar(avatar) {
177
+ avatar = avatar && (await DataResolver.resolveImage(avatar));
178
+ return this.edit({ avatar });
179
+ }
180
+
181
+ /**
182
+ * Options for setting activities
183
+ * @typedef {Object} ActivitiesOptions
184
+ * @property {string} name Name of the activity
185
+ * @property {string} [state] State of the activity
186
+ * @property {ActivityType|number} [type] Type of the activity
187
+ * @property {string} [url] Twitch / YouTube stream URL
188
+ */
189
+
190
+ /**
191
+ * Data resembling a raw Discord presence.
192
+ * @typedef {Object} PresenceData
193
+ * @property {PresenceStatusData} [status] Status of the user
194
+ * @property {boolean} [afk] Whether the user is AFK
195
+ * @property {ActivitiesOptions[]|CustomStatus[]|RichPresence[]|SpotifyRPC[]} [activities] Activity the user is playing
196
+ * @property {number|number[]} [shardId] Shard id(s) to have the activity set on
197
+ */
198
+
199
+ /**
200
+ * Sets the full presence of the client user.
201
+ * @param {PresenceData} data Data for the presence
202
+ * @returns {ClientPresence}
203
+ * @example
204
+ * // Set the client user's presence
205
+ * client.user.setPresence({ activities: [{ name: 'with discord.js' }], status: 'idle' });
206
+ * @see {@link https://github.com/aiko-chan-ai/discord.js-selfbot-v13/blob/main/Document/RichPresence.md}
207
+ */
208
+ setPresence(data) {
209
+ return this.client.presence.set(data);
210
+ }
211
+
212
+ /**
213
+ * A user's status. Must be one of:
214
+ * * `online`
215
+ * * `idle`
216
+ * * `invisible`
217
+ * * `dnd` (do not disturb)
218
+ * @typedef {string} PresenceStatusData
219
+ */
220
+
221
+ /**
222
+ * Sets the status of the client user.
223
+ * @param {PresenceStatusData} status Status to change to
224
+ * @param {number|number[]} [shardId] Shard id(s) to have the activity set on
225
+ * @returns {ClientPresence}
226
+ * @example
227
+ * // Set the client user's status
228
+ * client.user.setStatus('idle');
229
+ */
230
+ setStatus(status, shardId) {
231
+ return this.setPresence({ status, shardId });
232
+ }
233
+
234
+ /**
235
+ * Options for setting an activity.
236
+ * @typedef {Object} ActivityOptions
237
+ * @property {string} name Name of the activity
238
+ * @property {string} [url] Twitch / YouTube stream URL
239
+ * @property {ActivityType|number} [type] Type of the activity
240
+ * @property {number|number[]} [shardId] Shard Id(s) to have the activity set on
241
+ */
242
+
243
+ /**
244
+ * Sets the activity the client user is playing.
245
+ * @param {string|ActivityOptions} name Activity being played, or options for setting the activity
246
+ * @param {ActivityOptions} [options] Options for setting the activity
247
+ * @returns {ClientPresence}
248
+ * @example
249
+ * // Set the client user's activity
250
+ * client.user.setActivity('discord.js', { type: 'WATCHING' });
251
+ * @see {@link https://github.com/aiko-chan-ai/discord.js-selfbot-v13/blob/main/Document/RichPresence.md}
252
+ */
253
+ setActivity(name, options = {}) {
254
+ if (!name) return this.setPresence({ activities: [], shardId: options.shardId });
255
+
256
+ const activity = Object.assign({}, options, typeof name === 'object' ? name : { name });
257
+ return this.setPresence({ activities: [activity], shardId: activity.shardId });
258
+ }
259
+
260
+ /**
261
+ * Sets/removes the AFK flag for the client user.
262
+ * @param {boolean} [afk=true] Whether or not the user is AFK
263
+ * @param {number|number[]} [shardId] Shard Id(s) to have the AFK flag set on
264
+ * @returns {ClientPresence}
265
+ */
266
+ setAFK(afk = true, shardId) {
267
+ return this.setPresence({ afk, shardId });
268
+ }
269
+
270
+ /**
271
+ * Sets the banner of the logged in client.
272
+ * @param {?(BufferResolvable|Base64Resolvable)} banner The new banner
273
+ * @returns {Promise<ClientUser>}
274
+ * @example
275
+ * // Set banner
276
+ * client.user.setBanner('./banner.png')
277
+ * .then(user => console.log(`New banner set!`))
278
+ * .catch(console.error);
279
+ */
280
+ async setBanner(banner) {
281
+ banner = banner && (await DataResolver.resolveImage(banner));
282
+ return this.edit({ banner });
283
+ }
284
+
285
+ /**
286
+ * Set HyperSquad House
287
+ * @param {string|number} type
288
+ * * `LEAVE`: 0
289
+ * * `HOUSE_BRAVERY`: 1
290
+ * * `HOUSE_BRILLIANCE`: 2
291
+ * * `HOUSE_BALANCE`: 3
292
+ * @returns {Promise<void>}
293
+ * @example
294
+ * // Set HyperSquad HOUSE_BRAVERY
295
+ * client.user.setHypeSquad(1); || client.user.setHypeSquad('HOUSE_BRAVERY');
296
+ * // Leave
297
+ * client.user.setHypeSquad(0);
298
+ */
299
+ setHypeSquad(type) {
300
+ switch (type) {
301
+ case 'LEAVE': {
302
+ type = 0;
303
+ break;
304
+ }
305
+ case 'HOUSE_BRAVERY': {
306
+ type = 1;
307
+ break;
308
+ }
309
+ case 'HOUSE_BRILLIANCE': {
310
+ type = 2;
311
+ break;
312
+ }
313
+ case 'HOUSE_BALANCE': {
314
+ type = 3;
315
+ break;
316
+ }
317
+ }
318
+ if (type == 0) {
319
+ return this.client.api.hypesquad.online.delete();
320
+ } else {
321
+ return this.client.api.hypesquad.online.post({
322
+ data: { house_id: type },
323
+ });
324
+ }
325
+ }
326
+
327
+ /**
328
+ * Set Accent color
329
+ * @param {ColorResolvable} color Color to set
330
+ * @returns {Promise<ClientUser>}
331
+ */
332
+ setAccentColor(color = null) {
333
+ return this.edit({ accent_color: color ? Util.resolveColor(color) : null });
334
+ }
335
+
336
+ /**
337
+ * Set About me
338
+ * @param {string} [bio=null] Bio to set
339
+ * @returns {Promise<ClientUser>}
340
+ */
341
+ setAboutMe(bio = null) {
342
+ return this.edit({ bio });
343
+ }
344
+
345
+ /**
346
+ * Create an invite [Friend Invites]
347
+ * maxAge: 604800 | maxUses: 1
348
+ * @returns {Promise<Invite>}
349
+ * @see {@link https://github.com/13-05/hidden-disc-docs#js-snippet-for-creating-friend-invites}
350
+ * @example
351
+ * // Options not working
352
+ * client.user.createFriendInvite();
353
+ * .then(console.log)
354
+ * .catch(console.error);
355
+ */
356
+ async createFriendInvite() {
357
+ const data = await this.client.api.users['@me'].invites.post({
358
+ data: {},
359
+ });
360
+ return new Invite(this.client, data);
361
+ }
362
+
363
+ /**
364
+ * Get all friend invites
365
+ * @returns {Promise<Collection<string, Invite>>}
366
+ */
367
+ async getAllFriendInvites() {
368
+ const data = await this.client.api.users['@me'].invites.get();
369
+ const collection = new Collection();
370
+ for (const invite of data) {
371
+ collection.set(invite.code, new Invite(this.client, invite));
372
+ }
373
+ return collection;
374
+ }
375
+
376
+ /**
377
+ * Revoke all friend invites
378
+ * @returns {Promise<void>}
379
+ */
380
+ revokeAllFriendInvites() {
381
+ return this.client.api.users['@me'].invites.delete();
382
+ }
383
+
384
+ /**
385
+ * Sets Discord Playing status to "Playing on Samsung Galaxy". Only selected gamss from discords database works
386
+ * @param {string} packageName Android package name
387
+ * @param {?string} type Must be START, UPDATE, or STOP
388
+ * @returns {Promise<ClientUser>}
389
+ * @example
390
+ * // Set the client user's status
391
+ * client.user.setSamsungActivity('com.YostarJP.BlueArchive', 'START');
392
+ * // Update
393
+ * client.user.setSamsungActivity('com.miHoYo.bh3oversea', 'UPDATE');
394
+ * // Stop
395
+ * client.user.setSamsungActivity('com.miHoYo.GenshinImpact', 'STOP');
396
+ */
397
+ async setSamsungActivity(packageName, type = 'START') {
398
+ type = type.toUpperCase();
399
+ if (!packageName || typeof packageName !== 'string') throw new Error('Package name is required.');
400
+ if (!['START', 'UPDATE', 'STOP'].includes(type)) throw new Error('Invalid type (Must be START, UPDATE, or STOP)');
401
+ await this.client.api.presences.post({
402
+ data: {
403
+ package_name: packageName,
404
+ update: type,
405
+ },
406
+ });
407
+ if (type !== 'STOP') this.#packageName = packageName;
408
+ else this.#packageName = null;
409
+ return this;
410
+ }
411
+
412
+ /**
413
+ * Stop ringing
414
+ * @param {ChannelResolvable} channel DMChannel | GroupDMChannel
415
+ * @returns {Promise<void>}
416
+ */
417
+ stopRinging(channel) {
418
+ return this.client.api.channels(this.client.channels.resolveId(channel)).call['stop-ringing'].post({
419
+ data: {},
420
+ });
421
+ }
422
+
423
+ /**
424
+ * Super Reactions
425
+ * @returns {Promise<number>}
426
+ */
427
+ fetchBurstCredit() {
428
+ return this.client.api.users['@me']['burst-credits'].get().then(d => d.amount);
429
+ }
430
+
431
+ /**
432
+ * Set global display name
433
+ * @param {string} globalName The new display name
434
+ * @returns {Promise<ClientUser>}
435
+ */
436
+ setGlobalName(globalName = '') {
437
+ return this.edit({ global_name: globalName });
438
+ }
439
+
440
+ /**
441
+ * Set pronouns
442
+ * @param {?string} pronouns Your pronouns
443
+ * @returns {Promise<ClientUser>}
444
+ */
445
+ setPronouns(pronouns = '') {
446
+ return this.edit({ pronouns });
447
+ }
448
+
449
+ /**
450
+ * Add a widget to the user's profile
451
+ * @param {string} type Widget type (favorite_games, current_games, played_games, want_to_play_games)
452
+ * @param {string} gameId The game ID to add
453
+ * @param {string} [comment] Optional comment for the game
454
+ * @param {string[]} [tags] Optional tags for the game
455
+ * @returns {Promise<Object>}
456
+ */
457
+ async addWidget(type, gameId, comment = null, tags = []) {
458
+ if (!type || !gameId) {
459
+ throw new TypeError('Widget type and game ID are required');
460
+ }
461
+
462
+ const validTypes = ['favorite_games', 'current_games', 'played_games', 'want_to_play_games'];
463
+ if (!validTypes.includes(type)) {
464
+ throw new TypeError(`Invalid widget type. Must be one of: ${validTypes.join(', ')}`);
465
+ }
466
+
467
+ // Get current widgets first
468
+ const currentWidgets = await this.widgetsList();
469
+
470
+ // Find existing widget of this type or create new one
471
+ let targetWidget = currentWidgets.widgets.find(w => w.data.type === type);
472
+
473
+ if (!targetWidget) {
474
+ // Create new widget if it doesn't exist
475
+ targetWidget = {
476
+ id: Date.now().toString(), // Generate temporary ID
477
+ data: {
478
+ type: type,
479
+ games: []
480
+ }
481
+ };
482
+ currentWidgets.widgets.push(targetWidget);
483
+ }
484
+
485
+ // Add the game if it doesn't already exist
486
+ const existingGame = targetWidget.data.games.find(g => g.game_id === gameId);
487
+ if (!existingGame) {
488
+ const gameData = { game_id: gameId };
489
+ if (comment !== null) gameData.comment = comment;
490
+ if (tags.length > 0) gameData.tags = tags;
491
+
492
+ targetWidget.data.games.push(gameData);
493
+ }
494
+
495
+ // Update widgets via API
496
+ return this.client.api.users['@me'].profile.patch({
497
+ data: { widgets: currentWidgets.widgets }
498
+ });
499
+ }
500
+
501
+ /**
502
+ * Delete a widget or remove a game from a widget
503
+ * @param {string} type Widget type to modify
504
+ * @param {string} [gameId] Optional game ID to remove (if not provided, removes entire widget)
505
+ * @returns {Promise<Object>}
506
+ */
507
+ async delWidget(type, gameId = null) {
508
+ if (!type) {
509
+ throw new TypeError('Widget type is required');
510
+ }
511
+
512
+ const validTypes = ['favorite_games', 'current_games', 'played_games', 'want_to_play_games'];
513
+ if (!validTypes.includes(type)) {
514
+ throw new TypeError(`Invalid widget type. Must be one of: ${validTypes.join(', ')}`);
515
+ }
516
+
517
+ // Get current widgets
518
+ const currentWidgets = await this.widgetsList();
519
+
520
+ if (gameId) {
521
+ // Remove specific game from widget
522
+ const targetWidget = currentWidgets.widgets.find(w => w.data.type === type);
523
+ if (targetWidget) {
524
+ targetWidget.data.games = targetWidget.data.games.filter(g => g.game_id !== gameId);
525
+ }
526
+ } else {
527
+ // Remove entire widget
528
+ currentWidgets.widgets = currentWidgets.widgets.filter(w => w.data.type !== type);
529
+ }
530
+
531
+ // Update widgets via API
532
+ return this.client.api.users['@me'].profile.patch({
533
+ data: { widgets: currentWidgets.widgets }
534
+ });
535
+ }
536
+
537
+ /**
538
+ * Get the list of all widgets for the user
539
+ * @returns {Promise<Object>} Object containing widgets array
540
+ */
541
+ async widgetsList() {
542
+ try {
543
+ const data = await this.client.api.users['@me'].profile.get();
544
+ return data.widgets ? { widgets: data.widgets } : { widgets: [] };
545
+ } catch (error) {
546
+ // If profile endpoint doesn't exist or fails, return empty widgets
547
+ return { widgets: [] };
548
+ }
549
+ }
550
+
551
+ /**
552
+ * Set display name style with font, effect, and colors
553
+ * @param {string|number} fontName Font name or ID
554
+ * @param {string|number} effectName Effect name or ID
555
+ * @param {number|string} color1 Primary color (hex or decimal)
556
+ * @param {number|string} [color2] Secondary color for gradient effects (hex or decimal)
557
+ * @returns {Promise<ClientUser>}
558
+ * @example
559
+ * // Set Sans font with gradient effect
560
+ * client.user.setNameStyle('Sans', 'Gradient', 7183099, 6082490);
561
+ * // Set Tempo font with solid effect
562
+ * client.user.setNameStyle('Tempo', 'Solid', 7183099);
563
+ * // Using IDs directly
564
+ * client.user.setNameStyle(11, 2, 7183099, 6082490);
565
+ */
566
+ async setNameStyle(fontName, effectName, color1, color2 = null) {
567
+ // Font name/ID mapping
568
+ const fontMap = {
569
+ 'Sans': 11,
570
+ 'Tempo': 12,
571
+ 'Sakura': 3,
572
+ 'JellyBean': 4,
573
+ 'Modern': 6,
574
+ 'Medieval': 7,
575
+ '8Bit': 8,
576
+ 'Vampire': 10
577
+ };
578
+
579
+ // Effect name/ID mapping
580
+ const effectMap = {
581
+ 'Solid': 1,
582
+ 'Gradient': 2,
583
+ 'Neon': 3,
584
+ 'Toon': 4,
585
+ 'Pop': 5
586
+ };
587
+
588
+ // Resolve font ID
589
+ let fontId = typeof fontName === 'string' ? fontMap[fontName] : fontName;
590
+ if (!fontId) {
591
+ throw new TypeError(`Invalid font name. Must be one of: ${Object.keys(fontMap).join(', ')} or a valid font ID`);
592
+ }
593
+
594
+ // Resolve effect ID
595
+ let effectId = typeof effectName === 'string' ? effectMap[effectName] : effectName;
596
+ if (!effectId) {
597
+ throw new TypeError(`Invalid effect name. Must be one of: ${Object.keys(effectMap).join(', ')} or a valid effect ID`);
598
+ }
599
+
600
+ // Resolve colors
601
+ const resolveColor = (color) => {
602
+ if (typeof color === 'string') {
603
+ // Handle hex colors
604
+ if (color.startsWith('#')) {
605
+ return parseInt(color.slice(1), 16);
606
+ }
607
+ return parseInt(color, 16);
608
+ }
609
+ return color;
610
+ };
611
+
612
+ const primaryColor = resolveColor(color1);
613
+ const colors = [primaryColor];
614
+
615
+ if (color2 !== null) {
616
+ const secondaryColor = resolveColor(color2);
617
+ colors.push(secondaryColor);
618
+ }
619
+
620
+ // Build the data object
621
+ const data = {
622
+ display_name_font_id: fontId,
623
+ display_name_effect_id: effectId,
624
+ display_name_colors: colors
625
+ };
626
+
627
+ // Send PATCH request to Discord API
628
+ await this.client.api.users('@me').patch({ data });
629
+ return this;
630
+ }
631
+
632
+ /**
633
+ * Set the TAG of a guild.
634
+ * @param {GuildIDResolve} guild The guild with the tag
635
+ * @returns {Promise<ClientUser>}
636
+ */
637
+ setClan(guild) {
638
+ const id = this.guilds.resolveId(guild);
639
+ if (!id) throw new TypeError('INVALID_TYPE', 'guild', 'GuildResolvable');
640
+
641
+ return this.client.api.users['@me'].clan.put({ data: { identity_guild_id: id, identity_enabled: true } });
642
+ }
643
+
644
+ /**
645
+ * Remove the TAG from your profile
646
+ * @returns {Promise<ClientUser>}
647
+ */
648
+ deleteClan() {
649
+ return this.client.api.users['@me'].clan.put({ data: { identity_guild_id: null, identity_enabled: false } });
650
+ }
651
+ }
652
+
653
+ module.exports = ClientUser;