Files
bio_frontend/composables/useApi.ts

46 lines
1.2 KiB
TypeScript
Raw Normal View History

import { useRuntimeConfig } from "#imports";
import { useUserStore } from "~/stores/user";
2025-08-08 13:11:33 +09:00
export const useApi = async <T>(
2025-08-08 13:11:33 +09:00
path: string,
options: {
method?: "get" | "post" | "put" | "delete";
body?: any;
query?: Record<string, any>;
headers?: HeadersInit;
2025-08-08 13:11:33 +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
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;
}
};