UNPKG

@c4tplatform/caminojs

Version:
116 lines 14.9 kB
"use strict"; 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"]}