Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
76 changes: 76 additions & 0 deletions src/app/my/_services/deleteUser.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
'use server';

import { cookies } from 'next/headers';
import axios from 'axios';
import refreshAccessToken from '@/lib/refreshToken';

// 기본 헤더 구성
const getHeaders = (token: string, cookieString?: string) => ({
Authorization: `Bearer ${token}`,
Cookie: cookieString || '', // 쿠키를 헤더에 포함
'Content-Type': 'application/json',
});

// my : 고객 회원 탈퇴
export default async function deleteUser() {
const cookieStore = cookies();

// 요청할 주소
const url = `${process.env.NEXT_PUBLIC_BASE_URL}/api/customer/delete`;

try {
// 1. Access Token 가져오기
const accessToken = (await cookieStore).get('accessToken')?.value;
const cookieString = (await cookieStore)
.getAll()
.map((c) => `${c.name}=${c.value}`)
.join('; ');

if (!accessToken) {
throw new Error('Access token is missing');
}

console.log(accessToken);
// 2. 첫 번째 요청 시도
const response = await axios.patch(
url,
{},
{
headers: getHeaders(accessToken, cookieString),
withCredentials: true, // 서버와 쿠키 공유
},
);

if (response.status === 200) {
return response.data;
}

return '회원 탈퇴에 실패했습니다.';
// eslint-disable-next-line @typescript-eslint/no-explicit-any
} catch (error: any) {
// 3. 401 오류 발생 시 토큰 갱신
if (error.response?.status === 401) {
const newAccessToken = await refreshAccessToken();

// 4. 갱신된 토큰으로 재요청
const retryResponse = await axios.patch(
url,
{},
{
headers: getHeaders(newAccessToken),
withCredentials: true,
},
);

if (retryResponse.status === 200) {
return retryResponse.data;
}

return '회원 탈퇴에 실패했습니다.';
}

// 5. 기타 오류 처리
console.error('Error uploading content:', error);
throw error;
}
}
19 changes: 14 additions & 5 deletions src/app/my/_services/getUserInfo.ts
Original file line number Diff line number Diff line change
Expand Up @@ -152,15 +152,24 @@ export async function deleteUser() {
// console.log(accessToken);

// 2. 첫 번째 요청 시도
const response = await axios.patch(url, {
headers: getHeaders(accessToken || ''),
});
const response = await axios.patch(
url,
{},
{
headers: getHeaders(accessToken || ''),
},
);

console.log(response);

if (response.status === 200) {
return response;
const logoutResponse = await axios.post(
`${process.env.NEXT_PUBLIC_BASE_URL}/logout`,
);
return logoutResponse;
}

return '회원정보 수정에 실패했습니다.';
return '회원 탈퇴에 실패했습니다.';

// eslint-disable-next-line @typescript-eslint/no-explicit-any
} catch (error: any) {
Expand Down
3 changes: 2 additions & 1 deletion src/app/my/editinfo/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import {
import RightChevronIcon from '@/assets/RightChevronIcon';
import { useMutation, useQuery } from '@tanstack/react-query';
import { UpdateUserInfoProps, UserInfoProps } from '@/types/user';

import {
deleteUser,
getUserInfo,
Expand Down Expand Up @@ -82,7 +83,7 @@ export default function EditProfile() {
},
});

// 회원 정보 업데이트 함수수
// 회원 정보 업데이트 함수
const updateUserMutation = useMutation({
mutationKey: ['updateUserInfo'],
mutationFn: updateUserInfo,
Expand Down