@gam-test/fetch-wrapper
Version:
A simple fetch wrapper for better error handling and less response context
25 lines (23 loc) • 1.49 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 PostHttpClient extends _HttpClientjs.HttpClient {
async connect({ data, ...config }) {
const response = await fetch(`${this.url}`, {
...config,
method: "POST",
body: JSON.stringify(data)
});
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: data,
responseBody
});
}
return response;
}
}
exports.PostHttpClient = PostHttpClient;
//# sourceMappingURL=PostHttpClient.js.map
;