From 1ded73a33bd2dc9300b52c22747b6e0c6f22cbfb Mon Sep 17 00:00:00 2001 From: bender Date: Wed, 11 Mar 2026 20:51:32 +0000 Subject: [PATCH] Add src/app/api/auth/verify/route.ts --- src/app/api/auth/verify/route.ts | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 src/app/api/auth/verify/route.ts diff --git a/src/app/api/auth/verify/route.ts b/src/app/api/auth/verify/route.ts new file mode 100644 index 0000000..b78bc59 --- /dev/null +++ b/src/app/api/auth/verify/route.ts @@ -0,0 +1,30 @@ +import { NextRequest, NextResponse } from "next/server"; +import jwt from "jsonwebtoken"; + +const JWT_SECRET = process.env.JWT_SECRET || "your-secret-key-change-in-production"; + +export async function GET(request: NextRequest) { + try { + const authHeader = request.headers.get("authorization"); + if (!authHeader || !authHeader.startsWith("Bearer ")) { + return NextResponse.json( + { message: "Token não fornecido" }, + { status: 401 } + ); + } + + const token = authHeader.substring(7); + const decoded = jwt.verify(token, JWT_SECRET) as any; + + return NextResponse.json( + { user: { id: decoded.id, email: decoded.email, name: decoded.name } }, + { status: 200 } + ); + } catch (error) { + console.error("Verify error:", error); + return NextResponse.json( + { message: "Token inválido ou expirado" }, + { status: 401 } + ); + } +} \ No newline at end of file