djs-selfbot-v13 3.1.7 → 3.1.8

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 (149) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +18 -45
  3. package/package.json +8 -37
  4. package/src/client/BaseClient.js +2 -3
  5. package/src/client/Client.js +187 -539
  6. package/src/client/actions/Action.js +18 -13
  7. package/src/client/actions/ActionsManager.js +7 -1
  8. package/src/client/actions/AutoModerationActionExecution.js +1 -0
  9. package/src/client/actions/AutoModerationRuleCreate.js +1 -0
  10. package/src/client/actions/AutoModerationRuleDelete.js +1 -0
  11. package/src/client/actions/AutoModerationRuleUpdate.js +1 -0
  12. package/src/client/actions/MessageCreate.js +0 -4
  13. package/src/client/actions/PresenceUpdate.js +17 -16
  14. package/src/client/websocket/WebSocketManager.js +11 -31
  15. package/src/client/websocket/WebSocketShard.js +39 -38
  16. package/src/client/websocket/handlers/CALL_CREATE.js +3 -3
  17. package/src/client/websocket/handlers/CALL_DELETE.js +2 -2
  18. package/src/client/websocket/handlers/CALL_UPDATE.js +2 -2
  19. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_ADD.js +16 -13
  20. package/src/client/websocket/handlers/CHANNEL_RECIPIENT_REMOVE.js +11 -11
  21. package/src/client/websocket/handlers/GUILD_CREATE.js +7 -0
  22. package/src/client/websocket/handlers/INTERACTION_MODAL_CREATE.js +1 -0
  23. package/src/client/websocket/handlers/READY.js +47 -137
  24. package/src/client/websocket/handlers/RELATIONSHIP_ADD.js +7 -5
  25. package/src/client/websocket/handlers/RELATIONSHIP_REMOVE.js +6 -4
  26. package/src/client/websocket/handlers/RELATIONSHIP_UPDATE.js +32 -9
  27. package/src/client/websocket/handlers/USER_GUILD_SETTINGS_UPDATE.js +2 -8
  28. package/src/client/websocket/handlers/USER_NOTE_UPDATE.js +1 -1
  29. package/src/client/websocket/handlers/USER_REQUIRED_ACTION_UPDATE.js +78 -0
  30. package/src/client/websocket/handlers/USER_SETTINGS_UPDATE.js +1 -5
  31. package/src/client/websocket/handlers/VOICE_CHANNEL_STATUS_UPDATE.js +12 -0
  32. package/src/client/websocket/handlers/index.js +15 -20
  33. package/src/errors/Messages.js +24 -69
  34. package/src/index.js +12 -43
  35. package/src/managers/ApplicationCommandManager.js +9 -12
  36. package/src/managers/ApplicationCommandPermissionsManager.js +3 -11
  37. package/src/managers/ChannelManager.js +3 -4
  38. package/src/managers/ClientUserSettingManager.js +161 -279
  39. package/src/managers/GuildBanManager.js +1 -1
  40. package/src/managers/GuildChannelManager.js +2 -0
  41. package/src/managers/GuildForumThreadManager.js +22 -28
  42. package/src/managers/GuildMemberManager.js +40 -216
  43. package/src/managers/GuildSettingManager.js +22 -15
  44. package/src/managers/MessageManager.js +42 -44
  45. package/src/managers/PermissionOverwriteManager.js +1 -1
  46. package/src/managers/ReactionUserManager.js +5 -5
  47. package/src/managers/RelationshipManager.js +81 -74
  48. package/src/managers/ThreadManager.js +12 -45
  49. package/src/managers/ThreadMemberManager.js +1 -1
  50. package/src/managers/UserManager.js +6 -10
  51. package/src/managers/UserNoteManager.js +53 -0
  52. package/src/rest/APIRequest.js +42 -20
  53. package/src/rest/DiscordAPIError.js +17 -16
  54. package/src/rest/RESTManager.js +1 -21
  55. package/src/rest/RequestHandler.js +35 -21
  56. package/src/structures/ApplicationCommand.js +19 -456
  57. package/src/structures/ApplicationRoleConnectionMetadata.js +3 -0
  58. package/src/structures/AutoModerationRule.js +5 -5
  59. package/src/structures/AutocompleteInteraction.js +1 -0
  60. package/src/structures/BaseGuildTextChannel.js +10 -12
  61. package/src/structures/BaseGuildVoiceChannel.js +16 -18
  62. package/src/structures/{Call.js → CallState.js} +17 -12
  63. package/src/structures/CategoryChannel.js +2 -0
  64. package/src/structures/Channel.js +2 -3
  65. package/src/structures/ClientPresence.js +12 -8
  66. package/src/structures/ClientUser.js +117 -336
  67. package/src/structures/ContextMenuInteraction.js +1 -1
  68. package/src/structures/DMChannel.js +29 -92
  69. package/src/structures/ForumChannel.js +0 -10
  70. package/src/structures/GroupDMChannel.js +387 -0
  71. package/src/structures/Guild.js +135 -271
  72. package/src/structures/GuildAuditLogs.js +0 -5
  73. package/src/structures/GuildChannel.js +16 -2
  74. package/src/structures/GuildMember.js +27 -145
  75. package/src/structures/Interaction.js +1 -62
  76. package/src/structures/Invite.js +35 -52
  77. package/src/structures/Message.js +228 -202
  78. package/src/structures/MessageAttachment.js +11 -0
  79. package/src/structures/MessageButton.js +1 -67
  80. package/src/structures/MessageEmbed.js +1 -1
  81. package/src/structures/MessageMentions.js +3 -2
  82. package/src/structures/MessagePayload.js +4 -46
  83. package/src/structures/MessageReaction.js +1 -1
  84. package/src/structures/MessageSelectMenu.js +1 -252
  85. package/src/structures/Modal.js +75 -180
  86. package/src/structures/Presence.js +2 -2
  87. package/src/structures/RichPresence.js +14 -34
  88. package/src/structures/Role.js +18 -2
  89. package/src/structures/SelectMenuInteraction.js +2 -151
  90. package/src/structures/Team.js +0 -49
  91. package/src/structures/TextInputComponent.js +0 -70
  92. package/src/structures/ThreadChannel.js +0 -19
  93. package/src/structures/User.js +117 -345
  94. package/src/structures/UserContextMenuInteraction.js +2 -2
  95. package/src/structures/VoiceState.js +74 -39
  96. package/src/structures/WebEmbed.js +38 -52
  97. package/src/structures/Webhook.js +17 -11
  98. package/src/structures/interfaces/Application.js +146 -23
  99. package/src/structures/interfaces/TextBasedChannel.js +411 -256
  100. package/src/util/ApplicationFlags.js +1 -1
  101. package/src/util/AttachmentFlags.js +38 -0
  102. package/src/util/Constants.js +106 -284
  103. package/src/util/Formatters.js +16 -2
  104. package/src/util/InviteFlags.js +29 -0
  105. package/src/util/LimitedCollection.js +1 -1
  106. package/src/util/Options.js +48 -68
  107. package/src/util/Permissions.js +5 -0
  108. package/src/util/PurchasedFlags.js +2 -0
  109. package/src/util/RemoteAuth.js +221 -356
  110. package/src/util/RoleFlags.js +37 -0
  111. package/src/util/Sweepers.js +1 -1
  112. package/src/util/Util.js +76 -36
  113. package/typings/enums.d.ts +18 -73
  114. package/typings/index.d.ts +873 -1225
  115. package/typings/rawDataTypes.d.ts +68 -9
  116. package/src/client/actions/InteractionCreate.js +0 -115
  117. package/src/client/websocket/handlers/APPLICATION_COMMAND_AUTOCOMPLETE_RESPONSE.js +0 -23
  118. package/src/client/websocket/handlers/GUILD_APPLICATION_COMMANDS_UPDATE.js +0 -11
  119. package/src/client/websocket/handlers/GUILD_MEMBER_LIST_UPDATE.js +0 -55
  120. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUNDS_UPDATE.js +0 -0
  121. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_CREATE.js +0 -0
  122. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_DELETE.js +0 -0
  123. package/src/client/websocket/handlers/GUILD_SOUNDBOARD_SOUND_UPDATE.js +0 -0
  124. package/src/client/websocket/handlers/INTERACTION_CREATE.js +0 -16
  125. package/src/client/websocket/handlers/INTERACTION_FAILURE.js +0 -18
  126. package/src/client/websocket/handlers/INTERACTION_SUCCESS.js +0 -30
  127. package/src/client/websocket/handlers/MESSAGE_ACK.js +0 -16
  128. package/src/client/websocket/handlers/SOUNDBOARD_SOUNDS.js +0 -0
  129. package/src/client/websocket/handlers/VOICE_CHANNEL_EFFECT_SEND.js +0 -0
  130. package/src/managers/DeveloperPortalManager.js +0 -104
  131. package/src/managers/GuildApplicationCommandManager.js +0 -28
  132. package/src/managers/GuildFolderManager.js +0 -24
  133. package/src/managers/SessionManager.js +0 -57
  134. package/src/rest/CaptchaSolver.js +0 -132
  135. package/src/structures/ClientApplication.js +0 -204
  136. package/src/structures/DeveloperPortalApplication.js +0 -520
  137. package/src/structures/GuildFolder.js +0 -75
  138. package/src/structures/InteractionResponse.js +0 -114
  139. package/src/structures/PartialGroupDMChannel.js +0 -433
  140. package/src/structures/Session.js +0 -81
  141. package/src/util/Voice.js +0 -1456
  142. package/src/util/arRPC/index.js +0 -229
  143. package/src/util/arRPC/process/detectable.json +0 -1
  144. package/src/util/arRPC/process/index.js +0 -102
  145. package/src/util/arRPC/process/native/index.js +0 -5
  146. package/src/util/arRPC/process/native/linux.js +0 -37
  147. package/src/util/arRPC/process/native/win32.js +0 -25
  148. package/src/util/arRPC/transports/ipc.js +0 -281
  149. package/src/util/arRPC/transports/websocket.js +0 -128
