@c4tplatform/caminojs
Version:
Camino Platform JS Library
116 lines • 14.9 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.fetchAdapter = void 0;
function createRequest(config) {
const headers = new Headers(config.headers);
if (config.auth) {
const username = config.auth.username || "";
const password = config.auth.password
? encodeURIComponent(config.auth.password)
: "";
headers.set("Authorization", `Basic ${Buffer.from(`${username}:${password}`).toString("base64")}`);
}
const method = config.method.toUpperCase();
const options = {
headers: headers,
method
};
if (method !== "GET" && method !== "HEAD") {
options.body = config.data;
}
if (config.withCredentials) {
options.credentials = config.withCredentials ? "include" : "omit";
}
const fullPath = new URL(config.url, config.baseURL);
const params = new URLSearchParams(config.params);
const url = `${fullPath}${params}`;
return new Request(url, options);
}
function getResponse(request, config) {
return __awaiter(this, void 0, void 0, function* () {
let stageOne;
try {
stageOne = yield fetch(request);
}
catch (e) {
const error = Object.assign(Object.assign({}, new Error("Network Error")), { config,
request, isAxiosError: true, toJSON: () => error });
return Promise.reject(error);
}
const response = {
status: stageOne.status,
statusText: stageOne.statusText,
headers: Object.assign({}, stageOne.headers),
config: config,
request,
data: undefined // we set it below
};
if (stageOne.status >= 200 && stageOne.status !== 204) {
switch (config.responseType) {
case "arraybuffer":
response.data = yield stageOne.arrayBuffer();
break;
case "blob":
response.data = yield stageOne.blob();
break;
case "json":
response.data = yield stageOne.json();
break;
case "formData":
response.data = yield stageOne.formData();
break;
default:
response.data = yield stageOne.text();
break;
}
}
return Promise.resolve(response);
});
}
function fetchAdapter(config) {
return __awaiter(this, void 0, void 0, function* () {
const request = createRequest(config);
const promiseChain = [getResponse(request, config)];
if (config.timeout && config.timeout > 0) {
promiseChain.push(new Promise((res, reject) => {
setTimeout(() => {
const message = config.timeoutErrorMessage
? config.timeoutErrorMessage
: "timeout of " + config.timeout + "ms exceeded";
const error = Object.assign(Object.assign({}, new Error(message)), { config,
request, code: "ECONNABORTED", isAxiosError: true, toJSON: () => error });
reject(error);
}, config.timeout);
}));
}
const response = yield Promise.race(promiseChain);
return new Promise((resolve, reject) => {
if (response instanceof Error) {
reject(response);
}
else {
if (!response.status ||
!response.config.validateStatus ||
response.config.validateStatus(response.status)) {
resolve(response);
}
else {
const error = Object.assign(Object.assign({}, new Error("Request failed with status code " + response.status)), { config,
request, code: response.status >= 500 ? "ERR_BAD_RESPONSE" : "ERR_BAD_REQUEST", isAxiosError: true, toJSON: () => error });
reject(error);
}
}
});
});
}
exports.fetchAdapter = fetchAdapter;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fetchadapter.js","sourceRoot":"","sources":["../../src/utils/fetchadapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { AxiosRequestConfig, AxiosResponse, AxiosError } from \"axios\"\n\nfunction createRequest(config: AxiosRequestConfig): Request {\n  const headers = new Headers(config.headers as Record<string, string>)\n\n  if (config.auth) {\n    const username = config.auth.username || \"\"\n    const password = config.auth.password\n      ? encodeURIComponent(config.auth.password)\n      : \"\"\n    headers.set(\n      \"Authorization\",\n      `Basic ${Buffer.from(`${username}:${password}`).toString(\"base64\")}`\n    )\n  }\n\n  const method = config.method.toUpperCase()\n  const options: RequestInit = {\n    headers: headers,\n    method\n  }\n  if (method !== \"GET\" && method !== \"HEAD\") {\n    options.body = config.data\n  }\n\n  if (config.withCredentials) {\n    options.credentials = config.withCredentials ? \"include\" : \"omit\"\n  }\n\n  const fullPath = new URL(config.url, config.baseURL)\n  const params = new URLSearchParams(config.params)\n\n  const url = `${fullPath}${params}`\n\n  return new Request(url, options)\n}\n\nasync function getResponse(request, config): Promise<AxiosResponse> {\n  let stageOne\n  try {\n    stageOne = await fetch(request)\n  } catch (e) {\n    const error: AxiosError = {\n      ...new Error(\"Network Error\"),\n      config,\n      request,\n      isAxiosError: true,\n      toJSON: () => error\n    }\n    return Promise.reject(error)\n  }\n\n  const response: AxiosResponse = {\n    status: stageOne.status,\n    statusText: stageOne.statusText,\n    headers: { ...stageOne.headers }, // make a copy of the headers\n    config: config,\n    request,\n    data: undefined // we set it below\n  }\n\n  if (stageOne.status >= 200 && stageOne.status !== 204) {\n    switch (config.responseType) {\n      case \"arraybuffer\":\n        response.data = await stageOne.arrayBuffer()\n        break\n      case \"blob\":\n        response.data = await stageOne.blob()\n        break\n      case \"json\":\n        response.data = await stageOne.json()\n        break\n      case \"formData\":\n        response.data = await stageOne.formData()\n        break\n      default:\n        response.data = await stageOne.text()\n        break\n    }\n  }\n\n  return Promise.resolve(response)\n}\n\nexport async function fetchAdapter(\n  config: AxiosRequestConfig\n): Promise<AxiosResponse> {\n  const request = createRequest(config)\n\n  const promiseChain = [getResponse(request, config)]\n\n  if (config.timeout && config.timeout > 0) {\n    promiseChain.push(\n      new Promise((res, reject) => {\n        setTimeout(() => {\n          const message = config.timeoutErrorMessage\n            ? config.timeoutErrorMessage\n            : \"timeout of \" + config.timeout + \"ms exceeded\"\n          const error: AxiosError = {\n            ...new Error(message),\n            config,\n            request,\n            code: \"ECONNABORTED\",\n            isAxiosError: true,\n            toJSON: () => error\n          }\n          reject(error)\n        }, config.timeout)\n      })\n    )\n  }\n\n  const response = await Promise.race(promiseChain)\n  return new Promise((resolve, reject) => {\n    if (response instanceof Error) {\n      reject(response)\n    } else {\n      if (\n        !response.status ||\n        !response.config.validateStatus ||\n        response.config.validateStatus(response.status)\n      ) {\n        resolve(response)\n      } else {\n        const error: AxiosError = {\n          ...new Error(\"Request failed with status code \" + response.status),\n          config,\n          request,\n          code: response.status >= 500 ? \"ERR_BAD_RESPONSE\" : \"ERR_BAD_REQUEST\",\n          isAxiosError: true,\n          toJSON: () => error\n        }\n        reject(error)\n      }\n    }\n  })\n}\n"]}