From 18c9508b9f0d50c8c14d1f7b39ddd2df42fe3771 Mon Sep 17 00:00:00 2001 From: David Amorim <66310990+davidffa@users.noreply.github.com> Date: Thu, 22 Aug 2024 19:17:34 +0100 Subject: [PATCH] Remove extension from received audio packets (#2721) --- .../dv8tion/jda/internal/audio/AudioPacket.java | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/main/java/net/dv8tion/jda/internal/audio/AudioPacket.java b/src/main/java/net/dv8tion/jda/internal/audio/AudioPacket.java index df9d79b51c..5f1cf4c7ed 100644 --- a/src/main/java/net/dv8tion/jda/internal/audio/AudioPacket.java +++ b/src/main/java/net/dv8tion/jda/internal/audio/AudioPacket.java @@ -84,7 +84,16 @@ public AudioPacket(byte[] rawPacket) for (int i = 0; i < cc; i++) this.csrc[i] = buffer.getInt(); - this.extension = this.hasExtension ? buffer.getInt() : 0; + // Extract extension length as described by https://datatracker.ietf.org/doc/html/rfc3550#section-5.3.1 + if (this.hasExtension) + { + buffer.position(buffer.position() + 2); + this.extension = buffer.getShort(); + } + else + { + this.extension = 0; + } this.headerLength = buffer.position(); this.encodedAudio = buffer; @@ -145,12 +154,14 @@ public static AudioPacket decryptAudioPacket(CryptoAdapter crypto, DatagramPacke return null; byte[] decryptedPayload = crypto.decrypt(encryptedPacket.encodedAudio); + int offset = 4 * encryptedPacket.extension; + return new AudioPacket( null, encryptedPacket.seq, encryptedPacket.timestamp, encryptedPacket.ssrc, - ByteBuffer.wrap(decryptedPayload) + ByteBuffer.wrap(decryptedPayload, offset, decryptedPayload.length - offset).slice() ); }