JS library for client side token renewal
npm install dis-authorisation-client-jsJS library for client side token renewal
* Run make help to see full list of make targets
1. Initialising with custom configuration.
You can call init with a custom config, this allows you to specify callbacks and settings.
See defaultConfig below for more details on what is provided in the default config:
``
import SessionManagement from 'dis-authorisation-client-js';
// Define configuration
const config = {
timeOffsets: { passiveRenewal: 300000 }, // Session renewal offset: 5 minutes
onRenewSuccess: (sessionExpiryTime, refreshExpiryTime) => {
console.debug([APP] Session renewed successfully! Session: ${sessionExpiryTime} and refresh: ${refreshExpiryTime});[APP] Session is valid. Session: ${sessionExpiryTime} and refresh: ${refreshExpiryTime}
},
onRenewFailure: (error) => {
console.error('[APP] Session renewal failed:', error);
},
onSessionValid: (sessionExpiryTime, refreshExpiryTime) => {
console.debug();
},
onSessionInvalid: () => {
console.warn('[APP] Session is invalid.');
},
onError: (error) => {
console.error('[APP] Error:', error);
},
};
// Initialise the SessionManagement library
SessionManagement.init(config);
`
2. Setting Session Expiry Times.
You can set the session and refresh expiry times either by creating default expiry times using createDefaultExpiryTimes or by setting them directly.
If init has not been called yet, the library will automatically initialise with default settings.
#### Using createDefaultExpiryTimes
You can create default expiry times for session and refresh using createDefaultExpiryTimes:
`
import SessionManagement, { createDefaultExpiryTimes } from 'dis-authorisation-client-js';
// Create default expiry times
const { session_expiry_time, refresh_expiry_time } = createDefaultExpiryTimes(12); // 12 hours
// Set the expiry timers
SessionManagement.setSessionExpiryTime(session_expiry_time, refresh_expiry_time);
`
#### Setting Expiry Times Directly
You can manually set the session and refresh expiry times using setSessionExpiryTime.
`
import SessionManagement from 'dis-authorisation-client-js';
// Define session and refresh expiry times
const sessionExpiryTime = new Date(new Date().getTime() + 60 60 1000); // 1 hour from now
const refreshExpiryTime = new Date(new Date().getTime() + 24 60 60 * 1000); // 24 hours from now
// Set the expiry timers
SessionManagement.setSessionExpiryTime(sessionExpiryTime, refreshExpiryTime);
`
If expiry times are found in local storage or cookies, those times will be used by default, even if provided times are not. You can also call setSessionExpiryTime without providing times, and the library will use the times found in local storage or cookies. To check if times need to be provided or not, you can use isSessionValid.
`
import { isSessionExpired } from 'dis-authorisation-client-js';
async function renewSession() {
const isExpired = await isSessionExpired();
if (isExpired) {
// Define session and refresh expiry times
const sessionExpiryTime = new Date(new Date().getTime() + 60 60 1000); // 1 hour from now
const refreshExpiryTime = new Date(new Date().getTime() + 24 60 60 * 1000); // 24 hours from now
// Set the expiry timers
SessionManagement.setSessionExpiryTime(sessionExpiryTime, refreshExpiryTime);
} else {
SessionManagement.setSessionExpiryTime();
}
}
`
* No further dependencies other than those defined in package.json
| Option | Type | Default Value | Description |
|---------------------|----------|---------------|-----------------------------------------------------------------------------|
| timeOffsets | Object | { passiveRenewal: 300000 } | Time offsets for session renewal in milliseconds. |onRenewSuccess
| | Function | (sessionExpiryTime, refreshExpiryTime) => console.debug('[LIBRARY] Session renewed successfully. Session: ${sessionExpiryTime} and refresh: ${refreshExpiryTime}') | Callback function to be called on successful session renewal. |onRenewFailure
| | Function | () => console.warn('[LIBRARY] Session renewal failed') | Callback function to be called on session renewal failure. |onSessionValid
| | Function | (sessionExpiryTime, refreshExpiryTime) => console.debug('[LIBRARY] Session Valid. Session: ${sessionExpiryTime} and refresh: ${refreshExpiryTime}') | Callback function to be called when the session is valid. |onSessionInvalid
| | Function | () => console.warn('[LIBRARY] Session is invalid') | Callback function to be called when the session is invalid. |apiEndpoints
| | String | { renewSession: "/api/v1/tokens/self" }` | The API endpoint for renewing the session. | |
See CONTRIBUTING for details.
Copyright © 2024, Office for National Statistics (https://www.ons.gov.uk)
Released under MIT license, see LICENSE for details.