e9c9e97dea02d020b46cbbe371e28754a8ff9c9e
[platform/core/api/media-content.git] / src / media_tag.c
1 /*
2 * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17
18 #include <media_info_private.h>
19
20 static void __media_tag_item_free(gpointer item)
21 {
22         media_tag_item_s *_item = (media_tag_item_s *)item;
23
24         g_free(_item->media_id);
25         g_free(_item->tag_name);
26         g_free(_item);
27 }
28
29 static void __media_tag_item_release(media_tag_s *tag)
30 {
31         if (!tag || !tag->item_list)
32                 return;
33
34         g_list_free_full(tag->item_list, __media_tag_item_free);
35         tag->item_list = NULL;
36 }
37
38 static int __media_tag_insert_item_to_tag(int tag_id, const char *media_id)
39 {
40         int ret = MEDIA_CONTENT_ERROR_NONE;
41         char *query_str = NULL;
42
43         query_str = sqlite3_mprintf("INSERT OR IGNORE INTO %q (tag_id, media_id) values (%d, '%q');", DB_TABLE_TAG_MAP, tag_id, media_id);
44         ret = media_svc_append_query(query_str, _content_get_uid());
45
46         return _content_error_capi(ret);
47 }
48
49 static int __media_tag_remove_item_from_tag(int tag_id, const char *media_id)
50 {
51         int ret = MEDIA_CONTENT_ERROR_NONE;
52         char *query_str = NULL;
53
54         query_str = sqlite3_mprintf(REMOVE_TAG_ITEM_FROM_TAG_MAP, tag_id, media_id);
55         ret = media_svc_append_query(query_str, _content_get_uid());
56
57         return _content_error_capi(ret);
58 }
59
60 static int __media_tag_update_tag_name(int tag_id, const char *tag_name)
61 {
62         int ret = MEDIA_CONTENT_ERROR_NONE;
63         char *query_str = NULL;
64
65         query_str = sqlite3_mprintf(UPDATE_TAG_NAME_FROM_TAG, tag_name, tag_id);
66         ret = media_svc_append_query(query_str, _content_get_uid());
67
68         return _content_error_capi(ret);
69 }
70
71 static int __media_tag_get_tag_info_from_db(const char *name, media_tag_h tag)
72 {
73         int ret = MEDIA_CONTENT_ERROR_NONE;
74         sqlite3_stmt *stmt = NULL;
75         char *select_query = NULL;
76         media_tag_s *_tag = (media_tag_s *)tag;
77
78         content_retip_if_fail(tag);
79
80         select_query = sqlite3_mprintf(SELECT_TAG_BY_NAME, name);
81
82         ret = _content_get_result(select_query, &stmt);
83         SQLITE3_SAFE_FREE(select_query);
84         content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
85
86         if (sqlite3_step(stmt) == SQLITE_ROW) {
87                 _tag->tag_id = sqlite3_column_int(stmt, 0);
88                 _tag->name = g_strdup(name);
89         } else {
90                 content_error("Nonexistent tag name[%s]", name);
91                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
92         }
93
94         SQLITE3_FINALIZE(stmt);
95
96         return ret;
97 }
98
99 int media_tag_insert_to_db(const char *tag_name, media_tag_h *tag)
100 {
101         int ret = MEDIA_CONTENT_ERROR_NONE;
102         char *query_str = NULL;
103         media_tag_s *_tag = NULL;
104
105         content_retip_if_fail(STRING_VALID(tag_name));
106         content_retip_if_fail(tag);
107
108         query_str = sqlite3_mprintf(INSERT_TAG_TO_TAG, tag_name);
109         ret = _content_query_sql(query_str);
110         SQLITE3_SAFE_FREE(query_str);
111         content_retvm_if(ret != MEDIA_CONTENT_ERROR_NONE, ret, "fail to insert tag");
112
113         _tag = g_new0(media_tag_s, 1);
114
115         ret = __media_tag_get_tag_info_from_db(tag_name, (media_tag_h)_tag);
116         *tag = (media_tag_h)_tag;
117
118         return ret;
119 }
120
121 int media_tag_delete_from_db(int tag_id)
122 {
123         int ret = MEDIA_CONTENT_ERROR_NONE;
124         char *query_str = NULL;
125
126         content_retipm_if_fail(tag_id > 0, "%d", tag_id);
127
128         query_str = sqlite3_mprintf(DELETE_TAG_FROM_TAG, tag_id);
129         ret = _content_query_sql(query_str);
130
131         SQLITE3_SAFE_FREE(query_str);
132
133         return ret;
134 }
135
136 int media_tag_get_tag_count_from_db(filter_h filter, int *tag_count)
137 {
138         content_retip_if_fail(tag_count);
139
140         return _media_db_get_group_count(filter, MEDIA_GROUP_TAG, tag_count);
141 }
142
143 int media_tag_foreach_tag_from_db(filter_h filter, media_tag_cb callback, void *user_data)
144 {
145         content_retip_if_fail(callback);
146
147         return _media_db_get_tag(NULL, filter, callback, user_data);
148 }
149
150 int media_tag_get_media_count_from_db(int tag_id, filter_h filter, int *media_count)
151 {
152         content_retipm_if_fail(tag_id > 0, "%d", tag_id);
153         content_retip_if_fail(media_count);
154
155         return _media_db_get_group_item_count_by_id(tag_id, filter, MEDIA_GROUP_TAG, media_count);
156 }
157
158 int media_tag_foreach_media_from_db(int tag_id, filter_h filter, media_info_cb callback, void *user_data)
159 {
160         content_retip_if_fail(callback);
161
162         return _media_db_get_group_item_by_id(tag_id, filter, callback, user_data, MEDIA_GROUP_TAG);
163 }
164
165 int media_tag_destroy(media_tag_h tag)
166 {
167         media_tag_s *_tag = (media_tag_s *)tag;
168
169         content_retip_if_fail(tag);
170
171         g_free(_tag->name);
172         g_free(_tag);
173
174         return MEDIA_CONTENT_ERROR_NONE;
175 }
176
177 int media_tag_clone(media_tag_h *dst, media_tag_h src)
178 {
179         media_tag_s *_src = (media_tag_s *)src;
180         media_tag_s *_dst = NULL;
181
182         content_retip_if_fail(src);
183         content_retip_if_fail(dst);
184
185         _dst = g_new0(media_tag_s, 1);
186
187         _dst->tag_id = _src->tag_id;
188         _dst->name = g_strdup(_src->name);
189
190         *dst = (media_tag_h)_dst;
191
192         return MEDIA_CONTENT_ERROR_NONE;
193 }
194
195 int media_tag_get_tag_id(media_tag_h tag, int *tag_id)
196 {
197         media_tag_s *_tag = (media_tag_s *)tag;
198
199         content_retip_if_fail(tag);
200         content_retip_if_fail(tag_id);
201
202         *tag_id = _tag->tag_id;
203
204         return MEDIA_CONTENT_ERROR_NONE;
205 }
206
207 int media_tag_get_name(media_tag_h tag, char **name)
208 {
209         media_tag_s *_tag = (media_tag_s *)tag;
210
211         content_retip_if_fail(tag);
212         content_retip_if_fail(name);
213
214         *name = g_strdup(_tag->name);
215
216         return MEDIA_CONTENT_ERROR_NONE;
217 }
218
219 int media_tag_get_tag_from_db(int tag_id, media_tag_h *tag)
220 {
221         int ret = MEDIA_CONTENT_ERROR_NONE;
222         sqlite3_stmt *stmt = NULL;
223         char *query = NULL;
224         media_tag_s *_tag = NULL;
225
226         content_retipm_if_fail(tag_id > 0, "%d", tag_id);
227         content_retip_if_fail(tag);
228
229         query = sqlite3_mprintf(SELECT_TAG_FROM_TAG, tag_id);
230         ret = _content_get_result(query, &stmt);
231         SQLITE3_SAFE_FREE(query);
232         content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
233
234         if (sqlite3_step(stmt) == SQLITE_ROW) {
235                 _tag = g_new0(media_tag_s, 1);
236
237                 _tag->tag_id = tag_id;
238                 _tag->name = g_strdup((const char *)sqlite3_column_text(stmt, 0));
239
240                 *tag = (media_tag_h)_tag;
241         } else {
242                 content_error("Nonexistent tag id[%d]", tag_id);
243                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
244         }
245
246         SQLITE3_FINALIZE(stmt);
247
248         return ret;
249 }
250
251 int media_tag_add_media(media_tag_h tag, const char *media_id)
252 {
253         int ret = MEDIA_CONTENT_ERROR_NONE;
254         media_tag_s *_tag = (media_tag_s *)tag;
255         media_tag_item_s *_item = NULL;
256
257         content_retip_if_fail(tag);
258         content_retip_if_fail(STRING_VALID(media_id));
259
260         _item = g_new0(media_tag_item_s, 1);
261
262         _item->media_id = g_strdup(media_id);
263         _item->function = MEDIA_TAG_ADD;
264
265         _tag->item_list = g_list_append(_tag->item_list, _item);
266
267         return ret;
268 }
269
270 int media_tag_remove_media(media_tag_h tag, const char *media_id)
271 {
272         int ret = MEDIA_CONTENT_ERROR_NONE;
273         media_tag_s *_tag = (media_tag_s *)tag;
274         media_tag_item_s *_item = NULL;
275
276         content_retip_if_fail(tag);
277         content_retip_if_fail(STRING_VALID(media_id));
278
279         _item = g_new0(media_tag_item_s, 1);
280
281         _item->media_id = g_strdup(media_id);
282         _item->function = MEDIA_TAG_REMOVE;
283
284         _tag->item_list = g_list_append(_tag->item_list, _item);
285
286         return ret;
287 }
288
289 int media_tag_set_name(media_tag_h tag, const char *tag_name)
290 {
291         int ret = MEDIA_CONTENT_ERROR_NONE;
292         media_tag_s *_tag = (media_tag_s *)tag;
293         media_tag_item_s *_item = NULL;
294
295         content_retip_if_fail(tag);
296         content_retip_if_fail(STRING_VALID(tag_name));
297
298         g_free(_tag->name);
299
300         _item = g_new0(media_tag_item_s, 1);
301
302         _item->tag_name = g_strdup(tag_name);
303         _item->function = MEDIA_TAG_UPDATE_TAG_NAME;
304
305         _tag->name = g_strdup(tag_name);
306
307         _tag->item_list = g_list_append(_tag->item_list, _item);
308
309         return ret;
310 }
311
312 void __media_tag_foreach_request(gpointer data, gpointer user_data)
313 {
314         int ret = MEDIA_CONTENT_ERROR_NONE;
315         media_tag_item_s *_tag_item = (media_tag_item_s *)data;
316         int tag_id = GPOINTER_TO_INT(user_data);
317
318         if (!_tag_item)
319                 return;
320
321         switch (_tag_item->function) {
322         case MEDIA_TAG_ADD:
323                 ret = __media_tag_insert_item_to_tag(tag_id, _tag_item->media_id);
324                 break;
325
326         case MEDIA_TAG_REMOVE:
327                 ret = __media_tag_remove_item_from_tag(tag_id, _tag_item->media_id);
328                 break;
329
330         case MEDIA_TAG_UPDATE_TAG_NAME:
331                 ret = __media_tag_update_tag_name(tag_id, _tag_item->tag_name);
332                 break;
333
334         default:
335                 break;
336         }
337
338         if (ret != MEDIA_CONTENT_ERROR_NONE)
339                 content_error("Failed some operation[%d]", _tag_item->function);
340 }
341
342 int media_tag_update_to_db(media_tag_h tag)
343 {
344         int ret = MEDIA_CONTENT_ERROR_NONE;
345         media_tag_s *_tag = (media_tag_s *)tag;
346
347         content_retip_if_fail(tag);
348         content_retvm_if(_tag->item_list == NULL, MEDIA_CONTENT_ERROR_NONE, "operation list length is 0");
349
350         g_list_foreach(_tag->item_list, __media_tag_foreach_request, GINT_TO_POINTER(_tag->tag_id));
351
352         ret = media_svc_send_query(_content_get_uid());
353
354         __media_tag_item_release(_tag);
355
356         return _content_error_capi(ret);
357 }
358
359 int media_tag_create(media_tag_h *tag)
360 {
361         content_retip_if_fail(tag);
362
363         media_tag_s *_tag = g_new0(media_tag_s, 1);
364
365         _tag->tag_id = -1;
366         _tag->name = NULL;
367         _tag->item_list = NULL;
368
369         *tag = (media_tag_h)_tag;
370
371         return MEDIA_CONTENT_ERROR_NONE;
372 }
373
374 int media_tag_insert_to_db_v2(media_tag_h tag)
375 {
376         int ret = MEDIA_CONTENT_ERROR_NONE;
377         media_tag_s *_tag = (media_tag_s *)tag;
378         media_tag_h tag_1;
379         int tag_id = -1;
380
381         content_retip_if_fail(tag);
382         content_retip_if_fail(STRING_VALID(_tag->name));
383         content_retip_if_fail(_tag->tag_id == -1);
384
385         ret = media_tag_insert_to_db(_tag->name, &tag_1);
386         if (ret != MEDIA_CONTENT_ERROR_NONE) {
387                 content_error("fail media_tag_insert_to_db");
388                 goto ERROR;
389         }
390
391         ret = media_tag_get_tag_id(tag_1, &tag_id);
392         if (ret != MEDIA_CONTENT_ERROR_NONE) {
393                 content_error("fail media_tag_get_tag_id");
394                 goto ERROR;
395         }
396
397          _tag->tag_id = tag_id;
398
399         ret = media_tag_update_to_db(tag);
400
401 ERROR:
402         __media_tag_item_release(_tag);
403         media_tag_destroy(tag_1);
404
405         return ret;
406 }
407
408 int media_tag_update_to_db_v2(int tag_id, media_tag_h tag)
409 {
410         media_tag_s *_tag = (media_tag_s *)tag;
411
412         content_retip_if_fail(tag);
413         content_retip_if_fail(tag_id > 0);
414
415         _tag->tag_id = tag_id;
416
417         return media_tag_update_to_db(tag);
418 }