Files
bio_frontend/stores/user.ts

113 lines
2.5 KiB
TypeScript
Raw Permalink Normal View History

export const useUserStore = defineStore(
"user",
() => {
// 상태
const isLoggedIn = ref(false);
const user = ref<{
userId?: string;
name?: string;
} | null>(null);
const token = ref<string | null>(null);
2025-08-08 13:11:33 +09:00
// 추후 제거 필요
const isAdmin = true;
2025-08-22 14:01:30 +09:00
interface LoginData {
userId: string;
}
// 액션
const login = async (userId: string, password: string) => {
try {
// 실제 API 호출로 대체할 수 있습니다
2025-08-27 17:06:25 +09:00
const { success, data } = await useApi<ApiResponse<LoginData>>(
"/login",
{
method: "post",
body: { userId, password },
}
);
2025-08-08 13:11:33 +09:00
if (success) {
user.value = data;
isLoggedIn.value = true;
} else {
throw new Error("아이디 또는 비밀번호가 올바르지 않습니다.");
}
2025-08-22 14:01:30 +09:00
return { success };
} catch (error: any) {
console.log(error);
return {
success: false,
error:
error?.response?.status === 401
? "아이디 또는 비밀번호가 올바르지 않습니다."
: error instanceof Error
? error.message
: "로그인에 실패했습니다.",
};
}
};
2025-08-08 13:11:33 +09:00
const logout = async () => {
try {
await useApi("/members/logout", {
method: "post",
});
} catch (error) {
console.error("로그아웃 요청 실패:", error);
} finally {
// 로컬 상태 정리
user.value = null;
isLoggedIn.value = false;
}
};
2025-08-08 13:11:33 +09:00
const checkAuth = () => {
// 페이지 로드 시 로컬 스토리지에서 사용자 정보 복원
const savedUser = localStorage.getItem("user");
const savedToken = localStorage.getItem("token");
2025-08-08 13:11:33 +09:00
if (savedUser && savedToken) {
user.value = JSON.parse(savedUser);
token.value = savedToken;
isLoggedIn.value = true;
}
};
2025-08-08 13:11:33 +09:00
const setToken = (accessToken: string) => {
token.value = accessToken;
};
2025-08-27 17:06:25 +09:00
const getToken = () => {
return token;
};
2025-08-27 17:06:25 +09:00
// 초기 인증 상태 확인
if (import.meta.client) {
checkAuth();
}
2025-08-08 13:11:33 +09:00
return {
// 상태
isLoggedIn,
user,
token,
2025-08-08 13:11:33 +09:00
// 게터
isAdmin,
2025-08-08 13:11:33 +09:00
// 액션
login,
logout,
checkAuth,
setToken,
getToken,
};
},
{
persist: true,
}
);