route.ts 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. import { NextRequest, NextResponse } from 'next/server';
  2. import { LoginResponse } from '@/types/response/auth';
  3. const API_URL = process.env.API_URL;
  4. export async function POST(request: NextRequest)
  5. {
  6. // Google redirect 모드는 form data로 credential을 전송
  7. const formData = await request.formData();
  8. const credential = formData.get('credential') as string;
  9. if (!credential) {
  10. const url = new URL('/login', request.url);
  11. url.searchParams.set('error', 'Google 인증 정보가 없습니다.');
  12. return NextResponse.redirect(url);
  13. }
  14. // 백엔드 google-login API 직접 호출
  15. const res = await fetch(`${API_URL}/api/auth/google-login`, {
  16. method: 'POST',
  17. headers: { 'Content-Type': 'application/json', 'Accept': 'application/json' },
  18. body: JSON.stringify({ credential }),
  19. cache: 'no-store'
  20. });
  21. const json = await res.json();
  22. if (json.success && json.data) {
  23. const data = json.data as LoginResponse;
  24. const response = NextResponse.redirect(new URL('/login/google/complete', request.url));
  25. const cookieOptions = { httpOnly: true, path: '/' };
  26. response.cookies.set('accessToken', data.accessToken, cookieOptions);
  27. response.cookies.set('refreshToken', data.refreshToken, cookieOptions);
  28. return response;
  29. }
  30. // 실패 시 로그인 페이지로 리다이렉트
  31. const url = new URL('/login', request.url);
  32. url.searchParams.set('error', json.message || 'Google 로그인에 실패했습니다.');
  33. return NextResponse.redirect(url);
  34. }