6f723b1c29f7093c4b2aafd58ea9ce617eed700c
[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_add(media_tag_s *tag_s, media_tag_item_s *item_s);
21 static void __media_tag_item_release(media_tag_s *tag_s);
22 static int __media_tag_insert_item_to_tag(int tag_id, const char *media_id);
23 static int __media_tag_remove_item_from_tag(int tag_id, const char *media_id);
24 static int __media_tag_update_tag_name(int tag_id, const char *tag_name);
25 static int __media_tag_get_tag_info_from_db(const char *name, media_tag_h tag);
26
27 static void __media_tag_item_add(media_tag_s *tag_s, media_tag_item_s *item_s)
28 {
29         tag_s->item_list = g_list_append(tag_s->item_list, item_s);
30 }
31
32 static void __media_tag_item_release(media_tag_s *tag_s)
33 {
34         int idx = 0;
35         int list_cnt = 0;
36         media_tag_item_s *item = NULL;
37
38         list_cnt = g_list_length(tag_s->item_list);
39
40         media_content_debug("list_cnt : [%d]", list_cnt);
41
42         for (idx = 0; idx < list_cnt; idx++) {
43                 item = (media_tag_item_s*)g_list_nth_data(tag_s->item_list, idx);
44                 if (item != NULL) {
45                         SAFE_FREE(item->media_id);
46                         SAFE_FREE(item->tag_name);
47                         SAFE_FREE(item);
48                 }
49         }
50
51         g_list_free(tag_s->item_list);
52         tag_s->item_list = NULL;
53
54 }
55
56 static int __media_tag_insert_item_to_tag(int tag_id, const char *media_id)
57 {
58         int ret = MEDIA_CONTENT_ERROR_NONE;
59         char *query_str = NULL;
60
61         query_str = sqlite3_mprintf("INSERT OR IGNORE INTO %q (tag_id, media_id) values (%d, '%q');", DB_TABLE_TAG_MAP, tag_id, media_id);
62         ret = media_svc_append_query(query_str, _content_get_uid());
63
64         return _content_error_capi(ret);
65 }
66
67 static int __media_tag_remove_item_from_tag(int tag_id, const char *media_id)
68 {
69         int ret = MEDIA_CONTENT_ERROR_NONE;
70         char *query_str = NULL;
71
72         query_str = sqlite3_mprintf(REMOVE_TAG_ITEM_FROM_TAG_MAP, tag_id, media_id);
73         ret = media_svc_append_query(query_str, _content_get_uid());
74
75         return _content_error_capi(ret);
76 }
77
78 static int __media_tag_update_tag_name(int tag_id, const char *tag_name)
79 {
80         int ret = MEDIA_CONTENT_ERROR_NONE;
81         char *query_str = NULL;
82
83         query_str = sqlite3_mprintf(UPDATE_TAG_NAME_FROM_TAG, tag_name, tag_id);
84         ret = media_svc_append_query(query_str, _content_get_uid());
85
86         return _content_error_capi(ret);
87 }
88
89 static int __media_tag_get_tag_info_from_db(const char *name, media_tag_h tag)
90 {
91         int ret = MEDIA_CONTENT_ERROR_NONE;
92         sqlite3_stmt *stmt = NULL;
93         char *select_query = NULL;
94         media_tag_s *_tag = (media_tag_s*)tag;
95
96         media_content_retvm_if(_tag == NULL, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid tag");
97
98         select_query = sqlite3_mprintf(SELECT_TAG_BY_NAME, name);
99
100         ret = _content_get_result(select_query, &stmt);
101         SQLITE3_SAFE_FREE(select_query);
102         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
103
104         if (sqlite3_step(stmt) == SQLITE_ROW) {
105                 _tag->tag_id = (int)sqlite3_column_int(stmt, 0);
106                 _tag->name = g_strdup(name);
107         } else {
108                 media_content_error("Nonexistent tag name[%s]", name);
109                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
110         }
111
112         SQLITE3_FINALIZE(stmt);
113
114         return ret;
115 }
116
117 int media_tag_insert_to_db(const char *tag_name, media_tag_h *tag)
118 {
119         int ret = MEDIA_CONTENT_ERROR_NONE;
120         char *query_str = NULL;
121
122         if (!STRING_VALID(tag_name)) {
123                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
124                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
125         }
126
127         query_str = sqlite3_mprintf(INSERT_TAG_TO_TAG, tag_name);
128         ret = _content_query_sql(query_str);
129         SQLITE3_SAFE_FREE(query_str);
130
131         if (ret == MEDIA_CONTENT_ERROR_NONE) {
132                 media_tag_s *_tag = (media_tag_s*)calloc(1, sizeof(media_tag_s));
133                 media_content_retvm_if(_tag == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
134
135                 ret = __media_tag_get_tag_info_from_db(tag_name, (media_tag_h)_tag);
136                 *tag = (media_tag_h)_tag;
137         }
138
139         return ret;
140 }
141
142 int media_tag_delete_from_db(int tag_id)
143 {
144         int ret = MEDIA_CONTENT_ERROR_NONE;
145         char *query_str = NULL;
146
147         if (tag_id < 0) {
148                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
149                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
150         }
151
152         query_str = sqlite3_mprintf(DELETE_TAG_FROM_TAG, tag_id);
153
154         ret = _content_query_sql(query_str);
155
156         SQLITE3_SAFE_FREE(query_str);
157
158         return ret;
159 }
160
161 int media_tag_get_tag_count_from_db(filter_h filter, int *tag_count)
162 {
163         int ret = MEDIA_CONTENT_ERROR_NONE;
164
165         if (tag_count != NULL) {
166                 ret = _media_db_get_group_count(filter, MEDIA_GROUP_TAG, tag_count);
167         } else {
168                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
169                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
170         }
171
172         return ret;
173 }
174
175 int media_tag_foreach_tag_from_db(filter_h filter, media_tag_cb callback, void *user_data)
176 {
177         int ret = MEDIA_CONTENT_ERROR_NONE;
178
179         if (callback == NULL) {
180                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
181                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
182         }
183
184         ret = _media_db_get_tag(NULL, filter, callback, user_data);
185
186         return ret;
187 }
188
189 int media_tag_get_media_count_from_db(int tag_id, filter_h filter, int *media_count)
190 {
191         int ret = MEDIA_CONTENT_ERROR_NONE;
192
193         if ((tag_id > 0) && (media_count != NULL)) {
194                 ret = _media_db_get_group_item_count_by_id(tag_id, filter, MEDIA_GROUP_TAG, media_count);
195         } else {
196                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
197                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
198         }
199
200         return ret;
201 }
202
203 int media_tag_foreach_media_from_db(int tag_id, filter_h filter, media_info_cb callback, void *user_data)
204 {
205         int ret = MEDIA_CONTENT_ERROR_NONE;
206
207         if (callback == NULL) {
208                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
209                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
210         }
211
212         ret = _media_db_get_group_item_by_id(tag_id, filter, callback, user_data, MEDIA_GROUP_TAG);
213
214         return ret;
215 }
216
217 int media_tag_destroy(media_tag_h tag)
218 {
219         int ret = MEDIA_CONTENT_ERROR_NONE;
220         media_tag_s *_tag = (media_tag_s*)tag;
221         if (_tag) {
222                 SAFE_FREE(_tag->name);
223                 SAFE_FREE(_tag);
224                 ret = MEDIA_CONTENT_ERROR_NONE;
225         } else {
226                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
227                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
228         }
229
230         return ret;
231 }
232
233 int media_tag_clone(media_tag_h *dst, media_tag_h src)
234 {
235         int ret = MEDIA_CONTENT_ERROR_NONE;
236         media_tag_s *_src = (media_tag_s*)src;
237         media_tag_s *_dst = NULL;
238
239         if ((_src != NULL)) {
240                 _dst = (media_tag_s*)calloc(1, sizeof(media_tag_s));
241                 media_content_retvm_if(_dst == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
242
243                 _dst->tag_id = _src->tag_id;
244
245                 if (STRING_VALID(_src->name)) {
246                         _dst->name = strdup(_src->name);
247                         if (_dst->name == NULL) {
248                                 SAFE_FREE(_dst);
249                                 media_content_error("OUT_OF_MEMORY(0x%08x)", MEDIA_CONTENT_ERROR_OUT_OF_MEMORY);
250                                 return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
251                         }
252                 }
253                 *dst = (media_tag_h)_dst;
254                 ret = MEDIA_CONTENT_ERROR_NONE;
255         } else {
256                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
257                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
258         }
259
260         return ret;
261 }
262
263 int media_tag_get_tag_id(media_tag_h tag, int *tag_id)
264 {
265         int ret = MEDIA_CONTENT_ERROR_NONE;
266         media_tag_s *_tag = (media_tag_s*)tag;
267
268         if ((_tag != NULL) && (tag_id != NULL)) {
269                 *tag_id = _tag->tag_id;
270                 ret = MEDIA_CONTENT_ERROR_NONE;
271         } else {
272                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
273                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
274         }
275
276         return ret;
277 }
278
279 int media_tag_get_name(media_tag_h tag, char **name)
280 {
281         int ret = MEDIA_CONTENT_ERROR_NONE;
282         media_tag_s *_tag = (media_tag_s*)tag;
283         if (_tag) {
284                 if (STRING_VALID(_tag->name)) {
285                         *name = strdup(_tag->name);
286                         media_content_retvm_if(*name == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
287                 } else {
288                         *name = NULL;
289                 }
290                 ret = MEDIA_CONTENT_ERROR_NONE;
291
292         } else {
293                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
294                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
295         }
296
297         return ret;
298 }
299
300 int media_tag_get_tag_from_db(int tag_id, media_tag_h *tag)
301 {
302         int ret = MEDIA_CONTENT_ERROR_NONE;
303         sqlite3_stmt *stmt = NULL;
304         char select_query[DEFAULT_QUERY_SIZE] = {0, };
305
306         if (tag_id <= 0) {
307                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
308                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
309         }
310
311         memset(select_query, 0x00, sizeof(select_query));
312
313         snprintf(select_query, sizeof(select_query), SELECT_TAG_FROM_TAG, tag_id);
314
315         ret = _content_get_result(select_query, &stmt);
316         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
317
318         media_tag_s *_tag = NULL;
319
320         if (sqlite3_step(stmt) == SQLITE_ROW) {
321                 _tag = (media_tag_s*)calloc(1, sizeof(media_tag_s));
322                 if (_tag == NULL) {
323                         SQLITE3_FINALIZE(stmt);
324                         media_content_error("OUT_OF_MEMORY(0x%08x)", MEDIA_CONTENT_ERROR_OUT_OF_MEMORY);
325                         return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
326                 }
327
328                 _tag->tag_id = tag_id;
329                 _tag->name = g_strdup((const char *)sqlite3_column_text(stmt, 0));
330
331                 *tag = (media_tag_h)_tag;
332         } else {
333                 media_content_error("Nonexistent tag id[%d]", tag_id);
334                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
335         }
336
337         SQLITE3_FINALIZE(stmt);
338
339         return ret;
340 }
341
342 int media_tag_add_media(media_tag_h tag, const char *media_id)
343 {
344         int ret = MEDIA_CONTENT_ERROR_NONE;
345         media_tag_s *_tag = (media_tag_s*)tag;
346
347         if ((_tag != NULL) && STRING_VALID(media_id)) {
348                 media_tag_item_s *_item = (media_tag_item_s*)calloc(1, sizeof(media_tag_item_s));
349                 media_content_retvm_if(_item == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
350
351                 _item->media_id = strdup(media_id);
352                 _item->function = MEDIA_TAG_ADD;
353
354                 if (_item->media_id == NULL) {
355                         SAFE_FREE(_item);
356                         media_content_error("OUT_OF_MEMORY(0x%08x)", MEDIA_CONTENT_ERROR_OUT_OF_MEMORY);
357                         return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
358                 }
359
360                 __media_tag_item_add(_tag, _item);
361         } else {
362                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
363                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
364         }
365
366         return ret;
367 }
368
369 int media_tag_remove_media(media_tag_h tag, const char *media_id)
370 {
371         int ret = MEDIA_CONTENT_ERROR_NONE;
372         media_tag_s *_tag = (media_tag_s*)tag;
373
374         if (_tag != NULL && STRING_VALID(media_id)) {
375                 media_tag_item_s *_item = (media_tag_item_s*)calloc(1, sizeof(media_tag_item_s));
376                 media_content_retvm_if(_item == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
377
378                 _item->media_id = strdup(media_id);
379                 _item->function = MEDIA_TAG_REMOVE;
380
381                 if (_item->media_id == NULL) {
382                         SAFE_FREE(_item);
383                         media_content_error("OUT_OF_MEMORY(0x%08x)", MEDIA_CONTENT_ERROR_OUT_OF_MEMORY);
384                         return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
385                 }
386
387                 __media_tag_item_add(_tag, _item);
388         } else {
389                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
390                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
391         }
392
393         return ret;
394 }
395
396 int media_tag_set_name(media_tag_h tag, const char *tag_name)
397 {
398         int ret = MEDIA_CONTENT_ERROR_NONE;
399         media_tag_s *_tag = (media_tag_s*)tag;
400
401         if (_tag != NULL && STRING_VALID(tag_name)) {
402                 SAFE_FREE(_tag->name);
403
404                 media_tag_item_s *_item = (media_tag_item_s*)calloc(1, sizeof(media_tag_item_s));
405                 media_content_retvm_if(_item == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
406
407                 _item->tag_name = strdup(tag_name);
408                 _item->function = MEDIA_TAG_UPDATE_TAG_NAME;
409
410                 if (_item->tag_name == NULL) {
411                         SAFE_FREE(_item);
412                         media_content_error("OUT_OF_MEMORY(0x%08x)", MEDIA_CONTENT_ERROR_OUT_OF_MEMORY);
413                         return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
414                 }
415
416                 _tag->name = strdup(tag_name);
417                 if (_tag->name == NULL) {
418                         SAFE_FREE(_item->tag_name);
419                         SAFE_FREE(_item);
420                         media_content_error("OUT_OF_MEMORY(0x%08x)", MEDIA_CONTENT_ERROR_OUT_OF_MEMORY);
421                         return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
422                 }
423
424                 __media_tag_item_add(_tag, _item);
425         } else {
426                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
427                 ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
428         }
429
430         return ret;
431 }
432
433 int media_tag_update_to_db(media_tag_h tag)
434 {
435         int ret = MEDIA_CONTENT_ERROR_NONE;
436         media_tag_s *_tag = (media_tag_s*)tag;
437         int idx = 0;
438         int length = 0;
439         media_tag_item_s *_tag_item = NULL;
440
441         if (_tag == NULL) {
442                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
443                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
444         }
445
446         if (_tag->item_list != NULL) {
447                 length = g_list_length(_tag->item_list);
448         } else {
449                 media_content_debug("operation list length is 0");
450                 return MEDIA_CONTENT_ERROR_NONE;
451         }
452
453         for (idx = 0; idx < length; idx++) {
454                 _tag_item = (media_tag_item_s*)g_list_nth_data(_tag->item_list, idx);
455                 if (_tag_item != NULL) {
456                         switch (_tag_item->function) {
457                         case MEDIA_TAG_ADD:
458                         {
459                                 ret = __media_tag_insert_item_to_tag(_tag->tag_id, _tag_item->media_id);
460                         }
461                         break;
462
463                         case MEDIA_TAG_REMOVE:
464                         {
465                                 ret = __media_tag_remove_item_from_tag(_tag->tag_id, _tag_item->media_id);
466                         }
467                         break;
468
469                         case MEDIA_TAG_UPDATE_TAG_NAME:
470                         {
471                                 ret = __media_tag_update_tag_name(_tag->tag_id, _tag_item->tag_name);
472                         }
473                         break;
474
475                         default:
476                         break;
477                         }
478
479                         if (ret != MEDIA_CONTENT_ERROR_NONE)
480                                 media_content_error("Failed some operation[%d]", _tag_item->function);
481                 }
482         }
483
484         ret = media_svc_send_query(_content_get_uid());
485
486         __media_tag_item_release(_tag);
487
488         return _content_error_capi(ret);
489 }
490
491 int media_tag_create(media_tag_h *tag)
492 {
493         int ret = MEDIA_CONTENT_ERROR_NONE;
494
495         media_content_retvm_if(tag == NULL, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid tag");
496
497         media_tag_s *_tag = (media_tag_s*)calloc(1, sizeof(media_tag_s));
498         media_content_retvm_if(_tag == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
499
500         _tag->tag_id = -1;
501         _tag->name = NULL;
502         _tag->item_list = NULL;
503
504         *tag = (media_tag_h)_tag;
505
506         return ret;
507 }
508
509 int media_tag_insert_to_db_v2(media_tag_h tag)
510 {
511         int ret = MEDIA_CONTENT_ERROR_NONE;
512         media_tag_s *_tag = (media_tag_s*)tag;
513         media_tag_h tag_1;
514         int tag_id = -1;
515
516         media_content_retvm_if(_tag == NULL, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid tag");
517         media_content_retvm_if(!STRING_VALID(_tag->name), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid tag name");
518         media_content_retvm_if(_tag->tag_id != -1, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid tag insert");
519
520         ret = media_tag_insert_to_db(_tag->name, &tag_1);
521         if (ret != MEDIA_CONTENT_ERROR_NONE) {
522                 media_content_error("fail media_tag_insert_to_db");
523                 goto ERROR;
524         }
525
526         ret = media_tag_get_tag_id(tag_1, &tag_id);
527         if (ret != MEDIA_CONTENT_ERROR_NONE) {
528                 media_content_error("fail media_tag_get_tag_id");
529                 goto ERROR;
530         }
531
532          _tag->tag_id = tag_id;
533
534         ret = media_tag_update_to_db(tag);
535
536 ERROR:
537         __media_tag_item_release(_tag);
538         media_tag_destroy(tag_1);
539
540         return ret;
541 }
542
543 int media_tag_update_to_db_v2(int tag_id, media_tag_h tag)
544 {
545         media_tag_s *_tag = (media_tag_s*)tag;
546
547         media_content_retvm_if(_tag == NULL, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid tag");
548         media_content_retvm_if(tag_id == -1, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid tag update");
549
550         _tag->tag_id = tag_id;
551
552         return media_tag_update_to_db(tag);
553 }