Skip to content
stoic man

Auth-guards in Next.js frontend

Redirecting if session or onboarding is needed

Outdated. Next 13 brought major changes

Session required

LoginRequired.tsx
import {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.tsx
import {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}</>;
};

All snippets