master
Tudor Stanciu 2020-12-24 16:13:10 +02:00
parent cff580648a
commit 8580f10b0a
3 changed files with 15 additions and 4 deletions

View File

@ -26,7 +26,8 @@ const useStyles = makeStyles(() => ({
minHeight: "100vh", minHeight: "100vh",
display: "flex", display: "flex",
flexDirection: "column", flexDirection: "column",
justifyContent: "center" justifyContent: "center",
alignItems: "center"
} }
})); }));

View File

@ -14,7 +14,7 @@ const LoginContainer = () => {
const dispatchActions = useContext(ApplicationDispatchContext); const dispatchActions = useContext(ApplicationDispatchContext);
const { error } = useToast(); const { error } = useToast();
const { t } = useTranslation(); const { t } = useTranslation();
const { tokenIsValid } = useAuthorizationToken(); const { tokenIsValid, invalidateToken } = useAuthorizationToken();
const handleChange = prop => event => { const handleChange = prop => event => {
dispatchActions.onCredentialsChange(prop, event.target.value); dispatchActions.onCredentialsChange(prop, event.target.value);
@ -37,6 +37,7 @@ const LoginContainer = () => {
const handleLogout = () => { const handleLogout = () => {
invalidate(); invalidate();
invalidateToken();
}; };
return ( return (

View File

@ -1,8 +1,12 @@
import { useContext } from "react"; import { useContext } from "react";
import { ApplicationStateContext } from "../state/ApplicationContexts"; import {
ApplicationStateContext,
ApplicationDispatchContext
} from "../state/ApplicationContexts";
export const useAuthorizationToken = () => { export const useAuthorizationToken = () => {
const state = useContext(ApplicationStateContext); const state = useContext(ApplicationStateContext);
const dispatchActions = useContext(ApplicationDispatchContext);
const getToken = () => state.security.authorization.token; const getToken = () => state.security.authorization.token;
const validateToken = () => { const validateToken = () => {
@ -16,5 +20,10 @@ export const useAuthorizationToken = () => {
}; };
const tokenIsValid = validateToken(); const tokenIsValid = validateToken();
return { getToken, validateToken, tokenIsValid };
const invalidateToken = () => {
dispatchActions.onAuthorizationTokenChange(null);
};
return { getToken, validateToken, tokenIsValid, invalidateToken };
}; };