- Adicionar indexes compostos em lancamentos para queries frequentes - Eliminar ~20 JOINs com pagadores via helper cacheado getAdminPagadorId() - Consolidar queries: income-expense-balance (12→1), payment-status (2→1), categories (4→2) - Adicionar cache cross-request via unstable_cache com tag-based invalidation - Limitar scan de métricas a 24 meses - Deduplicar auth session por request via React.cache() Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
67 lines
1.5 KiB
TypeScript
67 lines
1.5 KiB
TypeScript
import { headers } from "next/headers";
|
|
import { redirect } from "next/navigation";
|
|
import { cache } from "react";
|
|
import { auth } from "@/lib/auth/config";
|
|
|
|
/**
|
|
* Cached session fetch - deduplicates auth calls within a single request.
|
|
* Layout + page calling getUser() will only hit auth once.
|
|
*/
|
|
const getSessionCached = cache(async () => {
|
|
return auth.api.getSession({ headers: await headers() });
|
|
});
|
|
|
|
/**
|
|
* Gets the current authenticated user
|
|
* @returns User object
|
|
* @throws Redirects to /login if user is not authenticated
|
|
*/
|
|
export async function getUser() {
|
|
const session = await getSessionCached();
|
|
|
|
if (!session?.user) {
|
|
redirect("/login");
|
|
}
|
|
|
|
return session.user;
|
|
}
|
|
|
|
/**
|
|
* Gets the current authenticated user ID
|
|
* @returns User ID string
|
|
* @throws Redirects to /login if user is not authenticated
|
|
*/
|
|
export async function getUserId() {
|
|
const session = await getSessionCached();
|
|
|
|
if (!session?.user) {
|
|
redirect("/login");
|
|
}
|
|
|
|
return session.user.id;
|
|
}
|
|
|
|
/**
|
|
* Gets the current authenticated session
|
|
* @returns Full session object including user
|
|
* @throws Redirects to /login if user is not authenticated
|
|
*/
|
|
export async function getUserSession() {
|
|
const session = await getSessionCached();
|
|
|
|
if (!session?.user) {
|
|
redirect("/login");
|
|
}
|
|
|
|
return session;
|
|
}
|
|
|
|
/**
|
|
* Gets the current session without requiring authentication
|
|
* @returns Session object or null if not authenticated
|
|
* @note This function does not redirect if user is not authenticated
|
|
*/
|
|
export async function getOptionalUserSession() {
|
|
return getSessionCached();
|
|
}
|