|
|
|
@@ -14,7 +14,6 @@ const useRefreshToken = () => { |
|
|
|
const router = useRouter() |
|
|
|
const timer = useRef<NodeJS.Timeout>() |
|
|
|
const advanceTime = useRef<number>(5 * 60 * 1000) |
|
|
|
const interval = useRef<number>(55 * 60 * 1000) |
|
|
|
|
|
|
|
const getExpireTime = useCallback((token: string) => { |
|
|
|
if (!token) |
|
|
|
@@ -31,18 +30,24 @@ const useRefreshToken = () => { |
|
|
|
localStorage?.removeItem('is_refreshing') |
|
|
|
localStorage?.removeItem('console_token') |
|
|
|
localStorage?.removeItem('refresh_token') |
|
|
|
localStorage?.removeItem('last_refresh_time') |
|
|
|
router.replace('/signin') |
|
|
|
}, []) |
|
|
|
|
|
|
|
const getNewAccessToken = useCallback(async (currentAccessToken: string, currentRefreshToken: string) => { |
|
|
|
if (localStorage?.getItem('is_refreshing') === '1') |
|
|
|
const getNewAccessToken = useCallback(async () => { |
|
|
|
const currentAccessToken = localStorage?.getItem('console_token') |
|
|
|
const currentRefreshToken = localStorage?.getItem('refresh_token') |
|
|
|
if (!currentAccessToken || !currentRefreshToken) { |
|
|
|
handleError() |
|
|
|
return new Error('No access token or refresh token found') |
|
|
|
} |
|
|
|
if (localStorage?.getItem('is_refreshing') === '1') { |
|
|
|
timer.current = setTimeout(() => { |
|
|
|
getNewAccessToken() |
|
|
|
}, 1000) |
|
|
|
return null |
|
|
|
} |
|
|
|
const currentTokenExpireTime = getExpireTime(currentAccessToken) |
|
|
|
let lastRefreshTime = parseInt(localStorage?.getItem('last_refresh_time') || '0') |
|
|
|
lastRefreshTime = isNaN(lastRefreshTime) ? 0 : lastRefreshTime |
|
|
|
if (getCurrentTimeStamp() + advanceTime.current > currentTokenExpireTime |
|
|
|
&& lastRefreshTime + interval.current < getCurrentTimeStamp()) { |
|
|
|
if (getCurrentTimeStamp() + advanceTime.current > currentTokenExpireTime) { |
|
|
|
localStorage?.setItem('is_refreshing', '1') |
|
|
|
const [e, res] = await fetchWithRetry(fetchNewToken({ |
|
|
|
body: { refresh_token: currentRefreshToken }, |
|
|
|
@@ -53,24 +58,17 @@ const useRefreshToken = () => { |
|
|
|
} |
|
|
|
const { access_token, refresh_token } = res.data |
|
|
|
localStorage?.setItem('is_refreshing', '0') |
|
|
|
localStorage?.setItem('last_refresh_time', getCurrentTimeStamp().toString()) |
|
|
|
localStorage?.setItem('console_token', access_token) |
|
|
|
localStorage?.setItem('refresh_token', refresh_token) |
|
|
|
const newTokenExpireTime = getExpireTime(access_token) |
|
|
|
timer.current = setTimeout(() => { |
|
|
|
const consoleTokenFromLocalStorage = localStorage?.getItem('console_token') |
|
|
|
const refreshTokenFromLocalStorage = localStorage?.getItem('refresh_token') |
|
|
|
if (consoleTokenFromLocalStorage && refreshTokenFromLocalStorage) |
|
|
|
getNewAccessToken(consoleTokenFromLocalStorage, refreshTokenFromLocalStorage) |
|
|
|
getNewAccessToken() |
|
|
|
}, newTokenExpireTime - advanceTime.current - getCurrentTimeStamp()) |
|
|
|
} |
|
|
|
else { |
|
|
|
const newTokenExpireTime = getExpireTime(currentAccessToken) |
|
|
|
timer.current = setTimeout(() => { |
|
|
|
const consoleTokenFromLocalStorage = localStorage?.getItem('console_token') |
|
|
|
const refreshTokenFromLocalStorage = localStorage?.getItem('refresh_token') |
|
|
|
if (consoleTokenFromLocalStorage && refreshTokenFromLocalStorage) |
|
|
|
getNewAccessToken(consoleTokenFromLocalStorage, refreshTokenFromLocalStorage) |
|
|
|
getNewAccessToken() |
|
|
|
}, newTokenExpireTime - advanceTime.current - getCurrentTimeStamp()) |
|
|
|
} |
|
|
|
return null |
|
|
|
@@ -80,7 +78,6 @@ const useRefreshToken = () => { |
|
|
|
return () => { |
|
|
|
clearTimeout(timer.current) |
|
|
|
localStorage?.removeItem('is_refreshing') |
|
|
|
localStorage?.removeItem('last_refresh_time') |
|
|
|
} |
|
|
|
}, []) |
|
|
|
|