1
0
Fork 0
mirror of https://gitlab.com/bramw/baserow.git synced 2025-04-29 06:49:55 +00:00
bramw_baserow/web-frontend/modules/core/middleware/authentication.js
2025-03-04 08:52:27 +00:00

31 lines
891 B
JavaScript

import {
getTokenIfEnoughTimeLeft,
setToken,
setUserSessionCookie,
} from '@baserow/modules/core/utils/auth'
export default function ({ store, req, app, route, redirect }) {
// If nuxt generate or already authenticated, pass this middleware
if ((process.server && !req) || store.getters['auth/isAuthenticated']) return
const userSession = route.query.user_session
if (userSession) {
setUserSessionCookie(app, userSession)
}
// token can be in the query string (SSO) or in the cookies (previous session)
let refreshToken = route.query.token
if (refreshToken) {
setToken(app, refreshToken)
} else {
refreshToken = getTokenIfEnoughTimeLeft(app)
}
if (refreshToken) {
return store.dispatch('auth/refresh', refreshToken).catch((error) => {
if (error.response?.status === 401) {
return redirect({ name: 'login' })
}
})
}
}