From d24c3a3ebdb94888f49922d4cd49490971509d4a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 01:58:28 +0100 Subject: [PATCH 01/11] Permissions --- lib/Constants.js | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/lib/Constants.js b/lib/Constants.js index 29c28de1a..e15dff7c0 100644 --- a/lib/Constants.js +++ b/lib/Constants.js @@ -573,7 +573,9 @@ const Permissions = { createGuildExpressions: 1n << 43n, createEvents: 1n << 44n, useExternalSounds: 1n << 45n, - sendVoiceMessages: 1n << 46n + sendVoiceMessages: 1n << 46n, + + setVoiceChannelStatus: 1n << 48n }; Permissions.allGuild = Permissions.kickMembers | Permissions.banMembers @@ -629,7 +631,8 @@ Permissions.allVoice = Permissions.createInstantInvite | Permissions.useEmbeddedActivities | Permissions.useSoundboard | Permissions.useExternalSounds - | Permissions.sendVoiceMessages; + | Permissions.sendVoiceMessages + | Permissions.setVoiceChannelStatus; Permissions.all = Permissions.allGuild | Permissions.allText | Permissions.allVoice; module.exports.Permissions = Permissions; From 867224cc12045b8599ef23bdfefb0cb52c867e52 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 01:58:36 +0100 Subject: [PATCH 02/11] Audit log actions --- lib/Constants.js | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/lib/Constants.js b/lib/Constants.js index e15dff7c0..e36de72cc 100644 --- a/lib/Constants.js +++ b/lib/Constants.js @@ -130,7 +130,10 @@ module.exports.AuditLogActions = { ROLE_PROMPT_DELETE: 162, GUILD_HOME_FEATURE_ITEM: 171, - GUILD_HOME_REMOVE_ITEM: 172 + GUILD_HOME_REMOVE_ITEM: 172, + + VOICE_CHANNEL_STATUS_UPDATE: 192, + VOICE_CHANNEL_STATUS_DELETE: 193 }; module.exports.AutoModerationActionTypes = { From cd7a2bfc4f22900346b5536f81b0b83526a5dd12 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 01:58:59 +0100 Subject: [PATCH 03/11] GuildAuditLogEntry#status --- lib/structures/GuildAuditLogEntry.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/lib/structures/GuildAuditLogEntry.js b/lib/structures/GuildAuditLogEntry.js index 36d633fb7..65d4cca9d 100644 --- a/lib/structures/GuildAuditLogEntry.js +++ b/lib/structures/GuildAuditLogEntry.js @@ -24,6 +24,7 @@ const {AuditLogActions} = require("../Constants"); * @prop {(Message | Object)?} message The message that was (un)pinned, action types 74/75 (MESSAGE_PIN/UNPIN) only. If the channel or message is not cached, this will be an object with an `id` key. No other property is guaranteed. * @prop {String?} reason The reason for the action * @prop {(Role | Object)?} role The role described by the permission overwrite, action types 13-15 (CHANNEL\_OVERWRITE\_CREATE/UPDATE/DELETE) only. If the guild or role is not cached, this could be {id: String, name: String} + * @prop {String?} status The new voice channel status, action type 192 (VOICE\_CHANNEL\_STATUS\_UPDATE) only * @prop {(CategoryChannel | Guild | Member | Invite | Role | Object | TextChannel | VoiceChannel | NewsChannel)?} target The object of the action target * If the item or the item's guild (where relevant, not including invites) is not cached, this property will be null * If the action targets a guild, this could be a Guild object @@ -104,6 +105,9 @@ class GuildAuditLogEntry extends Base { } } } + if(data.options.status) { + this.status = data.options.status; + } } } @@ -111,7 +115,7 @@ class GuildAuditLogEntry extends Base { const guildAvailable = this.guild instanceof Guild; if(this.actionType < 10) { // Guild return this.guild; - } else if(this.actionType < 20) { // Channel + } else if(this.actionType < 20 || this.actionType === 192 || this.actionType === 193) { // Channel return this._client.getChannel(this.targetID) || null; } else if(this.actionType < 30) { // Member if(this.actionType === AuditLogActions.MEMBER_MOVE || this.actionType === AuditLogActions.MEMBER_DISCONNECT) { // MEMBER_MOVE / MEMBER_DISCONNECT From a50ad62d04eead2e399e09b9393d0bf550d51045 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 01:59:09 +0100 Subject: [PATCH 04/11] VoiceChannel#status --- lib/structures/VoiceChannel.js | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/lib/structures/VoiceChannel.js b/lib/structures/VoiceChannel.js index bf85f6223..db18ec30b 100644 --- a/lib/structures/VoiceChannel.js +++ b/lib/structures/VoiceChannel.js @@ -13,6 +13,7 @@ const PermissionOverwrite = require("./PermissionOverwrite"); * @prop {Collection} permissionOverwrites Collection of PermissionOverwrites in the channel * @prop {Number} position The position of the channel * @prop {String?} rtcRegion The RTC region ID of the channel (automatic when `null`) + * @prop {String?} status The voice channel status * @prop {Number?} userLimit The max number of users that can join the channel * @prop {Number?} videoQualityMode The camera video quality mode of the voice channel. `1` is auto, `2` is 720p * @prop {Collection} voiceMembers Collection of Members in this channel @@ -53,6 +54,9 @@ class VoiceChannel extends GuildTextableChannel { if(data.video_quality_mode !== undefined) { this.videoQualityMode = data.video_quality_mode; } + if(data.status !== undefined) { + this.status = data.status; + } } /** From 67ddecceab04f90797bb1e5bd99be6263e6ca7dd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 02:31:57 +0100 Subject: [PATCH 05/11] Temp event --- lib/gateway/Shard.js | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/lib/gateway/Shard.js b/lib/gateway/Shard.js index a6e5cf251..23f794c35 100644 --- a/lib/gateway/Shard.js +++ b/lib/gateway/Shard.js @@ -972,6 +972,28 @@ class Shard extends EventEmitter { } break; } + case "VOICE_CHANNEL_STATUS_UPDATE": { + let channel = this.client.getChannel(packet.d.id); + if(!channel) { + break; + } + const oldChannel = { + status: channel.status + }; + channel = channel.update({ + ...channel, + status: packet.d.status + }); + /** + * Fired when a voice channel status is updated + * @event Client#voiceChannelStatusUpdate + * @prop {VoiceChannel} channel The updated voice channel + * @prop {Object} oldChannel The old channel data + * @prop {String?} oldChannel.status The old voice channel status + */ + this.emit("voiceChannelStatusUpdate", channel, oldChannel); + break; + } case "TYPING_START": { let member = null; const guild = this.client.guilds.get(packet.d.guild_id); From abe5d89776467c3154682f1b5209875400d3b512 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 02:44:29 +0100 Subject: [PATCH 06/11] Set voice channel status endpoint --- lib/rest/Endpoints.js | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/rest/Endpoints.js b/lib/rest/Endpoints.js index 45dde8b97..0b78a8ca4 100644 --- a/lib/rest/Endpoints.js +++ b/lib/rest/Endpoints.js @@ -29,6 +29,7 @@ module.exports.CHANNEL_PIN = (chanID, msgID) module.exports.CHANNEL_PINS = (chanID) => `/channels/${chanID}/pins`; module.exports.CHANNEL_RECIPIENT = (groupID, userID) => `/channels/${groupID}/recipients/${userID}`; module.exports.CHANNEL_TYPING = (chanID) => `/channels/${chanID}/typing`; +module.exports.CHANNEL_VOICE_STATUS = (chanID) => `/channels/${chanID}/voice-status`; module.exports.CHANNEL_WEBHOOKS = (chanID) => `/channels/${chanID}/webhooks`; module.exports.CHANNELS = "/channels"; module.exports.CUSTOM_EMOJI_GUILD = (emojiID) => `/emojis/${emojiID}/guild`; From 8b8c9e655ff178b35abe3e23f275fe66cdced52c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 02:45:06 +0100 Subject: [PATCH 07/11] funcs to update voice channel status --- lib/Client.js | 14 ++++++++++++++ lib/structures/VoiceChannel.js | 10 ++++++++++ 2 files changed, 24 insertions(+) diff --git a/lib/Client.js b/lib/Client.js index 7d0e9e1a6..0f503782d 100644 --- a/lib/Client.js +++ b/lib/Client.js @@ -3963,6 +3963,20 @@ class Client extends EventEmitter { return this.requestHandler.request("POST", Endpoints.CHANNEL_TYPING(channelID), true); } + /** + * Set the status of a voice channel + * @arg {String} channelID The ID of the channel + * @arg {String} status The new voice channel status + * @arg {String} [reason] The reason to be displayed in audit logs + * @returns {Promise} + */ + setVoiceChannelStatus(channelID, status, reason) { + return this.requestHandler.request("PUT", Endpoints.CHANNEL_VOICE_STATUS(channelID), true, { + status, + reason + }); + } + /** * Force a guild integration to sync * @arg {String} guildID The ID of the guild diff --git a/lib/structures/VoiceChannel.js b/lib/structures/VoiceChannel.js index db18ec30b..2b6c3d93c 100644 --- a/lib/structures/VoiceChannel.js +++ b/lib/structures/VoiceChannel.js @@ -124,6 +124,16 @@ class VoiceChannel extends GuildTextableChannel { return this._client.leaveVoiceChannel.call(this._client, this.id); } + /** + * Set the status of the voice channel + * @arg {String} status The new voice channel status + * @arg {String} [reason] The reason to be displayed in audit logs + * @returns {Promise} + */ + setStatus(status, reason) { + return this._client.setVoiceChannelStatus.call(this._client, this.id, status, reason); + } + toJSON(props = []) { return super.toJSON([ "bitrate", From dacf568beb462c69c0a24e9662abf6549e29176b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Sun, 21 Apr 2024 02:45:12 +0100 Subject: [PATCH 08/11] Add to JSON --- lib/structures/VoiceChannel.js | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/structures/VoiceChannel.js b/lib/structures/VoiceChannel.js index 2b6c3d93c..85dc8428b 100644 --- a/lib/structures/VoiceChannel.js +++ b/lib/structures/VoiceChannel.js @@ -141,6 +141,7 @@ class VoiceChannel extends GuildTextableChannel { "permissionOverwrites", "position", "rtcRegion", + "status", "userLimit", "videoQualityMode", "voiceMembers", From b76c3f6a55fa0237d2990a3cb3a07f4adaec2736 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Thu, 11 Jul 2024 17:03:22 +0100 Subject: [PATCH 09/11] ts docs --- index.d.ts | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/index.d.ts b/index.d.ts index f5612eb7f..3ea29fbcd 100644 --- a/index.d.ts +++ b/index.d.ts @@ -978,6 +978,7 @@ declare namespace Eris { userUpdate: [user: User, oldUser: PartialUser | null]; voiceChannelJoin: [member: Member, channel: AnyVoiceChannel]; voiceChannelLeave: [member: Member, channel: AnyVoiceChannel]; + voiceChannelStatusUpdate: [channel: AnyVoiceChannel, oldChannel: VoiceStatus]; voiceChannelSwitch: [member: Member, newChannel: AnyVoiceChannel, oldChannel: AnyVoiceChannel]; voiceStateUpdate: [member: Member, oldState: OldVoiceState]; warn: [message: string, id?: number]; @@ -1840,6 +1841,9 @@ declare namespace Eris { requestToSpeakTimestamp?: Date | null; suppress?: boolean; } + interface VoiceStatus { + status: string; + } interface VoiceStreamCurrent { buffer: Buffer | null; bufferingTicks: number; @@ -2010,6 +2014,9 @@ declare namespace Eris { AUTO_MODERATION_RULE_UPDATE: 141; AUTO_MODERATION_RULE_DELETE: 142; AUTO_MODERATION_BLOCK_MESSAGE: 143; + + VOICE_CHANNEL_STATUS_UPDATE: 192; + VOICE_CHANNEL_STATUS_DELETE: 193; }; AutoModerationActionTypes: { BLOCK_MESSAGE: 1; @@ -2441,10 +2448,11 @@ declare namespace Eris { createEvents: 17592186044416n; useExternalSounds: 35184372088832n; sendVoiceMessages: 70368744177664n; - allGuild: 29697484783806n; + setVoiceChannelStatus: 281474976710656n; + allGuild: 311172461494462n; allText: 70904273435729n; - allVoice: 110505548056337n; - all: 140737488355327n; + allVoice: 391980524766993n; + all: 422212465065983n; }; PremiumTiers: { NONE: 0; @@ -3119,6 +3127,7 @@ declare namespace Eris { searchGuildMembers(guildID: string, query: string, limit?: number): Promise; searchGuildMessages(guildID: string, query: SearchOptions): Promise; sendChannelTyping(channelID: string): Promise; + setVoiceChannelStatus(channelID: string, status: string, reason?: string): Promise; syncGuildIntegration(guildID: string, integrationID: string): Promise; syncGuildTemplate(guildID: string, code: string): Promise; unbanGuildMember(guildID: string, userID: string, reason?: string): Promise; @@ -3471,6 +3480,7 @@ declare namespace Eris { message?: Message | Uncached; reason: string | null; role?: Role | { id: string; name: string }; + status?: string; target?: Guild | AnyGuildChannel | Member | Role | Invite | Emoji | Sticker | Message | null; targetID: string; user: User | Uncached; @@ -4254,6 +4264,7 @@ declare namespace Eris { permissionOverwrites: Collection; position: number; rtcRegion: string | null; + status?: string; type: GuildVoiceChannelTypes; userLimit: number; videoQualityMode: VideoQualityMode; @@ -4265,6 +4276,7 @@ declare namespace Eris { getInvites(): Promise[]>; join(options?: JoinVoiceChannelOptions): Promise; leave(): void; + setStatus(status: string, reason?: string): Promise; } export class VoiceConnection extends EventEmitter implements SimpleJSON { From 6d97844bec8c1361a3683a67ad330da97e332b99 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Fri, 12 Jul 2024 19:28:16 +0100 Subject: [PATCH 10/11] Fix --- lib/gateway/Shard.js | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/lib/gateway/Shard.js b/lib/gateway/Shard.js index 38ad7d840..108e75d85 100644 --- a/lib/gateway/Shard.js +++ b/lib/gateway/Shard.js @@ -973,15 +973,14 @@ class Shard extends EventEmitter { break; } case "VOICE_CHANNEL_STATUS_UPDATE": { - let channel = this.client.getChannel(packet.d.id); + const channel = this.client.getChannel(packet.d.id); if(!channel) { break; } const oldChannel = { status: channel.status }; - channel = channel.update({ - ...channel, + channel.update({ status: packet.d.status }); /** From c524851926b6448d4ead955cb34eed53869f55a8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Conor=E2=84=A2?= Date: Fri, 12 Jul 2024 19:29:30 +0100 Subject: [PATCH 11/11] Add notes --- lib/Client.js | 2 +- lib/structures/VoiceChannel.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/Client.js b/lib/Client.js index 9375035b1..25365c1d0 100644 --- a/lib/Client.js +++ b/lib/Client.js @@ -3997,7 +3997,7 @@ class Client extends EventEmitter { } /** - * Set the status of a voice channel + * Set the status of a voice channel. Note: This will not work in stage channels * @arg {String} channelID The ID of the channel * @arg {String} status The new voice channel status * @arg {String} [reason] The reason to be displayed in audit logs diff --git a/lib/structures/VoiceChannel.js b/lib/structures/VoiceChannel.js index c5d73032c..220efc77c 100644 --- a/lib/structures/VoiceChannel.js +++ b/lib/structures/VoiceChannel.js @@ -122,7 +122,7 @@ class VoiceChannel extends GuildTextableChannel { } /** - * Set the status of the voice channel + * Set the status of the voice channel. Note: This will not work in stage channels * @arg {String} status The new voice channel status * @arg {String} [reason] The reason to be displayed in audit logs * @returns {Promise}