@@ -1,12 +1,10 @@
1
1
  'use strict';
2
2
 
3
3
  const { Collection } = require('@discordjs/collection');
4
- const { joinVoiceChannel, entersState, VoiceConnectionStatus } = require('@discordjs/voice');
5
4
  const { Channel } = require('./Channel');
6
5
  const TextBasedChannel = require('./interfaces/TextBasedChannel');
7
- const InteractionManager = require('../managers/InteractionManager');
8
6
  const MessageManager = require('../managers/MessageManager');
9
- const { Status, Opcodes } = require('../util/Constants');
7
+ const { Opcodes, Status } = require('../util/Constants');
10
8
 
11
9
  /**
12
10
  * Represents a direct message channel between two users.
@@ -25,12 +23,6 @@ class DMChannel extends Channel {
25
23
  * @type {MessageManager}
26
24
  */
27
25
  this.messages = new MessageManager(this);
28
-
29
- /**
30
- * A manager of the interactions sent to this channel
31
- * @type {InteractionManager}
32
- */
33
- this.interactions = new InteractionManager(this);
34
26
  }
35
27
 
36
28
  _patch(data) {
@@ -65,7 +57,7 @@ class DMChannel extends Channel {
65
57
  if ('is_message_request' in data) {
66
58
  /**
67
59
  * Whether the channel is a message request
68
- * @type {boolean}
60
+ * @type {?boolean}
69
61
  */
70
62
  this.messageRequest = data.is_message_request;
71
63
  }
@@ -138,69 +130,6 @@ class DMChannel extends Channel {
138
130
  return this.recipient.toString();
139
131
  }
140
132
 
141
- // These are here only for documentation purposes - they are implemented by TextBasedChannel
142
- /* eslint-disable no-empty-function */
143
- get lastMessage() {}
144
- get lastPinAt() {}
145
- send() {}
146
- sendTyping() {}
147
- createMessageCollector() {}
148
- awaitMessages() {}
149
- createMessageComponentCollector() {}
150
- awaitMessageComponent() {}
151
- sendSlash() {}
152
- searchInteraction() {}
153
- // Doesn't work on DM channels; bulkDelete() {}
154
- // Doesn't work on DM channels; setRateLimitPerUser() {}
155
- // Doesn't work on DM channels; setNSFW() {}
156
- // Testing feature: Call
157
- // URL: https://discord.com/api/v9/channels/DMchannelId/call/ring
158
- /**
159
- * Call this DMChannel. Return discordjs/voice VoiceConnection
160
- * @param {CallOptions} options Options for the call
161
- * @returns {Promise<VoiceConnection>}
162
- */
163
- call(options = {}) {
164
- options = Object.assign(
165
- {
166
- ring: true,
167
- },
168
- options || {},
169
- );
170
- return new Promise((resolve, reject) => {
171
- if (!this.client.options.patchVoice) {
172
- reject(
173
- new Error(
174
- 'VOICE_NOT_PATCHED',
175
- 'Enable voice patching in client options\nhttps://discordjs-self-v13.netlify.app/#/docs/docs/main/typedef/ClientOptions',
176
- ),
177
- );
178
- } else {
179
- if (options.ring) {
180
- this.client.api.channels(this.id).call.ring.post({
181
- data: {
182
- recipients: null,
183
- },
184
- });
185
- }
186
- const connection = joinVoiceChannel({
187
- channelId: this.id,
188
- guildId: null,
189
- adapterCreator: this.voiceAdapterCreator,
190
- selfDeaf: options.selfDeaf ?? false,
191
- selfMute: options.selfMute ?? false,
192
- });
193
- entersState(connection, VoiceConnectionStatus.Ready, 30000)
194
- .then(connection => {
195
- resolve(connection);
196
- })
197
- .catch(err => {
198
- connection.destroy();
199
- reject(err);
200
- });
201
- }
202
- });
203
- }
204
133
  /**
205
134
  * Sync VoiceState of this DMChannel.
206
135
  * @returns {undefined}
@@ -213,6 +142,19 @@ class DMChannel extends Channel {
213
142
  },
214
143
  });
215
144
  }
145
+
146
+ /**
147
+ * Ring the user's phone / PC (call)
148
+ * @returns {Promise<void>}
149
+ */
150
+ ring() {
151
+ return this.client.api.channels(this.id).call.ring.post({
152
+ data: {
153
+ recipients: null,
154
+ },
155
+ });
156
+ }
157
+
216
158
  /**
217
159
  * The user in this voice-based channel
218
160
  * @type {Collection<Snowflake, User>}
@@ -227,18 +169,7 @@ class DMChannel extends Channel {
227
169
  }
228
170
  return coll;
229
171
  }
230
- /**
231
- * Get connection to current call
232
- * @type {?VoiceConnection}
233
- * @readonly
234
- */
235
- get voiceConnection() {
236
- const check = this.client.callVoice?.joinConfig?.channelId == this.id;
237
- if (check) {
238
- return this.client.callVoice;
239
- }
240
- return null;
241
- }
172
+
242
173
  /**
243
174
  * Get current shard
244
175
  * @type {WebSocketShard}
@@ -247,6 +178,7 @@ class DMChannel extends Channel {
247
178
  get shard() {
248
179
  return this.client.ws.shards.first();
249
180
  }
181
+
250
182
  /**
251
183
  * The voice state adapter for this client that can be used with @discordjs/voice to play audio in DM / Group DM channels.
252
184
  * @type {?Function}
@@ -267,14 +199,19 @@ class DMChannel extends Channel {
267
199
  };
268
200
  };
269
201
  }
202
+
203
+ // These are here only for documentation purposes - they are implemented by TextBasedChannel
204
+ /* eslint-disable no-empty-function */
205
+ get lastMessage() {}
206
+ get lastPinAt() {}
207
+ send() {}
208
+ sendTyping() {}
209
+ createMessageCollector() {}
210
+ awaitMessages() {}
211
+ // Doesn't work on DM channels; setRateLimitPerUser() {}
212
+ // Doesn't work on DM channels; setNSFW() {}
270
213
  }
271
214
 
272
- TextBasedChannel.applyToClass(DMChannel, true, [
273
- 'bulkDelete',
274
- 'fetchWebhooks',
275
- 'createWebhook',
276
- 'setRateLimitPerUser',
277
- 'setNSFW',
278
- ]);
215
+ TextBasedChannel.applyToClass(DMChannel, true, ['fetchWebhooks', 'createWebhook', 'setRateLimitPerUser', 'setNSFW']);
279
216
 
280
217
  module.exports = DMChannel;
@@ -3,7 +3,6 @@
3
3
  const GuildChannel = require('./GuildChannel');
4
4
  const TextBasedChannel = require('./interfaces/TextBasedChannel');
5
5
  const GuildForumThreadManager = require('../managers/GuildForumThreadManager');
6
- const InteractionManager = require('../managers/InteractionManager');
7
6
  const { SortOrderTypes, ForumLayoutTypes } = require('../util/Constants');
8
7
  const { transformAPIGuildForumTag, transformAPIGuildDefaultReaction } = require('../util/Util');
9
8
 
@@ -46,12 +45,6 @@ class ForumChannel extends GuildChannel {
46
45
  constructor(guild, data, client) {
47
46
  super(guild, data, client, false);
48
47
 
49
- /**
50
- * A manager of the interactions sent to this channel
51
- * @type {InteractionManager}
52
- */
53
- this.interactions = new InteractionManager(this);
54
-
55
48
  /**
56
49
  * A manager of the threads belonging to this channel
57
50
  * @type {GuildForumThreadManager}
@@ -260,12 +253,9 @@ TextBasedChannel.applyToClass(ForumChannel, true, [
260
253
  'send',
261
254
  'lastMessage',
262
255
  'lastPinAt',
263
- 'bulkDelete',
264
256
  'sendTyping',
265
257
  'createMessageCollector',
266
258
  'awaitMessages',
267
- 'createMessageComponentCollector',
268
- 'awaitMessageComponent',
269
259
  ]);
270
260
 
271
261
  module.exports = ForumChannel;
@@ -0,0 +1,387 @@
1
+ 'use strict';
2
+
3
+ const { Collection } = require('@discordjs/collection');
4
+ const { Channel } = require('./Channel');
5
+ const Invite = require('./Invite');
6
+ const TextBasedChannel = require('./interfaces/TextBasedChannel');
7
+ const MessageManager = require('../managers/MessageManager');
8
+ const { Status, Opcodes } = require('../util/Constants');
9
+ const DataResolver = require('../util/DataResolver');
10
+
11
+ /**
12
+ * Represents a Group DM Channel on Discord.
13
+ * @extends {Channel}
14
+ * @implements {TextBasedChannel}
15
+ */
16
+ class GroupDMChannel extends Channel {
17
+ constructor(client, data) {
18
+ super(client, data);
19
+ // Override the channel type so partials have a known type
20
+ this.type = 'GROUP_DM';
21
+
22
+ /**
23
+ * A manager of the messages belonging to this channel
24
+ * @type {MessageManager}
25
+ */
26
+ this.messages = new MessageManager(this);
27
+ }
28
+
29
+ _patch(data) {
30
+ super._patch(data);
31
+
32
+ if ('recipients' in data && Array.isArray(data.recipients)) {
33
+ this._recipients = data.recipients;
34
+ data.recipients.forEach(u => this.client.users._add(u));
35
+ } else {
36
+ this._recipients = [];
37
+ }
38
+
39
+ if ('last_message_id' in data) {
40
+ /**
41
+ * The channel's last message id, if one was sent
42
+ * @type {?Snowflake}
43
+ */
44
+ this.lastMessageId = data.last_message_id;
45
+ }
46
+
47
+ if ('last_pin_timestamp' in data) {
48
+ /**
49
+ * The timestamp when the last pinned message was pinned, if there was one
50
+ * @type {?number}
51
+ */
52
+ this.lastPinTimestamp = new Date(data.last_pin_timestamp).getTime();
53
+ } else {
54
+ this.lastPinTimestamp ??= null;
55
+ }
56
+
57
+ if ('owner_id' in data) {
58
+ /**
59
+ * Owner ID
60
+ * @type {Snowflake}
61
+ */
62
+ this.ownerId = data.owner_id;
63
+ }
64
+
65
+ if ('name' in data) {
66
+ /**
67
+ * The name of this Group DM Channel
68
+ * @type {?string}
69
+ */
70
+ this.name = data.name;
71
+ }
72
+
73
+ if ('icon' in data) {
74
+ /**
75
+ * The hash of the channel icon
76
+ * @type {?string}
77
+ */
78
+ this.icon = data.icon;
79
+ }
80
+ }
81
+
82
+ /**
83
+ * The URL to this channel's icon.
84
+ * @param {StaticImageURLOptions} [options={}] Options for the Image URL
85
+ * @returns {?string}
86
+ */
87
+ iconURL({ format, size } = {}) {
88
+ return this.icon && this.client.rest.cdn.GDMIcon(this.id, this.icon, format, size);
89
+ }
90
+
91
+ /**
92
+ * The recipients of this Group DM Channel.
93
+ * @type {Collection<Snowflake, User>}
94
+ * @readonly
95
+ */
96
+ get recipients() {
97
+ const collect = new Collection();
98
+ this._recipients.map(recipient => collect.set(recipient.id, this.client.users.cache.get(recipient.id)));
99
+ collect.set(this.client.user.id, this.client.user);
100
+ return collect;
101
+ }
102
+
103
+ /**
104
+ * The owner of this Group DM Channel
105
+ * @type {?User}
106
+ * @readonly
107
+ */
108
+ get owner() {
109
+ return this.client.users.cache.get(this.ownerId);
110
+ }
111
+
112
+ /**
113
+ * Whether this DMChannel is a partial
114
+ * @type {boolean}
115
+ * @readonly
116
+ */
117
+ get partial() {
118
+ return typeof this.lastMessageId === 'undefined';
119
+ }
120
+
121
+ /**
122
+ * Leave this Group DM Channel.
123
+ * @param {?boolean} slient Leave without notifying other members
124
+ * @returns {Promise<GroupDMChannel>}
125
+ * @example
126
+ * // Delete the channel
127
+ * channel.delete()
128
+ * .then(console.log)
129
+ * .catch(console.error);
130
+ */
131
+ async delete(slient = false) {
132
+ if (typeof slient === 'boolean' && slient) {
133
+ await this.client.api.channels[this.id].delete({
134
+ query: {
135
+ silent: true,
136
+ },
137
+ });
138
+ } else {
139
+ await this.client.api.channels[this.id].delete();
140
+ }
141
+ return this;
142
+ }
143
+
144
+ /**
145
+ * When concatenated with a string, this automatically returns the recipient's mention instead of the
146
+ * GroupDMChannel object.
147
+ * @returns {string}
148
+ * @example
149
+ * // Logs: Hello from Group Test!
150
+ * console.log(`Hello from ${channel}!`);
151
+ */
152
+ toString() {
153
+ return (
154
+ this.name ??
155
+ this._recipients
156
+ .filter(user => user.id !== this.client.user.id)
157
+ .map(user => user.username)
158
+ .join(', ')
159
+ );
160
+ }
161
+
162
+ toJSON() {
163
+ const json = super.toJSON({
164
+ createdTimestamp: true,
165
+ });
166
+ json.iconURL = this.iconURL();
167
+ return json;
168
+ }
169
+
170
+ /**
171
+ * The data for editing a channe;.
172
+ * @typedef {Object} GroupDMChannelEditData
173
+ * @property {string} [name] The name of the channel
174
+ * @property {?(BufferResolvable|Base64Resolvable)} [icon] The icon of the channel
175
+ * @property {GuildMemberResolvable} [owner] The owner of the channel
176
+ */
177
+
178
+ /**
179
+ * Edit channel data
180
+ * @param {GroupDMChannelEditData} data Data
181
+ * @returns {Promise<GroupDMChannel>}
182
+ * @example
183
+ * // Set the channel name
184
+ * channel.edit({
185
+ * name: 'Group Test',
186
+ * })
187
+ * .then(updated => console.log(`New channel name ${updated}`))
188
+ * .catch(console.error);
189
+ */
190
+ async edit(data) {
191
+ const _data = {};
192
+ if ('name' in data) _data.name = data.name?.trim() ?? null;
193
+ if (typeof data.icon !== 'undefined') {
194
+ _data.icon = await DataResolver.resolveImage(data.icon);
195
+ }
196
+ if ('owner' in data) {
197
+ _data.owner = data.owner;
198
+ }
199
+ const newData = await this.client.api.channels[this.id].patch({
200
+ data: _data,
201
+ });
202
+
203
+ return this.client.actions.ChannelUpdate.handle(newData).updated;
204
+ }
205
+
206
+ /**
207
+ * Renames this Group DM Channel.
208
+ * @param {?string} name Name of the channel
209
+ * @returns {Promise<GroupDMChannel>}
210
+ */
211
+ setName(name) {
212
+ return this.edit({ name });
213
+ }
214
+
215
+ /**
216
+ * Sets the icon of this Group DM Channel.
217
+ * @param {?(Base64Resolvable|BufferResolvable)} icon Icon of the channel
218
+ * @returns {Promise<GroupDMChannel>}
219
+ */
220
+ setIcon(icon) {
221
+ return this.edit({ icon });
222
+ }
223
+
224
+ /**
225
+ * Changes the owner of this Group DM Channel.
226
+ * @param {UserResolvable} user User to transfer ownership to
227
+ * @returns {Promise<GroupDMChannel>}
228
+ */
229
+ setOwner(user) {
230
+ const id = this.client.users.resolveId(user);
231
+ if (this.ownerId === id) {
232
+ return Promise.resolve(this);
233
+ }
234
+ return this.edit({ owner: id });
235
+ }
236
+
237
+ /**
238
+ * Adds a user to this Group DM Channel.
239
+ * @param {UserResolvable} user User to add to the group
240
+ * @returns {Promise<GroupDMChannel>}
241
+ */
242
+ async addUser(user) {
243
+ user = this.client.users.resolveId(user);
244
+ await this.client.api.channels[this.id].recipients[user].put();
245
+ return this;
246
+ }
247
+
248
+ /**
249
+ * Removes a user from this Group DM Channel.
250
+ * @param {UserResolvable} user User to remove from the group
251
+ * @returns {Promise<GroupDMChannel>}
252
+ */
253
+ async removeUser(user) {
254
+ user = this.client.users.resolveId(user);
255
+ await this.client.api.channels[this.id].recipients[user].delete();
256
+ return this;
257
+ }
258
+
259
+ /**
260
+ * Gets the invite for this Group DM Channel.
261
+ * @returns {Promise<Invite>}
262
+ */
263
+ async getInvite() {
264
+ const inviteCode = await this.client.api.channels(this.id).invites.post({
265
+ data: {
266
+ max_age: 86400,
267
+ },
268
+ });
269
+ return new Invite(this.client, inviteCode);
270
+ }
271
+
272
+ /**
273
+ * Get all the invites for this Group DM Channel.
274
+ * @returns {Promise<Collection<string, Invite>>}
275
+ */
276
+ async fetchAllInvite() {
277
+ const invites = await this.client.api.channels(this.id).invites.get();
278
+ return new Collection(invites.map(invite => [invite.code, new Invite(this.client, invite)]));
279
+ }
280
+
281
+ /**
282
+ * Delete invites from this Group DM Channel.
283
+ * @param {InviteResolvable} invite Invite to add to the channel
284
+ * @returns {Promise<GroupDMChannel>}
285
+ */
286
+ async removeInvite(invite) {
287
+ // Resolve
288
+ let code = invite?.code;
289
+ if (!code && URL.canParse(invite)) code = new URL(invite).pathname.slice(1);
290
+ else code = invite;
291
+ await this.client.api.channels(this.id).invites[invite].delete();
292
+ return this;
293
+ }
294
+
295
+ /**
296
+ * Ring the user's phone / PC (call)
297
+ * @param {UserResolvable[]} [recipients] Array of recipients
298
+ * @returns {Promise<any>}
299
+ */
300
+ ring(recipients) {
301
+ if (!recipients || !Array.isArray(recipients) || recipients.length == 0) recipients = null;
302
+ recipients = recipients.map(r => this.client.users.resolveId(r)).filter(r => r && this.recipients.get(r));
303
+ return this.client.api.channels(this.id).call.ring.post({
304
+ data: {
305
+ recipients,
306
+ },
307
+ });
308
+ }
309
+
310
+ /**
311
+ * Sync VoiceState of this Group DMChannel.
312
+ * @returns {undefined}
313
+ */
314
+ sync() {
315
+ this.client.ws.broadcast({
316
+ op: Opcodes.DM_UPDATE,
317
+ d: {
318
+ channel_id: this.id,
319
+ },
320
+ });
321
+ }
322
+
323
+ /**
324
+ * The user in this voice-based channel
325
+ * @type {Collection<Snowflake, User>}
326
+ * @readonly
327
+ */
328
+ get voiceUsers() {
329
+ const coll = new Collection();
330
+ for (const state of this.client.voiceStates.cache.values()) {
331
+ if (state.channelId === this.id && state.user) {
332
+ coll.set(state.id, state.user);
333
+ }
334
+ }
335
+ return coll;
336
+ }
337
+
338
+ /**
339
+ * Get current shard
340
+ * @type {WebSocketShard}
341
+ * @readonly
342
+ */
343
+ get shard() {
344
+ return this.client.ws.shards.first();
345
+ }
346
+
347
+ /**
348
+ * The voice state adapter for this client that can be used with @discordjs/voice to play audio in DM / Group DM channels.
349
+ * @type {?Function}
350
+ * @readonly
351
+ */
352
+ get voiceAdapterCreator() {
353
+ return methods => {
354
+ this.client.voice.adapters.set(this.id, methods);
355
+ return {
356
+ sendPayload: data => {
357
+ if (this.shard.status !== Status.READY) return false;
358
+ this.shard.send(data);
359
+ return true;
360
+ },
361
+ destroy: () => {
362
+ this.client.voice.adapters.delete(this.id);
363
+ },
364
+ };
365
+ };
366
+ }
367
+
368
+ // These are here only for documentation purposes - they are implemented by TextBasedChannel
369
+ /* eslint-disable no-empty-function */
370
+ get lastMessage() {}
371
+ get lastPinAt() {}
372
+ send() {}
373
+ sendTyping() {}
374
+ createMessageCollector() {}
375
+ awaitMessages() {}
376
+ // Doesn't work on DM channels; setRateLimitPerUser() {}
377
+ // Doesn't work on DM channels; setNSFW() {}
378
+ }
379
+
380
+ TextBasedChannel.applyToClass(GroupDMChannel, true, [
381
+ 'fetchWebhooks',
382
+ 'createWebhook',
383
+ 'setRateLimitPerUser',
384
+ 'setNSFW',
385
+ ]);
386
+
387
+ module.exports = GroupDMChannel;