Version 3 of the kit: - Radix UI replaced with Base UI (using the Shadcn UI patterns) - next-intl replaces react-i18next - enhanceAction deprecated; usage moved to next-safe-action - main layout now wrapped with [locale] path segment - Teams only mode - Layout updates - Zod v4 - Next.js 16.2 - Typescript 6 - All other dependencies updated - Removed deprecated Edge CSRF - Dynamic Github Action runner
25 lines
845 B
TypeScript
25 lines
845 B
TypeScript
import 'server-only';
|
|
import { cache } from 'react';
|
|
|
|
import { redirect } from 'next/navigation';
|
|
|
|
import { requireUser } from '@kit/supabase/require-user';
|
|
import { getSupabaseServerClient } from '@kit/supabase/server-client';
|
|
|
|
/**
|
|
* @name requireUserInServerComponent
|
|
* @description Require the user to be authenticated in a server component.
|
|
* We reuse this function in multiple server components - it is cached so that the data is only fetched once per request.
|
|
* Use this instead of `requireUser` in server components, so you don't need to hit the database multiple times in a single request.
|
|
*/
|
|
export const requireUserInServerComponent = cache(async () => {
|
|
const client = getSupabaseServerClient();
|
|
const result = await requireUser(client);
|
|
|
|
if (result.error) {
|
|
redirect(result.redirectTo);
|
|
}
|
|
|
|
return result.data;
|
|
});
|