|  | @@ -1,6 +1,7 @@
 | 
	
		
			
				|  |  |  import async from "async";
 | 
	
		
			
				|  |  |  import config from "config";
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +import * as rax from "retry-axios";
 | 
	
		
			
				|  |  |  import axios from "axios";
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  import CoreClass from "../core";
 | 
	
	
		
			
				|  | @@ -61,6 +62,14 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  			this.rateLimiter = new RateLimitter(config.get("apis.youtube.rateLimit"));
 | 
	
		
			
				|  |  |  			this.requestTimeout = config.get("apis.youtube.requestTimeout");
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +			this.axios = axios.create();
 | 
	
		
			
				|  |  | +			this.axios.defaults.raxConfig = {
 | 
	
		
			
				|  |  | +				instance: this.axios,
 | 
	
		
			
				|  |  | +				retry: config.get("apis.youtube.retryAmount"),
 | 
	
		
			
				|  |  | +				noResponseRetries: config.get("apis.youtube.retryAmount")
 | 
	
		
			
				|  |  | +			};
 | 
	
		
			
				|  |  | +			rax.attach(this.axios);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  			resolve();
 | 
	
		
			
				|  |  |  		});
 | 
	
		
			
				|  |  |  	}
 | 
	
	
		
			
				|  | @@ -87,8 +96,20 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  		return new Promise((resolve, reject) =>
 | 
	
		
			
				|  |  |  			YouTubeModule.rateLimiter.continue().then(() => {
 | 
	
		
			
				|  |  |  				YouTubeModule.rateLimiter.restart();
 | 
	
		
			
				|  |  | -				axios
 | 
	
		
			
				|  |  | -					.get("https://www.googleapis.com/youtube/v3/search", { params })
 | 
	
		
			
				|  |  | +				YouTubeModule.axios
 | 
	
		
			
				|  |  | +					.get("https://www.googleapis.com/youtube/v3/search", {
 | 
	
		
			
				|  |  | +						params,
 | 
	
		
			
				|  |  | +						raxConfig: {
 | 
	
		
			
				|  |  | +							onRetryAttempt: err => {
 | 
	
		
			
				|  |  | +								const cfg = rax.getConfig(err);
 | 
	
		
			
				|  |  | +								YouTubeModule.log(
 | 
	
		
			
				|  |  | +									"ERROR",
 | 
	
		
			
				|  |  | +									"SEARCH",
 | 
	
		
			
				|  |  | +									`Attempt #${cfg.currentRetryAttempt}. Error: ${err.message}`
 | 
	
		
			
				|  |  | +								);
 | 
	
		
			
				|  |  | +							}
 | 
	
		
			
				|  |  | +						}
 | 
	
		
			
				|  |  | +					})
 | 
	
		
			
				|  |  |  					.then(res => {
 | 
	
		
			
				|  |  |  						if (res.data.err) {
 | 
	
		
			
				|  |  |  							YouTubeModule.log("ERROR", "SEARCH", `${res.data.error.message}`);
 | 
	
	
		
			
				|  | @@ -124,10 +145,20 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  			YouTubeModule.rateLimiter.continue().then(() => {
 | 
	
		
			
				|  |  |  				YouTubeModule.rateLimiter.restart();
 | 
	
		
			
				|  |  | -				axios
 | 
	
		
			
				|  |  | +				YouTubeModule.axios
 | 
	
		
			
				|  |  |  					.get("https://www.googleapis.com/youtube/v3/videos", {
 | 
	
		
			
				|  |  |  						params,
 | 
	
		
			
				|  |  | -						timeout: YouTubeModule.requestTimeout
 | 
	
		
			
				|  |  | +						timeout: YouTubeModule.requestTimeout,
 | 
	
		
			
				|  |  | +						raxConfig: {
 | 
	
		
			
				|  |  | +							onRetryAttempt: err => {
 | 
	
		
			
				|  |  | +								const cfg = rax.getConfig(err);
 | 
	
		
			
				|  |  | +								YouTubeModule.log(
 | 
	
		
			
				|  |  | +									"ERROR",
 | 
	
		
			
				|  |  | +									"GET_SONG",
 | 
	
		
			
				|  |  | +									`Attempt #${cfg.currentRetryAttempt}. Error: ${err.message}`
 | 
	
		
			
				|  |  | +								);
 | 
	
		
			
				|  |  | +							}
 | 
	
		
			
				|  |  | +						}
 | 
	
		
			
				|  |  |  					})
 | 
	
		
			
				|  |  |  					.then(res => {
 | 
	
		
			
				|  |  |  						if (res.data.error) {
 | 
	
	
		
			
				|  | @@ -176,6 +207,7 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  						return resolve({ song });
 | 
	
		
			
				|  |  |  					})
 | 
	
		
			
				|  |  |  					.catch(err => {
 | 
	
		
			
				|  |  | +						// console.log(111, err, payload);
 | 
	
		
			
				|  |  |  						YouTubeModule.log("ERROR", "GET_SONG", `${err.message}`);
 | 
	
		
			
				|  |  |  						return reject(new Error("An error has occured. Please try again later."));
 | 
	
		
			
				|  |  |  					});
 | 
	
	
		
			
				|  | @@ -248,6 +280,7 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  					}
 | 
	
		
			
				|  |  |  				],
 | 
	
		
			
				|  |  |  				(err, response) => {
 | 
	
		
			
				|  |  | +					// console.log(222, err, payload);
 | 
	
		
			
				|  |  |  					if (err && err !== true) {
 | 
	
		
			
				|  |  |  						YouTubeModule.log("ERROR", "GET_PLAYLIST", "Some error has occurred.", err.message);
 | 
	
		
			
				|  |  |  						reject(new Error(err.message));
 | 
	
	
		
			
				|  | @@ -281,10 +314,20 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  			YouTubeModule.rateLimiter.continue().then(() => {
 | 
	
		
			
				|  |  |  				YouTubeModule.rateLimiter.restart();
 | 
	
		
			
				|  |  | -				axios
 | 
	
		
			
				|  |  | +				YouTubeModule.axios
 | 
	
		
			
				|  |  |  					.get("https://www.googleapis.com/youtube/v3/playlistItems", {
 | 
	
		
			
				|  |  |  						params,
 | 
	
		
			
				|  |  | -						timeout: YouTubeModule.requestTimeout
 | 
	
		
			
				|  |  | +						timeout: YouTubeModule.requestTimeout,
 | 
	
		
			
				|  |  | +						raxConfig: {
 | 
	
		
			
				|  |  | +							onRetryAttempt: err => {
 | 
	
		
			
				|  |  | +								const cfg = rax.getConfig(err);
 | 
	
		
			
				|  |  | +								YouTubeModule.log(
 | 
	
		
			
				|  |  | +									"ERROR",
 | 
	
		
			
				|  |  | +									"GET_PLAYLIST_PAGE",
 | 
	
		
			
				|  |  | +									`Attempt #${cfg.currentRetryAttempt}. Error: ${err.message}`
 | 
	
		
			
				|  |  | +								);
 | 
	
		
			
				|  |  | +							}
 | 
	
		
			
				|  |  | +						}
 | 
	
		
			
				|  |  |  					})
 | 
	
		
			
				|  |  |  					.then(res => {
 | 
	
		
			
				|  |  |  						if (res.data.err) {
 | 
	
	
		
			
				|  | @@ -299,6 +342,7 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  						return resolve({ songs });
 | 
	
		
			
				|  |  |  					})
 | 
	
		
			
				|  |  |  					.catch(err => {
 | 
	
		
			
				|  |  | +						// console.log(333, err, payload);
 | 
	
		
			
				|  |  |  						YouTubeModule.log("ERROR", "GET_PLAYLIST_PAGE", `${err.message}`);
 | 
	
		
			
				|  |  |  						if (err.message === "Request failed with status code 404") {
 | 
	
		
			
				|  |  |  							return reject(new Error("Playlist not found. Is the playlist public/unlisted?"));
 | 
	
	
		
			
				|  | @@ -338,10 +382,20 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  			return YouTubeModule.rateLimiter.continue().then(() => {
 | 
	
		
			
				|  |  |  				YouTubeModule.rateLimiter.restart();
 | 
	
		
			
				|  |  | -				axios
 | 
	
		
			
				|  |  | +				YouTubeModule.axios
 | 
	
		
			
				|  |  |  					.get("https://www.googleapis.com/youtube/v3/videos", {
 | 
	
		
			
				|  |  |  						params,
 | 
	
		
			
				|  |  | -						timeout: YouTubeModule.requestTimeout
 | 
	
		
			
				|  |  | +						timeout: YouTubeModule.requestTimeout,
 | 
	
		
			
				|  |  | +						raxConfig: {
 | 
	
		
			
				|  |  | +							onRetryAttempt: err => {
 | 
	
		
			
				|  |  | +								const cfg = rax.getConfig(err);
 | 
	
		
			
				|  |  | +								YouTubeModule.log(
 | 
	
		
			
				|  |  | +									"ERROR",
 | 
	
		
			
				|  |  | +									"FILTER_MUSIC_VIDEOS",
 | 
	
		
			
				|  |  | +									`Attempt #${cfg.currentRetryAttempt}. Error: ${err.message}`
 | 
	
		
			
				|  |  | +								);
 | 
	
		
			
				|  |  | +							}
 | 
	
		
			
				|  |  | +						}
 | 
	
		
			
				|  |  |  					})
 | 
	
		
			
				|  |  |  					.then(res => {
 | 
	
		
			
				|  |  |  						if (res.data.err) {
 | 
	
	
		
			
				|  | @@ -368,6 +422,7 @@ class _YouTubeModule extends CoreClass {
 | 
	
		
			
				|  |  |  							.catch(err => reject(err));
 | 
	
		
			
				|  |  |  					})
 | 
	
		
			
				|  |  |  					.catch(err => {
 | 
	
		
			
				|  |  | +						// console.log(444, err, payload);
 | 
	
		
			
				|  |  |  						YouTubeModule.log("ERROR", "FILTER_MUSIC_VIDEOS", `${err.message}`);
 | 
	
		
			
				|  |  |  						return reject(new Error("Failed to find playlist from YouTube"));
 | 
	
		
			
				|  |  |  					});
 |