Outdated. Next 13 brought major changes Session required LoginRequired.tsximport {useRouter} from 'next/router'; import {useSession} from 'next-auth/client'; import {useEffect} from 'react'; import {useQueryClient} from 'react-query'; import {Spinner} from '@/f/components/spinner'; import {SIGN_IN_PAGE} from '@/f/constants/pages'; export const LoginRequired: React.FC = ({children}) => { const queryClient = useQueryClient(); const [session, isSessionLoading] = useSession(); const router = useRouter(); useEffect(() => { if (!session && !isSessionLoading) { queryClient.clear(); router.push(SIGN_IN_PAGE); } }, [session, isSessionLoading, router, queryClient]); if (isSessionLoading) { return ( <div className="mt-16 flex min-h-screen flex-col items-center space-y-4 pt-16"> <Spinner /> <span className="text-sm text-gray-600">Getting things ready..</span> </div> ); } // prevent any flicker if (!session) { return null; } return <>{children}</>; }; Membership required MembershipRequired.tsximport {useRouter} from 'next/router'; import {useEffect} from 'react'; import {ONBOARDING_PAGE} from '@/f/constants/pages'; import {useCurrentUser} from '@/f/requests/current-user'; export const MembershipRequired: React.FC = ({children}) => { const {user} = useCurrentUser(); const router = useRouter(); useEffect(() => { if (user && !user.membership) { router.push(ONBOARDING_PAGE); } }, [user, router]); return <>{children}</>; };