Package Exports
- apollo-link-token-refresh
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (apollo-link-token-refresh) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Token Refresh Link 
Purpose
An Apollo Link that performs renew expired JWT (access tokens)
Installation
npm install apollo-link-token-refresh --save
Usage
Token Refresh Link is non-terminating link, which means that this link shouldn't be the last link in the composed chain.
import { TokenRefreshLink } from "apollo-link-token-refresh";
const link = new TokenRefreshLink({
accessTokenField: 'accessToken',
isTokenValidOrUndefined: () => boolean,
fetchAccessToken: () => Promise<Response>,
handleFetch: (accessToken: string) => void,
handleResponse?: (operation, accessTokenField) => response => any,
handleError?: (err: Error) => void,
});Options
Token Refresh Link takes an object with four options on it to customize the behavior of the link
| name | value | explanation |
|---|---|---|
| accessTokenField? | string | Default: access_token. This is a name of access token field in response. In some scenarios we want to pass additional payload with access token, i.e. new refresh token, so this field could be the object's name |
| isTokenValidOrUndefined | (...args: any[]) => boolean | Indicates the current state of access token expiration. If token not yet expired or user doesn't have a token (guest) true should be returned |
| fetchAccessToken | (...args: any[]) => Promise |
Function covers fetch call with request fresh access token |
| handleFetch | (accessToken: string) => void | Callback which receives a fresh token from Response. From here we can save token to the storage |
| handleResponse? | (operation, accessTokenField) => response => any | This is optional. It could be used to override internal function to manually parse and extract your token from server response |
| handleError? | (err: Error) => void | Token fetch error callback. Allows to run additional actions like logout. Don't forget to handle Error if you are using this option |
Example
import { TokenRefreshLink } from 'apollo-link-token-refresh';
link: ApolloLink.from([
new TokenRefreshLink({
isTokenValidOrUndefined: () => !isTokenExpired() || typeof getAccessToken() !== 'string',
fetchAccessToken: () => {
return fetch(getEndpoint('getAccessTokenPath'), {
method: 'GET',
headers: {
Authorization: `Bearer ${getAccessToken()}`,
'refresh-token': getRefreshToken()
}
});
},
handleFetch: accessToken => {
const accessTokenDecrypted = jwtDecode(accessToken);
setAccessToken(accessToken);
setExpiresIn(parseExp(accessTokenDecrypted.exp).toString());
},
handleResponse: (operation, accessTokenField) => response => {
// here you can parse response, handle errors, prepare returned token to
// further operations
// returned object should be like this:
// {
// access_token: 'token string here'
// }
},
handleError: err => {
// full control over handling token fetch Error
console.warn('Your refresh token is invalid. Try to relogin');
console.error(err);
// your custom action here
user.logout();
}
}),
errorLink,
requestLink,
...
])Context
The Token Refresh Link does not use the context for anything