mirror of
https://github.com/swissmakers/swiss-datashare.git
synced 2026-04-17 12:43:13 +02:00
fix: reduce refresh access token calls
This commit is contained in:
@@ -50,7 +50,12 @@ function App({ Component, pageProps }: AppProps) {
|
|||||||
}, [router.pathname]);
|
}, [router.pathname]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
setInterval(async () => await authService.refreshAccessToken(), 30 * 1000);
|
const interval = setInterval(
|
||||||
|
async () => await authService.refreshAccessToken(),
|
||||||
|
2 * 60 * 1000, // 2 minutes
|
||||||
|
);
|
||||||
|
|
||||||
|
return () => clearInterval(interval);
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
|||||||
@@ -36,8 +36,10 @@ const signOut = async () => {
|
|||||||
const refreshAccessToken = async () => {
|
const refreshAccessToken = async () => {
|
||||||
try {
|
try {
|
||||||
const accessToken = getCookie("access_token") as string;
|
const accessToken = getCookie("access_token") as string;
|
||||||
|
|
||||||
|
// If the access token expires in less than 2 minutes refresh it
|
||||||
if (
|
if (
|
||||||
!accessToken ||
|
accessToken &&
|
||||||
(jose.decodeJwt(accessToken).exp ?? 0) * 1000 < Date.now() + 2 * 60 * 1000
|
(jose.decodeJwt(accessToken).exp ?? 0) * 1000 < Date.now() + 2 * 60 * 1000
|
||||||
) {
|
) {
|
||||||
await api.post("/auth/token");
|
await api.post("/auth/token");
|
||||||
|
|||||||
Reference in New Issue
Block a user