|
| 1 | +// ky 인스턴스 래퍼함수 |
| 2 | + |
| 3 | +import { HTTPError } from "ky"; |
| 4 | +import { apiClient } from "@/apis/api-client"; |
| 5 | + |
| 6 | +export const HTTPMethod = { |
| 7 | + GET: "GET", |
| 8 | + POST: "POST", |
| 9 | + PUT: "PUT", |
| 10 | + DELETE: "DELETE", |
| 11 | + PATCH: "PATCH", |
| 12 | +} as const; |
| 13 | + |
| 14 | +export type HTTPMethodType = (typeof HTTPMethod)[keyof typeof HTTPMethod]; |
| 15 | +type QueryValue = string | number | boolean; |
| 16 | + |
| 17 | +export interface RequestConfig { |
| 18 | + method: HTTPMethodType; |
| 19 | + url: string; |
| 20 | + query?: Record<string, QueryValue>; |
| 21 | + body?: unknown; |
| 22 | +} |
| 23 | + |
| 24 | +// Success response: { code, message, data } |
| 25 | +interface SuccessResponse<T> { |
| 26 | + code: string; |
| 27 | + message: string; |
| 28 | + data: T; |
| 29 | +} |
| 30 | + |
| 31 | +// Error response: { code, message, messageDetail } |
| 32 | +interface ErrorResponse { |
| 33 | + code: string; |
| 34 | + message: string; |
| 35 | + messageDetail: string | null; |
| 36 | +} |
| 37 | + |
| 38 | +// ky 인스턴스 래퍼 함수 |
| 39 | +export const request = async <T>(config: RequestConfig): Promise<T> => { |
| 40 | + // T: 응답 성공 시 받는 데이터의 타입 |
| 41 | + const { method, url, query, body } = config; |
| 42 | + |
| 43 | + try { |
| 44 | + const response = await apiClient(url, { |
| 45 | + method, |
| 46 | + searchParams: query as Record<string, string | number | boolean>, |
| 47 | + json: method !== HTTPMethod.GET ? body : undefined, // 자동으로 헤더에 Content-Type: application/json 추가 |
| 48 | + }).json<SuccessResponse<T>>(); |
| 49 | + |
| 50 | + return response.data; // 성공 시 data 필드만 추출해서 반환 |
| 51 | + } catch (error: unknown) { |
| 52 | + if (error instanceof HTTPError) { |
| 53 | + const errorData = await error.response |
| 54 | + .json<ErrorResponse>() |
| 55 | + .catch(() => null); |
| 56 | + |
| 57 | + const errorMessage = errorData?.message || "에러 메시지 정의 X"; |
| 58 | + const errorCode = errorData?.code || "UNKNOWN_ERROR"; |
| 59 | + const errorMessageDetail = errorData?.messageDetail || "UNKNOWN_ERROR"; |
| 60 | + |
| 61 | + if (import.meta.env.DEV) { |
| 62 | + console.error(`[${errorCode}] ${url}`); |
| 63 | + console.error("errorMessage: ", errorMessage); |
| 64 | + console.error("errorMessageDetail", errorMessageDetail); |
| 65 | + } |
| 66 | + |
| 67 | + throw error; |
| 68 | + } |
| 69 | + |
| 70 | + if (import.meta.env.DEV) { |
| 71 | + console.error("네트워크 에러"); |
| 72 | + } |
| 73 | + |
| 74 | + throw error; |
| 75 | + } |
| 76 | +}; |
0 commit comments