A simple wrapper around the Fetch API with
- Access token refresh on 401 response status
- Shorthands
- RTK baseQuery
- JSON to FormData converter (requires custom middleware on backend)
npm i @russh/fetch-api
First create an instance of the FetchApi class with a base URL and optionally a path name to refresh the access token.
const api = new FetchApi('https://example.com', '/refresh-token')
Then use full declaration...
const result = await api.fetch({ url: '/path', method: 'POST', body: { foo: 'bar' } })
...or shorthand to get fetch data
await api.get('/path')
await api.post('/path', { foo: 'bar' })
await api.patch('/path/id', { foo: 'bar' })
await api.delete('/path/id')
The instance also contains fetch-api based RTK baseQuery
export const apiName = createApi({
reducerPath: 'apiName',
baseQuery: api.baseQuery,
endpoints: (builder) => ({
...
})
})