diff --git a/demo/react-spa-demo/src/App.jsx b/demo/react-spa-demo/src/App.jsx index c75cac8..d4d618a 100644 --- a/demo/react-spa-demo/src/App.jsx +++ b/demo/react-spa-demo/src/App.jsx @@ -21,6 +21,7 @@ function App() { const [userInfo, setUserInfo] = useState(null); const [authToken, setAuthToken] = useState(null); const [refreshMessage, setRefreshMessage] = useState(""); // State to show refresh token message + const [expiresIn, setExpiresIn] = useState(null); // State to display the expires_in time const oauthClient = new OAuthClient(config); @@ -43,6 +44,14 @@ function App() { if (refreshedToken) { setAuthToken(refreshedToken); setRefreshMessage("Token successfully refreshed!"); + + // Save the new token and its expiration time in localStorage + const expirationTime = new Date().getTime() + refreshedToken.expires_in * 1000; // Convert seconds to milliseconds + localStorage.setItem("authToken", JSON.stringify(refreshedToken)); + localStorage.setItem("tokenExpiration", expirationTime.toString()); + + // Update the expiresIn state + setExpiresIn(refreshedToken.expires_in); } else { setRefreshMessage("Failed to refresh token."); } @@ -58,6 +67,22 @@ function App() { setUserInfo(JSON.parse(storedUser)); } + // Check for the stored token and its expiration time + const storedToken = localStorage.getItem("authToken"); + const storedExpiration = localStorage.getItem("tokenExpiration"); + + if (storedToken && storedExpiration) { + const currentTime = new Date().getTime(); + if (currentTime < storedExpiration) { + setAuthToken(JSON.parse(storedToken)); + setExpiresIn((storedExpiration - currentTime) / 1000); // Convert ms to seconds + } else { + // Token expired, clear from localStorage + localStorage.removeItem("authToken"); + localStorage.removeItem("tokenExpiration"); + } + } + // Handle the OAuth callback after redirect with code in URL const urlParams = new URLSearchParams(window.location.search); const code = urlParams.get("code"); @@ -162,6 +187,13 @@ function App() { {refreshMessage}

)} + + {/* Display expires in time */} + {expiresIn && ( +

+ Token expires in {expiresIn} seconds. +

+ )}