fix: introduce fix for token management

This commit is contained in:
kasia.oczkowska
2024-04-04 14:16:25 +01:00
parent 0930c9d8d6
commit 526e093689
6 changed files with 18 additions and 29 deletions

View File

@@ -1,31 +1,34 @@
import * as React from 'react';
import { getItem, setItem } from 'helpers/storage';
import { getItem, removeItem, setItem } from 'helpers/storage';
import api from 'helpers/api.js';
export const AuthenticationContext = React.createContext({
token: null,
updateToken: () => void 0,
updateToken: () => {},
removeToken: () => {},
isAuthenticated: false,
initialize: () => void 0,
});
export const AuthenticationProvider = (props) => {
const { children } = props;
const [isInitialized, setInitialized] = React.useState(false);
const [token, setToken] = React.useState(() => getItem('token'));
const value = React.useMemo(() => {
return {
token,
updateToken: (newToken) => {
api.defaults.headers.Authorization = newToken;
setToken(newToken);
setItem('token', newToken);
},
isAuthenticated: Boolean(token) && isInitialized,
initialize: () => {
setInitialized(true);
removeToken: () => {
delete api.defaults.headers.Authorization;
setToken(null);
removeItem('token');
},
isAuthenticated: Boolean(token),
};
}, [token, isInitialized]);
}, [token]);
return (
<AuthenticationContext.Provider value={value}>