100 lines
3.1 KiB
TypeScript
100 lines
3.1 KiB
TypeScript
import { FetchOptions } from 'ohmyfetch'
|
||
import { RequestCodeEnum, RequestMethodsEnum, RequestConfig } from '@/enums/requestEnums'
|
||
import feedback from '@/utils/feedback'
|
||
import { merge } from 'lodash-es'
|
||
import { Request } from './request'
|
||
import { useUserStore } from '@/stores/user'
|
||
import { getApiUrl } from '@/utils/env'
|
||
import { useNuxtApp } from 'nuxt/app'
|
||
export function createRequest(opt?: Partial<FetchOptions>) {
|
||
const userStore = useUserStore()
|
||
const nuxtApp = useNuxtApp()
|
||
const defaultOptions: FetchOptions = {
|
||
// 基础接口地址
|
||
baseURL: getApiUrl(),
|
||
//请求头
|
||
headers: {
|
||
// version: getVersion(),
|
||
},
|
||
retry: 2,
|
||
async onRequest({ options }) {
|
||
const headers = options.headers || {}
|
||
// 添加token
|
||
const token = userStore.token
|
||
const account = userStore.account
|
||
if (token) {
|
||
// @ts-ignore
|
||
headers[RequestConfig.TOKENNAME] = token
|
||
}
|
||
options.headers = headers
|
||
},
|
||
requestOptions: {
|
||
// apiPrefix: getApiPrefix(),
|
||
apiPrefix: '/api/',
|
||
isTransformResponse: true,
|
||
isReturnDefaultResponse: false,
|
||
withToken: true,
|
||
isParamsToData: true,
|
||
requestInterceptorsHook(options) {
|
||
const { apiPrefix, isParamsToData } = options.requestOptions
|
||
// 拼接请求前缀
|
||
if (apiPrefix) {
|
||
options.url = `${apiPrefix}${options.url}`
|
||
}
|
||
const params = options.params || {}
|
||
// POST请求下如果无data,则将params视为data
|
||
if (
|
||
isParamsToData &&
|
||
!Reflect.has(options, 'body') &&
|
||
options.method?.toUpperCase() === RequestMethodsEnum.POST
|
||
) {
|
||
options.body = params
|
||
options.params = {}
|
||
}
|
||
return options
|
||
},
|
||
async responseInterceptorsHook(response, options) {
|
||
const { isTransformResponse, isReturnDefaultResponse } = options.requestOptions
|
||
const headers = Object.fromEntries(response.headers.entries())
|
||
|
||
//返回默认响应,当需要获取响应头及其他数据时可使用
|
||
if (isReturnDefaultResponse) {
|
||
return response
|
||
}
|
||
// 是否需要对数据进行处理
|
||
if (!isTransformResponse) {
|
||
return response._data
|
||
}
|
||
|
||
const { code, data, message } = response._data
|
||
|
||
// code返回码处理
|
||
switch (code) {
|
||
case RequestCodeEnum.SUCCESS:
|
||
return Promise.resolve(data)
|
||
case RequestCodeEnum.FAIL:
|
||
message && feedback.msgError(message)
|
||
return Promise.reject(message)
|
||
case RequestCodeEnum.PARAMS_FAIL:
|
||
message && feedback.msgError(message)
|
||
return Promise.reject(message)
|
||
case RequestCodeEnum.LOGIN_FAILURE_ONE:
|
||
case RequestCodeEnum.LOGIN_FAILURE_TWO:
|
||
nuxtApp.$onHandlerLogin()
|
||
userStore.logout()
|
||
return Promise.reject(message)
|
||
default:
|
||
return data
|
||
}
|
||
},
|
||
responseInterceptorsCatchHook(err) {
|
||
return err
|
||
},
|
||
},
|
||
}
|
||
return new Request(
|
||
// 深度合并
|
||
merge(defaultOptions, opt || {}),
|
||
)
|
||
}
|