171 lines
3.9 KiB
JavaScript
Raw Normal View History

import 'whatwg-fetch';
2017-11-29 11:43:38 +01:00
import auth from 'utils/auth';
/**
* Parses the JSON returned by a network request
*
* @param {object} response A response from a network request
*
* @return {object} The parsed JSON from the request
*/
function parseJSON(response) {
return response.json ? response.json() : response;
}
/**
* Checks if a network request came back fine, and throws an error if not
*
* @param {object} response A response from a network request
*
* @return {object|undefined} Returns either the response, or throws an error
*/
function checkStatus(response, checkToken = true) {
2019-02-22 15:25:11 +01:00
if ((response.status >= 200 && response.status < 300) || response.status === 0) {
return response;
}
if (response.status === 401 && auth.getToken() && checkToken) {
return checkTokenValidity(response);
}
return parseJSON(response).then(responseFormatted => {
const error = new Error(response.statusText);
error.response = response;
error.response.payload = responseFormatted;
throw error;
});
}
function checkTokenValidity(response) {
const options = {
method: 'GET',
headers: {
'Content-Type': 'application/json',
2019-02-14 10:36:20 +01:00
Authorization: `Bearer ${auth.getToken()}`,
},
};
if (auth.getToken()) {
2019-02-14 10:36:20 +01:00
return fetch(`${strapi.backendURL}/user/me`, options).then(() => {
if (response.status === 401) {
window.location = `${
strapi.remoteURL
}/plugins/users-permissions/auth/login`;
2019-02-14 10:36:20 +01:00
auth.clearAppStorage();
}
2019-02-14 10:36:20 +01:00
return checkStatus(response, false);
});
}
}
/**
* Format query params
*
* @param params
* @returns {string}
*/
function formatQueryParams(params) {
return Object.keys(params)
.map(k => `${encodeURIComponent(k)}=${encodeURIComponent(params[k])}`)
.join('&');
}
/**
2019-02-14 10:36:20 +01:00
* Server restart watcher
* @param response
* @returns {object} the response data
*/
function serverRestartWatcher(response) {
2019-02-14 10:36:20 +01:00
return new Promise(resolve => {
fetch(`${strapi.backendURL}/_health`, {
method: 'HEAD',
mode: 'no-cors',
headers: {
'Content-Type': 'application/json',
'Keep-Alive': false,
},
})
.then(() => {
// Hide the global OverlayBlocker
strapi.unlockApp();
resolve(response);
})
.catch(() => {
setTimeout(() => {
2019-02-14 10:36:20 +01:00
return serverRestartWatcher(response).then(resolve);
}, 100);
});
});
}
/**
* Requests a URL, returning a promise
*
* @param {string} url The URL we want to request
* @param {object} [options] The options we want to pass to "fetch"
*
* @return {object} The response data
*/
export default function request(...args) {
let [url, options = {}, shouldWatchServerRestart, stringify = true, ...rest] = args;
let noAuth;
try {
[{ noAuth }] = rest;
} catch(err) {
noAuth = false;
}
// Set headers
2017-12-20 11:23:50 +01:00
if (!options.headers) {
2019-02-14 10:36:20 +01:00
options.headers = Object.assign(
{
'Content-Type': 'application/json',
},
options.headers,
{
'X-Forwarded-Host': 'strapi',
},
);
2017-12-20 11:23:50 +01:00
}
2017-12-20 11:23:50 +01:00
const token = auth.getToken();
2017-11-29 12:48:58 +01:00
if (token && !noAuth) {
2019-02-14 10:36:20 +01:00
options.headers = Object.assign(
{
Authorization: `Bearer ${token}`,
},
options.headers,
);
2017-12-20 11:23:50 +01:00
}
2017-11-29 12:48:58 +01:00
2017-12-20 11:23:50 +01:00
// Add parameters to url
url = _.startsWith(url, '/') ? `${strapi.backendURL}${url}` : url;
2017-12-20 11:23:50 +01:00
if (options && options.params) {
const params = formatQueryParams(options.params);
url = `${url}?${params}`;
}
2017-12-20 11:23:50 +01:00
// Stringify body object
2018-02-22 18:24:17 +01:00
if (options && options.body && stringify) {
2017-12-20 11:23:50 +01:00
options.body = JSON.stringify(options.body);
}
2019-02-22 15:25:11 +01:00
2017-12-20 11:23:50 +01:00
return fetch(url, options)
.then(checkStatus)
.then(parseJSON)
2019-02-14 10:36:20 +01:00
.then(response => {
if (shouldWatchServerRestart) {
// Display the global OverlayBlocker
strapi.lockApp(shouldWatchServerRestart);
return serverRestartWatcher(response);
}
return response;
});
2017-12-20 11:23:50 +01:00
}