2020-12-05 01:55:53 +01:00
|
|
|
import axios from 'axios'
|
2020-12-14 22:33:19 +01:00
|
|
|
import { store, RootState } from '@root/store'
|
2020-10-23 09:22:17 +02:00
|
|
|
|
2020-10-31 21:04:46 +01:00
|
|
|
const client = async ({
|
|
|
|
method,
|
|
|
|
instance,
|
2020-12-05 01:55:53 +01:00
|
|
|
instanceDomain,
|
|
|
|
version = 'v1',
|
|
|
|
url,
|
|
|
|
params,
|
2020-11-15 22:33:09 +01:00
|
|
|
headers,
|
2020-12-05 01:55:53 +01:00
|
|
|
body,
|
|
|
|
onUploadProgress
|
2020-10-31 21:04:46 +01:00
|
|
|
}: {
|
2020-11-20 01:41:46 +01:00
|
|
|
method: 'get' | 'post' | 'put' | 'delete'
|
2020-10-31 21:04:46 +01:00
|
|
|
instance: 'local' | 'remote'
|
2020-12-05 01:55:53 +01:00
|
|
|
instanceDomain?: string
|
|
|
|
version?: 'v1' | 'v2'
|
|
|
|
url: string
|
|
|
|
params?: {
|
2020-10-31 21:04:46 +01:00
|
|
|
[key: string]: string | number | boolean
|
|
|
|
}
|
2020-12-05 01:55:53 +01:00
|
|
|
headers?: { [key: string]: string }
|
2020-11-17 23:57:23 +01:00
|
|
|
body?: FormData
|
2020-12-05 01:55:53 +01:00
|
|
|
onUploadProgress?: (progressEvent: any) => void
|
2020-10-31 21:04:46 +01:00
|
|
|
}): Promise<any> => {
|
2020-11-21 00:40:55 +01:00
|
|
|
const state: RootState['instances'] = store.getState().instances
|
2020-12-05 01:55:53 +01:00
|
|
|
const domain =
|
|
|
|
instance === 'remote' ? instanceDomain || state.remote.url : state.local.url
|
2020-10-26 00:27:53 +01:00
|
|
|
|
2020-12-05 01:55:53 +01:00
|
|
|
return axios({
|
|
|
|
method,
|
|
|
|
baseURL: `https://${domain}/api/${version}/`,
|
|
|
|
url,
|
|
|
|
params,
|
2020-11-17 23:57:23 +01:00
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
...headers,
|
|
|
|
...(instance === 'local' && {
|
2020-11-21 00:40:55 +01:00
|
|
|
Authorization: `Bearer ${state.local.token}`
|
2020-11-17 23:57:23 +01:00
|
|
|
})
|
|
|
|
},
|
2020-12-05 01:55:53 +01:00
|
|
|
...(body && { data: body }),
|
|
|
|
...(onUploadProgress && { onUploadProgress: onUploadProgress })
|
2020-11-17 23:57:23 +01:00
|
|
|
})
|
2020-12-05 01:55:53 +01:00
|
|
|
.then(response =>
|
|
|
|
Promise.resolve({
|
|
|
|
headers: response.headers,
|
|
|
|
body: response.data
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.catch(error => {
|
|
|
|
if (error.response) {
|
|
|
|
// The request was made and the server responded with a status code
|
|
|
|
// that falls out of the range of 2xx
|
|
|
|
console.error('axios error', error.response)
|
|
|
|
return Promise.reject({
|
|
|
|
headers: error.response.headers,
|
|
|
|
body: error.response.data.error
|
|
|
|
})
|
|
|
|
} else if (error.request) {
|
|
|
|
// The request was made but no response was received
|
|
|
|
// `error.request` is an instance of XMLHttpRequest in the browser and an instance of
|
|
|
|
// http.ClientRequest in node.js
|
|
|
|
console.error('axios error', error)
|
|
|
|
return Promise.reject()
|
|
|
|
} else {
|
|
|
|
console.error('axios error', error.message)
|
|
|
|
return Promise.reject({ body: error.message })
|
|
|
|
}
|
2020-10-31 02:22:08 +01:00
|
|
|
})
|
2020-10-23 09:22:17 +02:00
|
|
|
}
|
2020-10-31 21:04:46 +01:00
|
|
|
|
|
|
|
export default client
|