aboutsummaryrefslogtreecommitdiff
path: root/src/app/settings/page.tsx
diff options
context:
space:
mode:
authorschererleander <leander@schererleander.de>2025-12-26 16:24:36 +0100
committerschererleander <leander@schererleander.de>2025-12-26 16:24:36 +0100
commit67527c2f52e76725ad78719d4b0307e702bd0da1 (patch)
treec22ee317ce5afaa796593f11a3a2d3dff2d5ca66 /src/app/settings/page.tsx
parentca731fb137465408a3c1729c13d785f7857e67e0 (diff)
feat(2fa): implement google authenticator 2fa
- add otplib and qrcode dependencies - update user model with 2fa fields - add twoFactorCode to validation schema - implement api routes for setup, enable, disable - add 2fa verification in auth flow - add 2fa management ui in settings - implement 2fa challenge in login page
Diffstat (limited to 'src/app/settings/page.tsx')
-rw-r--r--src/app/settings/page.tsx32
1 files changed, 21 insertions, 11 deletions
diff --git a/src/app/settings/page.tsx b/src/app/settings/page.tsx
index 5d5fd92..75d9d3d 100644
--- a/src/app/settings/page.tsx
+++ b/src/app/settings/page.tsx
@@ -1,21 +1,31 @@
-import { redirect } from "next/navigation"
import { getServerSession } from "next-auth"
-
-import Navbar from "@/components/Navbar"
+import { redirect } from "next/navigation"
+import dbConnect from "@/lib/mongodb"
+import User from "@/model/User"
import { authOptions } from "@/lib/auth"
-import { SettingsForm } from "@/app/settings/settings-form"
+import SettingsContent from "./settings-content"
export default async function SettingsPage() {
const session = await getServerSession(authOptions)
- if (!session?.user) {
+ if (!session?.user?.email) {
redirect("/login")
}
- return (
- <div className="min-h-screen bg-background">
- <Navbar />
- <SettingsForm user={session.user} />
- </div>
- )
+ await dbConnect()
+ const user = await User.findOne({ email: session.user.email }).lean() as any
+
+ if (!user) {
+ redirect("/login")
+ }
+
+ // Sanitize user object for client component
+ const initialUser = {
+ name: user.name,
+ email: user.email,
+ image: user.profileImage?.url || null,
+ twoFactorEnabled: !!user.twoFactorEnabled,
+ }
+
+ return <SettingsContent initialUser={initialUser} />
}