All checks were successful
CI / test-go-consent (push) Successful in 42s
CI / test-python-voice (push) Successful in 30s
CI / test-bqas (push) Successful in 30s
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / Deploy (push) Successful in 2s
Adds /pitch-admin dashboard with real bcrypt admin accounts and full audit attribution for every state-changing action. - pitch_admins + pitch_admin_sessions tables (migration 002) - pitch_audit_logs.admin_id + target_investor_id columns - lib/admin-auth.ts: bcryptjs, single-session, jose JWT with audience claim - middleware.ts: two-cookie gating with bearer-secret CLI fallback - 14 new API routes (admin-auth, dashboard, investor detail/edit/resend, admins CRUD, fm scenarios + assumptions PATCH) - 9 admin pages: login, dashboard, investors list/new/[id], audit, financial-model list/[id], admins - Bootstrap CLI: npm run admin:create - 36 vitest tests covering auth, admin-auth, rate-limit primitives Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
19 lines
525 B
TypeScript
19 lines
525 B
TypeScript
import { redirect } from 'next/navigation'
|
|
import { getAdminFromCookie } from '@/lib/admin-auth'
|
|
import AdminShell from '@/components/pitch-admin/AdminShell'
|
|
|
|
export const dynamic = 'force-dynamic'
|
|
|
|
export default async function AuthedAdminLayout({ children }: { children: React.ReactNode }) {
|
|
const admin = await getAdminFromCookie()
|
|
if (!admin) {
|
|
redirect('/pitch-admin/login')
|
|
}
|
|
|
|
return (
|
|
<AdminShell admin={{ id: admin.id, email: admin.email, name: admin.name }}>
|
|
{children}
|
|
</AdminShell>
|
|
)
|
|
}
|