2024-08-01 23:15:38 +05:30

77 lines
1.7 KiB
JavaScript

const axios = require('axios');
const { baseAPIURL, accountsAPIURL } = require("../constants");
const logger = require('./logger')(module);
const authInstance = axios.default.create({
baseURL: accountsAPIURL,
timeout: 20000,
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Authorization': 'Basic ' + (Buffer.from(process.env.CLIENT_ID + ':' + process.env.CLIENT_SECRET).toString('base64'))
},
});
const axiosInstance = axios.default.create({
baseURL: baseAPIURL,
timeout: 20000,
headers: {
'Content-Type': 'application/json'
},
});
axiosInstance.interceptors.request.use(config => {
logger.http("API call", {
url: config.url,
method: config.method,
params: config.params ?? {},
});
return config;
});
axiosInstance.interceptors.response.use(
(response) => response,
(error) => {
if (error.response && error.response.status === 429) {
// Rate limiting
logger.warn("Spotify API: Too many requests");
return error.response;
}
else if (error.response) {
// Server has responded
logger.error(
"Spotify API: Error", {
response: {
status: error.response.status,
statusText: error.response.statusText,
data: error.response.data
}
});
return error.response;
} else if (error.request) {
// The request was made but no response was received
logger.error(
"Spotify API: No response", {
request: {
url: error.request?.url,
params: error.request?.params,
}
});
} else {
// Something happened in setting up the request that triggered an Error
logger.error(
"Spotify API: Request error", {
error: {
message: error.message,
}
});
}
return Promise.reject(error);
}
);
module.exports = {
authInstance,
axiosInstance
};