2017-04-26 15:58:19 +02:00
|
|
|
import baseRequest from './baseRequest';
|
|
|
|
import sanitize from './sanitize';
|
|
|
|
|
|
|
|
|
|
|
|
const DEFAULT_REQUEST_CONFIG = {
|
|
|
|
headers: {
|
|
|
|
'Accept': 'application/json'
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2017-05-11 17:19:07 +02:00
|
|
|
* Small wrapper around js-utility-belt's request that provides url resolving,
|
|
|
|
* default settings, and response handling.
|
2017-04-26 15:58:19 +02:00
|
|
|
*/
|
|
|
|
export default function request(url, config = {}, onlyJsonResponse=true) {
|
|
|
|
// Load default fetch configuration and remove any falsy query parameters
|
|
|
|
const requestConfig = Object.assign({}, DEFAULT_REQUEST_CONFIG, config, {
|
|
|
|
query: config.query && sanitize(config.query)
|
|
|
|
});
|
|
|
|
let apiUrl = url;
|
|
|
|
|
|
|
|
if (requestConfig.jsonBody) {
|
|
|
|
requestConfig.headers = Object.assign({}, requestConfig.headers, {
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
if (!url) {
|
|
|
|
return Promise.reject(new Error('Request was not given a url.'));
|
|
|
|
}
|
|
|
|
|
|
|
|
return baseRequest(apiUrl, requestConfig)
|
|
|
|
.then((res) => {
|
|
|
|
return onlyJsonResponse ? res.json() :
|
|
|
|
{
|
|
|
|
json: res.json(),
|
|
|
|
url: res.url
|
|
|
|
};
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.error(err);
|
|
|
|
throw err;
|
|
|
|
});
|
|
|
|
}
|