umami/src/components/hooks/useRequireLogin.ts

31 lines
728 B
TypeScript
Raw Normal View History

2023-01-05 06:20:24 +01:00
import { useEffect } from 'react';
import { useRouter } from 'next/router';
import useApi from 'components/hooks/useApi';
import useUser from 'components/hooks/useUser';
2023-01-05 06:20:24 +01:00
2023-08-23 21:50:18 +02:00
export function useRequireLogin(handler: (data?: object) => void) {
2023-09-22 03:37:40 +02:00
const { basePath } = useRouter();
2023-01-05 06:20:24 +01:00
const { get } = useApi();
const { user, setUser } = useUser();
useEffect(() => {
async function loadUser() {
try {
2023-08-23 21:50:18 +02:00
const data = await get('/auth/verify');
2023-01-05 06:20:24 +01:00
2023-08-23 21:50:18 +02:00
setUser(typeof handler === 'function' ? handler(data) : (data as any)?.user);
2023-01-05 06:20:24 +01:00
} catch {
2023-09-22 03:37:40 +02:00
location.href = `${basePath}/login`;
2023-01-05 06:20:24 +01:00
}
}
if (!user) {
loadUser();
}
}, [user]);
return { user };
}
2023-05-18 08:20:06 +02:00
export default useRequireLogin;