Configuration
Axle fully supports all axios configuration. You can access the built-in axios instance via axle.axios to configure defaults, headers, timeouts, and interceptors.
Access Axios Instance
ts
import { createAxle } from 'rattail/axle'
const axle = createAxle({ baseURL: '/api' })
const axios = axle.axiosConfigure Defaults
ts
axios.defaults.timeout = 10000
axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest'Configure Headers
ts
axios.defaults.headers.common['Authorization'] = `Bearer ${token}`
axios.defaults.headers.post['Content-Type'] = 'application/json'Custom Interceptors via Axios
In addition to Axle's built-in interceptors, you can register interceptors directly on the axios instance.
ts
axios.interceptors.request.use(
(config) => {
config.headers['X-Timestamp'] = Date.now().toString()
return config
},
(error) => {
return Promise.reject(error)
},
)
axios.interceptors.response.use(
(response) => {
return response
},
(error) => {
if (error.response?.status === 401) {
window.location.href = '/login'
}
return Promise.reject(error)
},
)