From 76b76a27cc331dddb6882698e22a28aef8e465b9 Mon Sep 17 00:00:00 2001 From: Snowflake107 Date: Thu, 13 May 2021 12:09:28 +0545 Subject: [PATCH] cache youtube links for spotify --- src/Player.ts | 28 ++++++++++++++++------------ src/Structures/Track.ts | 2 +- 2 files changed, 17 insertions(+), 13 deletions(-) diff --git a/src/Player.ts b/src/Player.ts index 4f9444b..29e4d87 100644 --- a/src/Player.ts +++ b/src/Player.ts @@ -1279,17 +1279,16 @@ export class Player extends EventEmitter { } let newStream: any; - let clonedTrack = queue.playing; // modify spotify - if (clonedTrack.raw.source === 'spotify') { + if (queue.playing.raw.source === 'spotify' && !(queue.playing as any).backupLink) { const searchQueryString = this.options.disableArtistSearch - ? clonedTrack.title - : `${clonedTrack.title}${' - ' + clonedTrack.author}`; + ? queue.playing.title + : `${queue.playing.title}${' - ' + queue.playing.author}`; const yteqv = await Util.ytSearch(searchQueryString, { player: this, limit: 1, - user: clonedTrack.requestedBy + user: queue.playing.requestedBy }).catch(() => {}); if (!yteqv || !yteqv.length) @@ -1301,13 +1300,18 @@ export class Player extends EventEmitter { new PlayerError('Could not find alternative track on youtube!', 'SpotifyTrackError') ); - clonedTrack = yteqv[0]; + Object.defineProperty(queue.playing, 'backupLink', { + value: yteqv[0].url, + writable: true, + enumerable: false, + configurable: true + }); } - if (clonedTrack.raw.source === 'youtube') { - newStream = ytdl(clonedTrack.url, { + if (queue.playing.raw.source === 'youtube' || queue.playing.raw.source === 'spotify') { + newStream = ytdl((queue.playing as any).backupLink ?? queue.playing.url, { opusEncoded: true, - encoderArgs: clonedTrack.raw.live ? [] : encoderArgs, + encoderArgs: queue.playing.raw.live ? [] : encoderArgs, seek: seekTime / 1000, // tslint:disable-next-line:no-bitwise highWaterMark: 1 << 25, @@ -1315,9 +1319,9 @@ export class Player extends EventEmitter { }); } else { newStream = ytdl.arbitraryStream( - clonedTrack.raw.source === 'soundcloud' - ? await clonedTrack.raw.engine.downloadProgressive() - : clonedTrack.raw.engine, + queue.playing.raw.source === 'soundcloud' + ? await queue.playing.raw.engine.downloadProgressive() + : queue.playing.raw.engine, { opusEncoded: true, encoderArgs, diff --git a/src/Structures/Track.ts b/src/Structures/Track.ts index c92c057..e24b791 100644 --- a/src/Structures/Track.ts +++ b/src/Structures/Track.ts @@ -133,7 +133,7 @@ export class Track { .map((m, i) => parseInt(m) * times(60, i)) .reduce((a, c) => a + c, 0); } - + /** * Returns source of this track * @type {TrackSource}