Files
full-stack-fastapi-template/frontend/src/hooks/useAuth.ts

43 lines
946 B
TypeScript
Raw Normal View History

2024-03-08 14:58:36 +01:00
import { useQuery } from 'react-query'
import { useNavigate } from '@tanstack/react-router'
2024-03-08 14:58:36 +01:00
import {
Body_login_login_access_token as AccessToken,
LoginService,
UserOut,
UsersService,
} from '../client'
const isLoggedIn = () => {
2024-03-08 14:58:36 +01:00
return localStorage.getItem('access_token') !== null
}
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-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-08 14:58:36 +01:00
const logout = () => {
localStorage.removeItem('access_token')
navigate({ to: '/login' })
}
2024-03-08 14:58:36 +01:00
return { login, logout, user, isLoading }
}
2024-03-08 14:58:36 +01:00
export { isLoggedIn }
export default useAuth