|
|
|
import { notification } from 'ant-design-vue'
|
|
|
|
import type { Actions, State } from './types'
|
|
|
|
import { useNuxtApp } from '#imports'
|
|
|
|
|
|
|
|
export function useGlobalActions(state: State): Actions {
|
|
|
|
// todo replace with just `new Api()`? Would solve recursion issues
|
|
|
|
/** we have to use the globally injected api instance, otherwise we run into recursion as `useApi` calls `useGlobal` */
|
|
|
|
const { $api } = useNuxtApp()
|
|
|
|
|
|
|
|
/** Sign out by deleting the token from localStorage */
|
|
|
|
const signOut: Actions['signOut'] = () => {
|
|
|
|
state.token.value = null
|
|
|
|
state.user.value = null
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Sign in by setting the token in localStorage */
|
|
|
|
const signIn: Actions['signIn'] = async (newToken) => {
|
|
|
|
state.token.value = newToken
|
|
|
|
|
|
|
|
if (state.jwtPayload.value) {
|
|
|
|
state.user.value = {
|
|
|
|
id: state.jwtPayload.value.id,
|
|
|
|
email: state.jwtPayload.value.email,
|
|
|
|
firstname: state.jwtPayload.value.firstname,
|
|
|
|
lastname: state.jwtPayload.value.lastname,
|
|
|
|
roles: state.jwtPayload.value.roles,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** manually try to refresh token */
|
|
|
|
const refreshToken = async () => {
|
|
|
|
$api.instance
|
|
|
|
.post('/auth/refresh-token', null, {
|
|
|
|
withCredentials: true,
|
|
|
|
})
|
|
|
|
.then((response) => {
|
|
|
|
if (response.data?.token) {
|
|
|
|
signIn(response.data.token)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
notification.error({
|
|
|
|
// todo: add translation
|
|
|
|
message: err.message || 'You have been signed out.',
|
|
|
|
})
|
|
|
|
console.error(err)
|
|
|
|
|
|
|
|
signOut()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return { signIn, signOut, refreshToken }
|
|
|
|
}
|