2024-03-08 14:58:36 +01:00
|
|
|
import { useQuery } from 'react-query'
|
|
|
|
import { useNavigate } from '@tanstack/react-router'
|
2024-03-07 19:16:23 +01:00
|
|
|
|
2024-03-08 14:58:36 +01:00
|
|
|
import {
|
|
|
|
Body_login_login_access_token as AccessToken,
|
|
|
|
LoginService,
|
|
|
|
UserOut,
|
|
|
|
UsersService,
|
|
|
|
} from '../client'
|
2024-03-07 19:16:23 +01:00
|
|
|
|
|
|
|
const isLoggedIn = () => {
|
2024-03-08 14:58:36 +01:00
|
|
|
return localStorage.getItem('access_token') !== null
|
|
|
|
}
|
2024-03-07 19:16:23 +01:00
|
|
|
|
|
|
|
const useAuth = () => {
|
2024-03-08 14:58:36 +01:00
|
|
|
const navigate = useNavigate()
|
|
|
|
const { data: user, isLoading } = useQuery<UserOut | null, Error>(
|
|
|
|
'currentUser',
|
|
|
|
UsersService.readUserMe,
|
|
|
|
{
|
|
|
|
enabled: isLoggedIn(),
|
|
|
|
},
|
|
|
|
)
|
2024-03-07 19:16:23 +01:00
|
|
|
|
2024-03-08 14:58:36 +01:00
|
|
|
const login = async (data: AccessToken) => {
|
|
|
|
const response = await LoginService.loginAccessToken({
|
|
|
|
formData: data,
|
|
|
|
})
|
|
|
|
localStorage.setItem('access_token', response.access_token)
|
|
|
|
navigate({ to: '/' })
|
|
|
|
}
|
2024-03-07 19:16:23 +01:00
|
|
|
|
2024-03-08 14:58:36 +01:00
|
|
|
const logout = () => {
|
|
|
|
localStorage.removeItem('access_token')
|
|
|
|
navigate({ to: '/login' })
|
|
|
|
}
|
2024-03-07 19:16:23 +01:00
|
|
|
|
2024-03-08 14:58:36 +01:00
|
|
|
return { login, logout, user, isLoading }
|
2024-03-07 19:16:23 +01:00
|
|
|
}
|
|
|
|
|
2024-03-08 14:58:36 +01:00
|
|
|
export { isLoggedIn }
|
|
|
|
export default useAuth
|