Skip to content

rus-sharafiev/fetch-api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fetch with access token refresh

npm

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)

Install

npm i @russh/fetch-api

Usage

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) => ({
    ...
    })
})