Files
certd/packages/core/pipeline/src/utils/util.request.ts

164 lines
4.7 KiB
TypeScript
Raw Normal View History

2024-09-09 16:01:42 +08:00
import axios, { AxiosRequestConfig } from "axios";
2024-07-15 00:30:33 +08:00
import { logger } from "./util.log.js";
2024-06-15 02:17:34 +08:00
import { Logger } from "log4js";
2024-09-22 00:33:09 +08:00
import { HttpProxyAgent } from "http-proxy-agent";
import { HttpsProxyAgent } from "https-proxy-agent";
import nodeHttp from "http";
export class HttpError extends Error {
status?: number;
statusText?: string;
2024-09-09 16:01:42 +08:00
code?: string;
request?: { baseURL: string; url: string; method: string; params?: any; data?: any };
2024-09-09 16:01:42 +08:00
response?: { data: any };
cause?: any;
constructor(error: any) {
if (!error) {
return;
}
super(error.message);
this.name = error.name;
2024-09-09 16:01:42 +08:00
this.code = error.code;
this.cause = error.cause;
this.status = error.response?.status;
this.statusText = error.response?.statusText;
this.request = {
baseURL: error.config?.baseURL,
2024-09-09 16:01:42 +08:00
url: error.config?.url,
method: error.config?.method,
params: error.config?.params,
data: error.config?.data,
};
this.response = {
2024-09-09 16:01:42 +08:00
data: error.response?.data,
};
2024-09-09 16:01:42 +08:00
delete error.response;
delete error.config;
delete error.request;
2024-09-19 14:23:15 +08:00
// logger.error(error);
}
}
2024-09-19 14:23:15 +08:00
export const HttpCommonError = HttpError;
2022-11-07 23:31:20 +08:00
/**
* @description
*/
2024-06-15 02:17:34 +08:00
export function createAxiosService({ logger }: { logger: Logger }) {
2022-11-07 23:31:20 +08:00
// 创建一个 axios 实例
const service = axios.create();
2024-09-14 10:28:06 +08:00
2024-09-22 00:33:09 +08:00
const defaultAgents = createAgent();
2022-11-07 23:31:20 +08:00
// 请求拦截
service.interceptors.request.use(
(config: any) => {
2024-09-09 16:01:42 +08:00
logger.info(`http request:${config.url}method:${config.method}params:${JSON.stringify(config.params)}`);
if (config.timeout == null) {
2024-09-10 17:39:41 +08:00
config.timeout = 15000;
}
2024-09-22 00:33:09 +08:00
let agents = defaultAgents;
if (config.skipSslVerify) {
logger.info("跳过SSL验证");
agents = createAgent({ rejectUnauthorized: false } as any);
}
delete config.skipSslVerify;
config.httpsAgent = agents.httpsAgent;
config.httpAgent = agents.httpAgent;
2024-09-14 10:28:06 +08:00
2022-11-07 23:31:20 +08:00
return config;
},
(error: Error) => {
// 发送失败
2024-06-15 02:17:34 +08:00
logger.error("接口请求失败:", error);
2022-11-07 23:31:20 +08:00
return Promise.reject(error);
}
);
// 响应拦截
service.interceptors.response.use(
(response: any) => {
2024-06-15 02:17:34 +08:00
logger.info("http response:", JSON.stringify(response?.data));
2022-11-07 23:31:20 +08:00
return response.data;
},
(error: any) => {
2024-09-10 17:39:41 +08:00
const status = error.response?.status;
switch (status) {
case 400:
error.message = "请求错误";
break;
case 401:
error.message = "未授权,请登录";
break;
case 403:
error.message = "拒绝访问";
break;
case 404:
error.message = `请求地址出错: ${error.response.config.url}`;
break;
case 408:
error.message = "请求超时";
break;
case 500:
error.message = "服务器内部错误";
break;
case 501:
error.message = "服务未实现";
break;
case 502:
error.message = "网关错误";
break;
case 503:
error.message = "服务不可用";
break;
case 504:
error.message = "网关超时";
break;
case 505:
error.message = "HTTP版本不受支持";
break;
default:
break;
}
logger.error(
2024-09-09 16:01:42 +08:00
`请求出错status:${error.response?.status},statusText:${error.response?.statusText},url:${error.config?.url},method:${error.config?.method}`
);
2024-09-09 16:01:42 +08:00
logger.error("返回数据:", JSON.stringify(error.response?.data));
2024-09-24 11:11:08 +08:00
if (error.response?.data) {
error.message = error.response.data.message || error.response.data.msg || error.response.data.error || error.response.data;
}
2024-09-09 10:17:40 +08:00
if (error instanceof AggregateError) {
2024-09-19 14:23:15 +08:00
logger.error("AggregateError", error);
2024-09-09 10:17:40 +08:00
}
const err = new HttpError(error);
return Promise.reject(err);
2022-11-07 23:31:20 +08:00
}
);
return service;
}
2024-09-09 16:01:42 +08:00
export const http = createAxiosService({ logger }) as HttpClient;
export type HttpClientResponse<R> = any;
2024-09-14 10:28:06 +08:00
export type HttpRequestConfig<D> = {
skipSslVerify?: boolean;
2024-09-30 18:00:51 +08:00
skipCheckRes?: boolean;
2024-09-14 10:28:06 +08:00
} & AxiosRequestConfig<D>;
2024-09-09 16:01:42 +08:00
export type HttpClient = {
2024-09-14 10:28:06 +08:00
request<D = any, R = any>(config: HttpRequestConfig<D>): Promise<HttpClientResponse<R>>;
2024-09-09 16:01:42 +08:00
};
2024-09-14 10:28:06 +08:00
2024-09-22 00:33:09 +08:00
export function createAgent(opts: nodeHttp.AgentOptions = {}) {
let httpAgent, httpsAgent;
const httpProxy = process.env.HTTP_PROXY || process.env.http_proxy;
if (httpProxy) {
httpAgent = new HttpProxyAgent(httpProxy, opts as any);
}
const httpsProxy = process.env.HTTPS_PROXY || process.env.https_proxy;
if (httpsProxy) {
httpsAgent = new HttpsProxyAgent(httpsProxy, opts as any);
}
2024-09-14 10:28:06 +08:00
return {
httpAgent,
2024-09-22 00:33:09 +08:00
httpsAgent,
2024-09-14 10:28:06 +08:00
};
}