-
Notifications
You must be signed in to change notification settings - Fork 118
Expand file tree
/
Copy pathapi.js
More file actions
160 lines (149 loc) · 3.94 KB
/
api.js
File metadata and controls
160 lines (149 loc) · 3.94 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
// API 서비스 - 백엔드와의 통신을 담당
import {
mockGetPosts,
mockGetPost,
mockCreatePost,
mockUpdatePost,
mockDeletePost,
mockGetComments,
mockCreateComment,
mockLikePost,
mockUnlikePost
} from './mockData';
const API_URL = 'http://localhost:8000/api';
// 백엔드 API 사용 여부 (false면 목업 데이터 사용)
const USE_REAL_API = true;
// 포스트 관련 API 함수
export const getPosts = async () => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts`);
if (!response.ok) {
throw new Error('포스트를 불러오는데 실패했습니다');
}
return response.json();
} else {
return mockGetPosts();
}
};
export const getPost = async (postId) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts/${postId}`);
if (!response.ok) {
throw new Error('포스트를 불러오는데 실패했습니다');
}
return response.json();
} else {
return mockGetPost(postId);
}
};
export const createPost = async (postData) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts`, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(postData)
});
if (!response.ok) {
throw new Error('포스트 작성에 실패했습니다');
}
return response.json();
} else {
return mockCreatePost(postData);
}
};
export const updatePost = async (postId, postData) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts/${postId}`, {
method: 'PATCH',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(postData)
});
if (!response.ok) {
throw new Error('포스트 수정에 실패했습니다');
}
return response.json();
} else {
return mockUpdatePost(postId, postData);
}
};
export const deletePost = async (postId) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts/${postId}`, {
method: 'DELETE'
});
if (!response.ok) {
throw new Error('포스트 삭제에 실패했습니다');
}
return true;
} else {
return mockDeletePost(postId);
}
};
// 댓글 관련 API 함수
export const getComments = async (postId) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts/${postId}/comments`);
if (!response.ok) {
throw new Error('댓글을 불러오는데 실패했습니다');
}
return response.json();
} else {
return mockGetComments(postId);
}
};
export const createComment = async (postId, commentData) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts/${postId}/comments`, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(commentData)
});
if (!response.ok) {
throw new Error('댓글 작성에 실패했습니다');
}
return response.json();
} else {
return mockCreateComment(postId, commentData);
}
};
// 좋아요 관련 API 함수
export const likePost = async (postId, userData) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts/${postId}/likes`, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(userData)
});
if (!response.ok) {
throw new Error('좋아요에 실패했습니다');
}
return true;
} else {
return mockLikePost(postId, userData);
}
};
export const unlikePost = async (postId, userData) => {
if (USE_REAL_API) {
const response = await fetch(`${API_URL}/posts/${postId}/likes`, {
method: 'DELETE',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(userData)
});
if (!response.ok) {
throw new Error('좋아요 취소에 실패했습니다');
}
return true;
} else {
return mockUnlikePost(postId, userData);
}
};