philomena/assets/js/utils/requests.js

65 lines
1.3 KiB
JavaScript
Raw Normal View History

2019-10-05 02:09:52 +02:00
/**
* Request Utils
*/
function fetchJson(verb, endpoint, body) {
const data = {
method: verb,
credentials: 'same-origin',
headers: {
'Content-Type': 'application/json',
2020-09-28 05:53:14 +02:00
'x-csrf-token': window.booru.csrfToken,
'x-requested-with': 'xmlhttprequest'
2019-10-05 02:09:52 +02:00
},
};
if (body) {
body._method = verb;
data.body = JSON.stringify(body);
}
return fetch(endpoint, data);
}
function fetchHtml(endpoint) {
return fetch(endpoint, {
credentials: 'same-origin',
headers: {
2020-09-28 05:53:14 +02:00
'x-csrf-token': window.booru.csrfToken,
'x-requested-with': 'xmlhttprequest'
2019-10-05 02:09:52 +02:00
},
});
}
function handleError(response) {
if (!response.ok) {
throw new Error('Received error from server');
}
return response;
}
2021-10-26 05:42:29 +02:00
/** @returns {Promise<Response>} */
function fetchBackoff(...fetchArgs) {
/**
* @param timeout {number}
* @returns {Promise<Response>}
*/
function fetchBackoffTimeout(timeout) {
// Adjust timeout
const newTimeout = Math.min(timeout * 2, 300000);
// Try to fetch the thing
return fetch(...fetchArgs)
.then(handleError)
.catch(() =>
new Promise(resolve =>
setTimeout(() => resolve(fetchBackoffTimeout(newTimeout)), timeout)
)
);
}
return fetchBackoffTimeout(5000);
}
export { fetchJson, fetchHtml, fetchBackoff, handleError };