gohttpdUi/src/config/axios/service.ts

71 lines
1.9 KiB
TypeScript
Raw Normal View History

2023-04-28 17:50:58 +08:00
import axios from 'axios'
2023-05-04 14:20:10 +08:00
import config, { defaultRequestInterceptors, defaultResponseInterceptors } from './config'
2023-04-28 17:50:58 +08:00
2023-06-08 09:47:18 +08:00
import { AxiosInstance, InternalAxiosRequestConfig, RequestConfig, AxiosResponse } from './types'
2023-04-28 17:50:58 +08:00
2023-05-04 14:20:10 +08:00
const { interceptors, baseUrl } = config
2023-06-08 09:47:18 +08:00
export const PATH_URL = baseUrl[import.meta.env.VITE_API_BASE_PATH]
2023-04-28 17:50:58 +08:00
const { requestInterceptors, responseInterceptors } = interceptors
const abortControllerMap: Map<string, AbortController> = new Map()
2023-05-04 14:20:10 +08:00
const axiosInstance: AxiosInstance = axios.create({
...config,
baseURL: PATH_URL
})
2023-04-28 17:50:58 +08:00
axiosInstance.interceptors.request.use((res: InternalAxiosRequestConfig) => {
const controller = new AbortController()
const url = res.url || ''
res.signal = controller.signal
abortControllerMap.set(url, controller)
return res
2022-08-13 09:32:13 +08:00
})
2023-04-28 17:50:58 +08:00
axiosInstance.interceptors.response.use(
(res: AxiosResponse) => {
const url = res.config.url || ''
abortControllerMap.delete(url)
return res.data
2022-08-13 09:32:13 +08:00
},
2023-04-28 17:50:58 +08:00
(err: any) => err
2022-08-13 09:32:13 +08:00
)
2023-05-04 14:20:10 +08:00
axiosInstance.interceptors.request.use(requestInterceptors || defaultRequestInterceptors)
axiosInstance.interceptors.response.use(responseInterceptors || defaultResponseInterceptors)
const service = {
request: (config: RequestConfig) => {
return new Promise((resolve, reject) => {
if (config.interceptors?.requestInterceptors) {
config = config.interceptors.requestInterceptors(config as any)
}
axiosInstance
.request(config)
.then((res) => {
resolve(res)
})
.catch((err: any) => {
reject(err)
})
})
},
cancelRequest: (url: string | string[]) => {
const urlList = Array.isArray(url) ? url : [url]
for (const _url of urlList) {
abortControllerMap.get(_url)?.abort()
abortControllerMap.delete(_url)
}
},
cancelAllRequest() {
for (const [_, controller] of abortControllerMap) {
controller.abort()
}
abortControllerMap.clear()
}
}
export default service