2023-10-05 17:46:12 +02:00
|
|
|
const axios = require('axios');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function that configures axios with timing interceptors
|
|
|
|
* Important to note here that the timings are not completely accurate.
|
|
|
|
* @see https://github.com/axios/axios/issues/695
|
2023-10-15 16:40:50 +02:00
|
|
|
* @returns {axios.AxiosInstance}
|
2023-10-05 17:46:12 +02:00
|
|
|
*/
|
|
|
|
function makeAxiosInstance() {
|
2023-10-15 16:40:50 +02:00
|
|
|
/** @type {axios.AxiosInstance} */
|
2023-10-05 17:46:12 +02:00
|
|
|
const instance = axios.create();
|
|
|
|
|
|
|
|
instance.interceptors.request.use((config) => {
|
|
|
|
config.headers['request-start-time'] = Date.now();
|
|
|
|
return config;
|
|
|
|
});
|
|
|
|
|
|
|
|
instance.interceptors.response.use(
|
|
|
|
(response) => {
|
|
|
|
const end = Date.now();
|
|
|
|
const start = response.config.headers['request-start-time'];
|
|
|
|
response.headers['request-duration'] = end - start;
|
|
|
|
return response;
|
|
|
|
},
|
|
|
|
(error) => {
|
|
|
|
if (error.response) {
|
|
|
|
const end = Date.now();
|
|
|
|
const start = error.config.headers['request-start-time'];
|
2023-10-15 16:40:50 +02:00
|
|
|
error.response.headers['request-duration'] = end - start;
|
2023-10-05 17:46:12 +02:00
|
|
|
}
|
|
|
|
return Promise.reject(error);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
return instance;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
makeAxiosInstance
|
|
|
|
};
|