PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/avalanche/dist/utils

Просмотр файла: fetchadapter.js

"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":";;;;;;;;;;;;AAEA,SAAS,aAAa,CAAC,MAA0B;IAC/C,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,MAAM,CAAC,OAAiC,CAAC,CAAA;IAErE,IAAI,MAAM,CAAC,IAAI,EAAE;QACf,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAA;QAC3C,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ;YACnC,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC1C,CAAC,CAAC,EAAE,CAAA;QACN,OAAO,CAAC,GAAG,CACT,eAAe,EACf,SAAS,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,IAAI,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CACrE,CAAA;KACF;IAED,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,CAAA;IAC1C,MAAM,OAAO,GAAgB;QAC3B,OAAO,EAAE,OAAO;QAChB,MAAM;KACP,CAAA;IACD,IAAI,MAAM,KAAK,KAAK,IAAI,MAAM,KAAK,MAAM,EAAE;QACzC,OAAO,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;KAC3B;IAED,IAAI,CAAC,CAAC,MAAM,CAAC,eAAe,EAAE;QAC5B,OAAO,CAAC,WAAW,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAA;KAClE;IAED,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,CAAC,CAAA;IACpD,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAEjD,MAAM,GAAG,GAAG,GAAG,QAAQ,GAAG,MAAM,EAAE,CAAA;IAElC,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;AAClC,CAAC;AAED,SAAe,WAAW,CAAC,OAAO,EAAE,MAAM;;QACxC,IAAI,QAAQ,CAAA;QACZ,IAAI;YACF,QAAQ,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,CAAA;SAChC;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,KAAK,mCACN,IAAI,KAAK,CAAC,eAAe,CAAC,KAC7B,MAAM;gBACN,OAAO,EACP,YAAY,EAAE,IAAI,EAClB,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK,GACpB,CAAA;YACD,OAAO,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;SAC7B;QAED,MAAM,QAAQ,GAAkB;YAC9B,MAAM,EAAE,QAAQ,CAAC,MAAM;YACvB,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,OAAO,oBAAO,QAAQ,CAAC,OAAO,CAAE;YAChC,MAAM,EAAE,MAAM;YACd,OAAO;YACP,IAAI,EAAE,SAAS,CAAC,kBAAkB;SACnC,CAAA;QAED,IAAI,QAAQ,CAAC,MAAM,IAAI,GAAG,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE;YACrD,QAAQ,MAAM,CAAC,YAAY,EAAE;gBAC3B,KAAK,aAAa;oBAChB,QAAQ,CAAC,IAAI,GAAG,MAAM,QAAQ,CAAC,WAAW,EAAE,CAAA;oBAC5C,MAAK;gBACP,KAAK,MAAM;oBACT,QAAQ,CAAC,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;oBACrC,MAAK;gBACP,KAAK,MAAM;oBACT,QAAQ,CAAC,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;oBACrC,MAAK;gBACP,KAAK,UAAU;oBACb,QAAQ,CAAC,IAAI,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,CAAA;oBACzC,MAAK;gBACP;oBACE,QAAQ,CAAC,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;oBACrC,MAAK;aACR;SACF;QAED,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IAClC,CAAC;CAAA;AAED,SAAsB,YAAY,CAChC,MAA0B;;QAE1B,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;QAErC,MAAM,YAAY,GAAG,CAAC,WAAW,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;QAEnD,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,OAAO,GAAG,CAAC,EAAE;YACxC,YAAY,CAAC,IAAI,CACf,IAAI,OAAO,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;gBAC1B,UAAU,CAAC,GAAG,EAAE;oBACd,MAAM,OAAO,GAAG,MAAM,CAAC,mBAAmB;wBACxC,CAAC,CAAC,MAAM,CAAC,mBAAmB;wBAC5B,CAAC,CAAC,aAAa,GAAG,MAAM,CAAC,OAAO,GAAG,aAAa,CAAA;oBAClD,MAAM,KAAK,mCACN,IAAI,KAAK,CAAC,OAAO,CAAC,KACrB,MAAM;wBACN,OAAO,EACP,IAAI,EAAE,cAAc,EACpB,YAAY,EAAE,IAAI,EAClB,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK,GACpB,CAAA;oBACD,MAAM,CAAC,KAAK,CAAC,CAAA;gBACf,CAAC,EAAE,MAAM,CAAC,OAAO,CAAC,CAAA;YACpB,CAAC,CAAC,CACH,CAAA;SACF;QAED,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;QACjD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,QAAQ,YAAY,KAAK,EAAE;gBAC7B,MAAM,CAAC,QAAQ,CAAC,CAAA;aACjB;iBAAM;gBACL,IACE,CAAC,QAAQ,CAAC,MAAM;oBAChB,CAAC,QAAQ,CAAC,MAAM,CAAC,cAAc;oBAC/B,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,CAAC,EAC/C;oBACA,OAAO,CAAC,QAAQ,CAAC,CAAA;iBAClB;qBAAM;oBACL,MAAM,KAAK,mCACN,IAAI,KAAK,CAAC,kCAAkC,GAAG,QAAQ,CAAC,MAAM,CAAC,KAClE,MAAM;wBACN,OAAO,EACP,IAAI,EAAE,QAAQ,CAAC,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,iBAAiB,EACrE,YAAY,EAAE,IAAI,EAClB,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK,GACpB,CAAA;oBACD,MAAM,CAAC,KAAK,CAAC,CAAA;iBACd;aACF;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;CAAA;AApDD,oCAoDC","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"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!