2025-08-28 16:00:25 +09:00
|
|
|
import { useRuntimeConfig } from "#imports";
|
|
|
|
import { useUserStore } from "~/stores/user";
|
2025-08-08 13:11:33 +09:00
|
|
|
|
2025-08-28 16:00:25 +09:00
|
|
|
export const useApi = async <T>(
|
2025-08-08 13:11:33 +09:00
|
|
|
path: string,
|
|
|
|
options: {
|
2025-08-28 16:00:25 +09:00
|
|
|
method?: "get" | "post" | "put" | "delete";
|
|
|
|
body?: any;
|
|
|
|
query?: Record<string, any>;
|
|
|
|
headers?: HeadersInit;
|
2025-08-08 13:11:33 +09:00
|
|
|
} = {}
|
2025-08-28 16:00:25 +09:00
|
|
|
): Promise<T> => {
|
2025-08-27 17:06:25 +09:00
|
|
|
const userStore = useUserStore();
|
|
|
|
const config = useRuntimeConfig();
|
2025-08-08 13:11:33 +09:00
|
|
|
|
2025-08-28 16:00:25 +09:00
|
|
|
const method = options.method ? options.method.toUpperCase() : "GET";
|
|
|
|
|
|
|
|
try {
|
|
|
|
const response = await $fetch<T>(
|
|
|
|
`${config.public.apiBase}${config.public.contextPath}${path}`,
|
|
|
|
{
|
|
|
|
method: method as any,
|
|
|
|
body: options.body,
|
|
|
|
query: options.query,
|
|
|
|
headers: {
|
|
|
|
Authorization: "Bearer " + userStore.token,
|
|
|
|
...options.headers,
|
|
|
|
},
|
|
|
|
onResponse({ response }) {
|
|
|
|
const authHeader = response.headers.get("Authorization");
|
|
|
|
|
|
|
|
if (authHeader && authHeader.startsWith("Bearer ")) {
|
|
|
|
const accessToken = authHeader.substring(7);
|
|
|
|
userStore.setToken(accessToken);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
return response;
|
|
|
|
} catch (error) {
|
|
|
|
console.error("API 호출 실패:", error);
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
};
|