@gam-test/fetch-wrapper
Version:
A simple fetch wrapper for better error handling and less response context
24 lines (22 loc) • 1.44 kB
JavaScript
Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var _HttpClientjs = require('../HttpClient.js');
var _statusCodeExceptionsMapjs = require('../exceptions/statusCodeExceptionsMap.js');
class GetHttpClient extends _HttpClientjs.HttpClient {
async connect(config) {
const response = await fetch(`${this.url}`, {
...config,
method: "GET"
});
const requestException = _statusCodeExceptionsMapjs.statusCodeExceptionsMap.get(response.status);
if (requestException && _optionalChain([config, 'optionalAccess', _ => _.throwOnConnectionFailure])) {
const responseBody = await response.json().catch(() => "Request response with non json body");
throw new requestException({
url: this.url,
payload: null,
responseBody
});
}
return response;
}
}
exports.GetHttpClient = GetHttpClient;
//# sourceMappingURL=GetHttpClient.js.map
;