From 08a8d0ff20e36373d6d11fafc478c19d1273e594 Mon Sep 17 00:00:00 2001 From: Androz2091 Date: Sun, 21 Jun 2020 17:17:00 +0200 Subject: [PATCH] :art: Move _playYTDLStream function --- src/Player.js | 86 ++++++++++++++++++++++++++++----------------------- 1 file changed, 47 insertions(+), 39 deletions(-) diff --git a/src/Player.js b/src/Player.js index 7e97a99..5dc3d79 100644 --- a/src/Player.js +++ b/src/Player.js @@ -69,45 +69,6 @@ class Player { client.on('voiceStateUpdate', (oldState, newState) => this._handleVoiceStateUpdate(oldState, newState)) } - _playYTDLStream (queue, updateFilter) { - return new Promise((resolve) => { - const currentStreamTime = updateFilter ? queue.voiceConnection.dispatcher.streamTime / 1000 : undefined - const encoderArgsFilters = [] - Object.keys(queue.filters).forEach((filterName) => { - if (queue.filters[filterName]) { - encoderArgsFilters.push(filters[filterName]) - } - }) - let encoderArgs - if (encoderArgsFilters.length < 1) { - encoderArgs = [] - } else { - encoderArgs = ['-af', encoderArgsFilters.join(',')] - } - const newStream = ytdl(queue.playing.url, { - filter: 'audioonly', - opusEncoded: true, - encoderArgs, - seek: currentStreamTime - }) - setTimeout(() => { - queue.voiceConnection.play(newStream, { - type: 'opus' - }) - queue.voiceConnection.dispatcher.setVolumeLogarithmic(queue.volume / 200) - // When the track starts - queue.voiceConnection.dispatcher.on('start', () => { - resolve() - }) - // When the track ends - queue.voiceConnection.dispatcher.on('finish', () => { - // Play the next track - return this._playTrack(queue.guildID, false) - }) - }, 1000) - }) - } - /** * Update the filters for the guild * @param {Discord.Snowflake} guildID @@ -462,6 +423,53 @@ class Player { } } + /** + * Play a stream in a channel + * @ignore + * @private + * @param {Queue} queue The queue to play + * @param {*} updateFilter Whether this method is called to update some ffmpeg filters + * @returns {Promise} + */ + _playYTDLStream (queue, updateFilter) { + return new Promise((resolve) => { + const currentStreamTime = updateFilter ? queue.voiceConnection.dispatcher.streamTime / 1000 : undefined + const encoderArgsFilters = [] + Object.keys(queue.filters).forEach((filterName) => { + if (queue.filters[filterName]) { + encoderArgsFilters.push(filters[filterName]) + } + }) + let encoderArgs + if (encoderArgsFilters.length < 1) { + encoderArgs = [] + } else { + encoderArgs = ['-af', encoderArgsFilters.join(',')] + } + const newStream = ytdl(queue.playing.url, { + filter: 'audioonly', + opusEncoded: true, + encoderArgs, + seek: currentStreamTime + }) + setTimeout(() => { + queue.voiceConnection.play(newStream, { + type: 'opus' + }) + queue.voiceConnection.dispatcher.setVolumeLogarithmic(queue.volume / 200) + // When the track starts + queue.voiceConnection.dispatcher.on('start', () => { + resolve() + }) + // When the track ends + queue.voiceConnection.dispatcher.on('finish', () => { + // Play the next track + return this._playTrack(queue.guildID, false) + }) + }, 1000) + }) + } + /** * Start playing a track in a guild * @ignore