mirror of
https://github.com/swc-project/swc.git
synced 2025-01-02 10:37:56 +03:00
bbaf619f63
swc_bundler: - [x] Fix wrapped esms. (denoland/deno#9307) - [x] Make test secure.
308 lines
7.4 KiB
TypeScript
308 lines
7.4 KiB
TypeScript
// Loaded from https://deno.land/x/axiod@0.20.0-0/mod.ts
|
|
|
|
|
|
import { urlJoin } from "https://deno.land/x/url_join/mod.ts";
|
|
|
|
import {
|
|
IRequest,
|
|
IConfig,
|
|
Data,
|
|
IAxiodResponse,
|
|
} from "./interfaces.ts";
|
|
import { methods } from "./helpers.ts";
|
|
|
|
function axiod(
|
|
url: string | IRequest,
|
|
config?: IRequest,
|
|
): Promise<IAxiodResponse> {
|
|
if (typeof url === "string") {
|
|
return axiod.request(Object.assign({}, axiod.defaults, { url }, config));
|
|
}
|
|
return axiod.request(Object.assign({}, axiod.defaults, url));
|
|
}
|
|
|
|
axiod.defaults = {
|
|
url: "/",
|
|
method: "get",
|
|
timeout: 0,
|
|
withCredentials: false,
|
|
validateStatus: (status: number) => {
|
|
return status >= 200 && status < 300;
|
|
},
|
|
};
|
|
|
|
axiod.create = (config?: IRequest) => {
|
|
const instance = Object.assign({}, axiod);
|
|
instance.defaults = Object.assign({}, axiod.defaults, config);
|
|
instance.defaults.timeout = 1000;
|
|
|
|
return instance;
|
|
};
|
|
|
|
axiod.request = ({
|
|
url = "/",
|
|
baseURL,
|
|
method,
|
|
headers,
|
|
params,
|
|
data,
|
|
timeout,
|
|
withCredentials,
|
|
auth,
|
|
validateStatus,
|
|
paramsSerializer,
|
|
transformRequest,
|
|
transformResponse,
|
|
}: IRequest): Promise<IAxiodResponse> => {
|
|
// Url and Base url
|
|
if (baseURL) {
|
|
url = urlJoin(baseURL, url);
|
|
}
|
|
|
|
// Method
|
|
if (method) {
|
|
if (methods.indexOf(method.toLowerCase().trim()) === -1) {
|
|
throw new Error(`Method ${method} is not supported`);
|
|
} else {
|
|
method = method.toLowerCase().trim();
|
|
}
|
|
} else {
|
|
method = "get";
|
|
}
|
|
|
|
// Params
|
|
let _params = "";
|
|
if (params) {
|
|
if (paramsSerializer) {
|
|
_params = paramsSerializer(params);
|
|
} else {
|
|
_params = Object.keys(params)
|
|
.map((key) => {
|
|
return (
|
|
encodeURIComponent(key) + "=" + encodeURIComponent(params[key])
|
|
);
|
|
})
|
|
.join("&");
|
|
}
|
|
}
|
|
|
|
// Add credentials to header
|
|
if (withCredentials) {
|
|
if (auth?.username && auth?.password) {
|
|
if (!headers) {
|
|
headers = {};
|
|
}
|
|
|
|
headers["Authorization"] = "Basic " +
|
|
btoa(
|
|
unescape(encodeURIComponent(`${auth.username}:${auth.password}`)),
|
|
);
|
|
}
|
|
}
|
|
|
|
// Create fetch Request Config
|
|
const fetchRequestObject: RequestInit = {};
|
|
|
|
// Add method to Request Config
|
|
if (method !== "get") {
|
|
fetchRequestObject.method = method.toUpperCase();
|
|
}
|
|
|
|
// Add params to Request Config Url
|
|
if (_params) {
|
|
url = urlJoin(url, `?${params}`);
|
|
}
|
|
|
|
// Add body to Request Config
|
|
if (data && method !== "get") {
|
|
// transformRequest
|
|
if (
|
|
transformRequest &&
|
|
Array.isArray(transformRequest) &&
|
|
transformRequest.length > 0
|
|
) {
|
|
for (var i = 0; i < (transformRequest || []).length; i++) {
|
|
if (transformRequest && transformRequest[i]) {
|
|
data = transformRequest[i](data, headers);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (typeof data === "string" || data instanceof FormData) {
|
|
fetchRequestObject.body = data;
|
|
} else {
|
|
try {
|
|
fetchRequestObject.body = JSON.stringify(data);
|
|
if (!headers) {
|
|
headers = {};
|
|
}
|
|
|
|
headers["Accept"] = "application/json";
|
|
headers["Content-Type"] = "application/json";
|
|
} catch (ex) {}
|
|
}
|
|
}
|
|
|
|
// Add headers to Request Config
|
|
if (headers) {
|
|
const _headers: Headers = new Headers();
|
|
Object.keys(headers).forEach((header) => {
|
|
if (headers && headers[header]) {
|
|
_headers.set(header, headers[header]);
|
|
}
|
|
});
|
|
fetchRequestObject.headers = _headers;
|
|
}
|
|
|
|
// [TODO] Mouadh HSOUMI
|
|
// Remove commented test when Abort is supported by Deno
|
|
// https://github.com/denoland/deno/issues/5471
|
|
// https://github.com/Code-Hex/deno-context/issues/8
|
|
// Timeout
|
|
// const controller = new AbortController();
|
|
// fetchRequestObject.signal = controller.signal;
|
|
|
|
// let timeoutVar: number = 0;
|
|
// console.log("timeout", timeout);
|
|
// if ((timeout || 0) > 0) {
|
|
// timeoutVar = setTimeout(() => {
|
|
// timeoutVar = 0;
|
|
// console.log("Cancecled controller.abort()");
|
|
// controller.abort();
|
|
// }, timeout);
|
|
// }
|
|
|
|
// Start request
|
|
return fetch(url, fetchRequestObject).then(async (x) => {
|
|
// // Clear timeout
|
|
// if (timeoutVar) {
|
|
// clearTimeout(timeoutVar);
|
|
// }
|
|
|
|
const _status: number = x.status;
|
|
const _statusText: string = x.statusText;
|
|
|
|
// Data
|
|
let _data: any = null;
|
|
|
|
// Check content type and then do the needed transformations
|
|
const contentType = x.headers.get("content-type") || "";
|
|
if (contentType.toLowerCase().indexOf("json") === -1) {
|
|
// Try to convert to json
|
|
try {
|
|
_data = await x.json();
|
|
} catch (ex) {
|
|
_data = await x.text();
|
|
}
|
|
} else {
|
|
_data = await x.json();
|
|
}
|
|
|
|
// transformResponse
|
|
if (transformResponse) {
|
|
if (
|
|
transformResponse &&
|
|
Array.isArray(transformResponse) &&
|
|
transformResponse.length > 0
|
|
) {
|
|
for (var i = 0; i < (transformResponse || []).length; i++) {
|
|
if (transformResponse && transformResponse[i]) {
|
|
_data = transformResponse[i](_data);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
const _headers: Headers = x.headers;
|
|
const _config: IRequest = {
|
|
url,
|
|
baseURL,
|
|
method,
|
|
headers,
|
|
params,
|
|
data,
|
|
timeout,
|
|
withCredentials,
|
|
auth,
|
|
paramsSerializer,
|
|
};
|
|
|
|
// Validate the status code
|
|
let isValidStatus = true;
|
|
|
|
if (validateStatus) {
|
|
isValidStatus = validateStatus(_status);
|
|
} else {
|
|
isValidStatus = _status >= 200 && _status < 300;
|
|
}
|
|
|
|
if (isValidStatus) {
|
|
return Promise.resolve({
|
|
status: _status,
|
|
statusText: _statusText,
|
|
data: _data,
|
|
headers: _headers,
|
|
config: _config,
|
|
});
|
|
} else {
|
|
const error = {
|
|
response: {
|
|
status: _status,
|
|
statusText: _statusText,
|
|
data: _data,
|
|
headers: _headers,
|
|
},
|
|
config: _config,
|
|
};
|
|
|
|
return Promise.reject(error);
|
|
}
|
|
});
|
|
};
|
|
|
|
axiod.get = (url: string, config?: IConfig) => {
|
|
return axiod.request(Object.assign({}, { url }, config, { method: "get" }));
|
|
};
|
|
axiod.post = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "post", data }),
|
|
);
|
|
};
|
|
axiod.put = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "put", data }),
|
|
);
|
|
};
|
|
axiod.delete = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "delete", data }),
|
|
);
|
|
};
|
|
axiod.options = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "options", data }),
|
|
);
|
|
};
|
|
axiod.head = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "head", data }),
|
|
);
|
|
};
|
|
axiod.connect = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "connect", data }),
|
|
);
|
|
};
|
|
axiod.trace = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "trace", data }),
|
|
);
|
|
};
|
|
axiod.patch = (url: string, data?: Data, config?: IConfig) => {
|
|
return axiod.request(
|
|
Object.assign({}, { url }, config, { method: "patch", data }),
|
|
);
|
|
};
|
|
|
|
export default axiod;
|