Bug fix when using filter for bookmark and face
[platform/core/api/media-content.git] / src / media_content.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 #include <media_util_private.h>
20
21
22 static attribute_h g_attr_handle = NULL;
23 static attribute_h g_alias_attr_handle = NULL;
24 static MediaSvcHandle *db_handle = NULL;
25 static int ref_count = 0;
26 static GMutex db_mutex;
27 static __thread media_noti_cb_s *g_noti_info = NULL;
28
29 static int __media_content_create_attr_handle(void);
30 static int __media_content_create_alias_attr_handle(void);
31 static int __media_content_create_attribute_handle(void);
32 static int __media_content_destroy_attribute_handle(void);
33
34 static int __media_content_create_attr_handle(void)
35 {
36         int ret = MEDIA_CONTENT_ERROR_NONE;
37
38         ret = _media_filter_attribute_create(&g_attr_handle);
39         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
40
41         /* Media Info */
42         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ID, DB_FIELD_MEDIA_ID);
43         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
44
45         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_PATH, DB_FIELD_MEDIA_PATH);
46         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
47
48         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_DISPLAY_NAME, DB_FIELD_MEDIA_DISPLAY_NAME);
49         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
50
51         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_TYPE, DB_FIELD_MEDIA_TYPE);
52         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
53
54         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_MIME_TYPE, DB_FIELD_MEDIA_MIME_TYPE);
55         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
56
57         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_SIZE, DB_FIELD_MEDIA_SIZE);
58         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
59
60         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ADDED_TIME, DB_FIELD_MEDIA_ADDED_TIME);
61         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
62
63         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_MODIFIED_TIME, DB_FIELD_MEDIA_MODIFIED_TIME);
64         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
65
66         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_TIMELINE, DB_FIELD_MEDIA_TIMELINE);
67         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
68
69         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_THUMBNAIL_PATH, DB_FIELD_MEDIA_THUMBNAIL_PATH);
70         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
71
72         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_TITLE, DB_FIELD_MEDIA_TITLE);
73         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
74
75         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ALBUM, DB_FIELD_MEDIA_ALBUM);
76         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
77
78         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ARTIST, DB_FIELD_MEDIA_ARTIST);
79         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
80
81         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ALBUM_ARTIST, DB_FIELD_MEDIA_ALBUM_ARTIST);
82         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
83
84         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_GENRE, DB_FIELD_MEDIA_GENRE);
85         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
86
87         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_COMPOSER, DB_FIELD_MEDIA_COMPOSER);
88         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
89
90         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_YEAR, DB_FIELD_MEDIA_YEAR);
91         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
92
93         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_RECORDED_DATE, DB_FIELD_MEDIA_RECORDED_DATE);
94         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
95
96         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_COPYRIGHT, DB_FIELD_MEDIA_COPYRIGHT);
97         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
98
99         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_TRACK_NUM, DB_FIELD_MEDIA_TRACK_NUM);
100         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
101
102         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_DESCRIPTION, DB_FIELD_MEDIA_DESCRIPTION);
103         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
104
105         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_BITRATE, DB_FIELD_MEDIA_BITRATE);
106         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
107
108         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_BITPERSAMPLE, DB_FIELD_MEDIA_BITPERSAMPLE);
109         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
110
111         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_SAMPLERATE, DB_FIELD_MEDIA_SAMPLERATE);
112         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
113
114         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_CHANNEL, DB_FIELD_MEDIA_CHANNEL);
115         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
116
117         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_DURATION, DB_FIELD_MEDIA_DURATION);
118         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
119
120         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_LONGITUDE, DB_FIELD_MEDIA_LONGITUDE);
121         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
122
123         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_LATITUDE, DB_FIELD_MEDIA_LATITUDE);
124         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
125
126         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ALTITUDE, DB_FIELD_MEDIA_ALTITUDE);
127         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
128
129         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_WIDTH, DB_FIELD_MEDIA_WIDTH);
130         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
131
132         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_HEIGHT, DB_FIELD_MEDIA_HEIGHT);
133         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
134
135         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_DATETAKEN, DB_FIELD_MEDIA_DATETAKEN);
136         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
137
138         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ORIENTATION, DB_FIELD_MEDIA_ORIENTATION);
139         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
140
141         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_BURST_ID, DB_FIELD_MEDIA_BURST_ID);
142         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
143
144         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_PLAYED_COUNT, DB_FIELD_MEDIA_PLAYED_COUNT);
145         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
146
147         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_LAST_PLAYED_TIME, DB_FIELD_MEDIA_LAST_PLAYED_TIME);
148         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
149
150         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_LAST_PLAYED_POSITION, DB_FIELD_MEDIA_LAST_PLAYED_POSITION);
151         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
152
153         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_RATING, DB_FIELD_MEDIA_RATING);
154         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
155
156         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_FAVOURITE, DB_FIELD_MEDIA_FAVOURITE);
157         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
158
159         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_AUTHOR, DB_FIELD_MEDIA_AUTHOR);
160         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
161
162         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_PROVIDER, DB_FIELD_MEDIA_PROVIDER);
163         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
164
165         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_CONTENT_NAME, DB_FIELD_MEDIA_CONTENT_NAME);
166         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
167
168         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_CATEGORY, DB_FIELD_MEDIA_CATEGORY);
169         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
170
171         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_LOCATION_TAG, DB_FIELD_MEDIA_LOCATION_TAG);
172         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
173
174         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_AGE_RATING, DB_FIELD_MEDIA_AGE_RATING);
175         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
176
177         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_KEYWORD, DB_FIELD_MEDIA_KEYWORD);
178         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
179
180         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_WEATHER, DB_FIELD_MEDIA_WEATHER);
181         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
182
183         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_IS_DRM, DB_FIELD_MEDIA_IS_DRM);
184         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
185
186         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_STORAGE_TYPE, DB_FIELD_MEDIA_STORAGE_TYPE);
187         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
188
189         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_360, DB_FIELD_MEDIA_360);
190         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
191
192         /* Pinyin*/
193         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_FILE_NAME_PINYIN, DB_FIELD_MEDIA_FILE_NAME_PINYIN);
194         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
195
196         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_TITLE_PINYIN, DB_FIELD_MEDIA_TITLE_PINYIN);
197         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
198
199         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ALBUM_PINYIN, DB_FIELD_MEDIA_ALBUM_PINYIN);
200         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
201
202         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ARTIST_PINYIN, DB_FIELD_MEDIA_ARTIST_PINYIN);
203         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
204
205         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_ALBUM_ARTIST_PINYIN, DB_FIELD_MEDIA_ALBUM_ARTIST_PINYIN);
206         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
207
208         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_GENRE_PINYIN, DB_FIELD_MEDIA_GENRE_PINYIN);
209         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
210
211         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_COMPOSER_PINYIN, DB_FIELD_MEDIA_COMPOSER_PINYIN);
212         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
213
214         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_COPYRIGHT_PINYIN, DB_FIELD_MEDIA_COPYRIGHT_PINYIN);
215         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
216
217         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_DESCRIPTION_PINYIN, DB_FIELD_MEDIA_DESCRIPTION_PINYIN);
218         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
219
220         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_AUTHOR_PINYIN, DB_FIELD_MEDIA_AUTHOR_PINYIN);
221         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
222
223         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_PROVIDER_PINYIN, DB_FIELD_MEDIA_PROVIDER_PINYIN);
224         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
225
226         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_CONTENT_NAME_PINYIN, DB_FIELD_MEDIA_CONTENT_NAME_PINYIN);
227         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
228
229         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_CATEGORY_PINYIN, DB_FIELD_MEDIA_CATEGORY_PINYIN);
230         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
231
232         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_LOCATION_TAG_PINYIN, DB_FIELD_MEDIA_LOCATION_TAG_PINYIN);
233         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
234
235         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_AGE_RATING_PINYIN, DB_FIELD_MEDIA_AGE_RATING_PINYIN);
236         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
237
238         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_KEYWORD_PINYIN, DB_FIELD_MEDIA_KEYWORD_PINYIN);
239         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
240
241         /* Playlist*/
242         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_PLAYLIST_ID, DB_FIELD_PLAYLIST_ID);
243         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
244
245         ret = _media_filter_attribute_add(g_attr_handle, PLAYLIST_NAME, DB_FIELD_PLAYLIST_NAME);
246         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
247
248         ret = _media_filter_attribute_add(g_attr_handle, PLAYLIST_MEMBER_ORDER, DB_FIELD_PLAYLIST_MEMBER_ORDER);
249         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
250
251         /* Playlist View */
252         ret = _media_filter_attribute_add(g_attr_handle, PLAYLIST_MEDIA_COUNT, DB_FIELD_PLAYLIST_MEDIA_COUNT);
253         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
254
255         /* Tag*/
256         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_TAG_ID, DB_FIELD_TAG_ID);
257         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
258
259         ret = _media_filter_attribute_add(g_attr_handle, TAG_NAME, DB_FIELD_TAG_NAME);
260         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
261
262         /* Tag View */
263         ret = _media_filter_attribute_add(g_attr_handle, TAG_MEDIA_COUNT, DB_FIELD_TAG_MEDIA_COUNT);
264         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
265
266         /* Bookmark*/
267         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_BOOKMARK_ID, DB_FIELD_BOOKMARK_ID);
268         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
269
270         ret = _media_filter_attribute_add(g_attr_handle, BOOKMARK_MARKED_TIME, DB_FIELD_BOOKMARK_MARKED_TIME);
271         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
272
273         ret = _media_filter_attribute_add(g_attr_handle, BOOKMARK_NAME, DB_FIELD_BOOKMARK_NAME);
274         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
275
276         /* Storage*/
277         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_STORAGE_ID, DB_FIELD_STORAGE_ID);
278         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
279
280         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_STORAGE_PATH, DB_FIELD_STORAGE_PATH);
281         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
282
283         /* Face */
284         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_FACE_TAG, DB_FIELD_FACE_TAG);
285         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
286
287         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_FACE_ID, DB_FIELD_FACE_ID);
288         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
289
290 #ifdef _USE_SENIOR_MODE
291         if (_media_content_is_support_senior_mode()) {
292                 ret = _media_filter_attribute_add(g_attr_handle, MEDIA_CONTACT, DB_FIELD_MEDIA_CONTACT);
293                 media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
294
295                 ret = _media_filter_attribute_add(g_attr_handle, MEDIA_APP_DATA, DB_FIELD_MEDIA_APP_DATA);
296                 media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
297         }
298 #endif
299 #ifdef _USE_TV_PROFILE
300         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_FOLDER_ID, DB_FIELD_MEDIA_FOLDER_ID);
301         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
302
303         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_STITCHED_INFO, DB_FIELD_MEDIA_STITCHED_INFO);
304         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
305
306         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_MODIFIED_MONTH, DB_FIELD_MEDIA_MODIFIED_DATE);
307         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
308
309         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_MODIFIED_DATE, DB_FIELD_MEDIA_MODIFIED_DATE);
310         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
311
312         /* PVR*/
313         ret = _media_filter_attribute_add(g_attr_handle, PVR_DURATION, DB_FIELD_PVR_DURATION);
314         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
315
316         ret = _media_filter_attribute_add(g_attr_handle, PVR_TIME_ZONE, DB_FIELD_PVR_TIME_ZONE);
317         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
318
319         ret = _media_filter_attribute_add(g_attr_handle, PVR_PTC, DB_FIELD_PVR_PTC);
320         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
321
322         ret = _media_filter_attribute_add(g_attr_handle, PVR_MAJOR, DB_FIELD_PVR_MAJOR);
323         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
324
325         ret = _media_filter_attribute_add(g_attr_handle, PVR_MINOR, DB_FIELD_PVR_MINOR);
326         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
327
328         ret = _media_filter_attribute_add(g_attr_handle, PVR_CHANNEL_TYPE, DB_FIELD_PVR_CHANNEL_TYPE);
329         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
330
331         ret = _media_filter_attribute_add(g_attr_handle, PVR_CHANNEL_NAME, DB_FIELD_PVR_CHANNEL_NAME);
332         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
333
334         ret = _media_filter_attribute_add(g_attr_handle, PVR_CHANNEL_NUM, DB_FIELD_PVR_CHANNEL_NUM);
335         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
336
337         ret = _media_filter_attribute_add(g_attr_handle, PVR_PROGRAM_TITLE, DB_FIELD_PVR_PROGRAM_TITLE);
338         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
339
340         ret = _media_filter_attribute_add(g_attr_handle, PVR_PROGRAM_NUM, DB_FIELD_PVR_PROGRAM_NUM);
341         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
342
343         ret = _media_filter_attribute_add(g_attr_handle, PVR_PROGRAM_CRID, DB_FIELD_PVR_PROGRAM_CRID);
344         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
345
346         ret = _media_filter_attribute_add(g_attr_handle, PVR_GUIDANCE, DB_FIELD_PVR_GUIDANCE);
347         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
348
349         ret = _media_filter_attribute_add(g_attr_handle, PVR_SYNOPSIS, DB_FIELD_PVR_SYNOPSIS);
350         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
351
352         ret = _media_filter_attribute_add(g_attr_handle, PVR_GENRE, DB_FIELD_PVR_GENRE);
353         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
354
355         ret = _media_filter_attribute_add(g_attr_handle, PVR_LANGUAGE, DB_FIELD_PVR_LANGUAGE);
356         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
357
358         ret = _media_filter_attribute_add(g_attr_handle, PVR_EMBARGO_TIME, DB_FIELD_PVR_EMBARGO_TIME);
359         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
360
361         ret = _media_filter_attribute_add(g_attr_handle, PVR_EXPIRY_TIME, DB_FIELD_PVR_EXPIRY_TIME);
362         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
363
364         ret = _media_filter_attribute_add(g_attr_handle, PVR_START_TIME, DB_FIELD_PVR_START_TIME);
365         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
366
367         ret = _media_filter_attribute_add(g_attr_handle, PVR_PROGRAM_START_TIME, DB_FIELD_PVR_PROGRAM_START_TIME);
368         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
369
370         ret = _media_filter_attribute_add(g_attr_handle, PVR_PROGRAM_END_TIME, DB_FIELD_PVR_PROGRAM_END_TIME);
371         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
372
373         ret = _media_filter_attribute_add(g_attr_handle, PVR_PROGRAM_DATE, DB_FIELD_PVR_PROGRAM_DATE);
374         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
375
376         ret = _media_filter_attribute_add(g_attr_handle, PVR_PARENTAL_RATING, DB_FIELD_PVR_PARENTAL_RATING);
377         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
378
379         ret = _media_filter_attribute_add(g_attr_handle, PVR_TIMER_RECORD, DB_FIELD_PVR_TIMER_RECORD);
380         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
381
382         ret = _media_filter_attribute_add(g_attr_handle, PVR_SERIES_RECORD, DB_FIELD_PVR_SERIES_RECORD);
383         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
384
385         ret = _media_filter_attribute_add(g_attr_handle, PVR_HD, DB_FIELD_PVR_HD);
386         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
387
388         ret = _media_filter_attribute_add(g_attr_handle, PVR_SUBTITLE, DB_FIELD_PVR_SUBTITLE);
389         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
390
391         ret = _media_filter_attribute_add(g_attr_handle, PVR_TTX, DB_FIELD_PVR_TTX);
392         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
393
394         ret = _media_filter_attribute_add(g_attr_handle, PVR_AD, DB_FIELD_PVR_AD);
395         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
396
397         ret = _media_filter_attribute_add(g_attr_handle, PVR_TTX, DB_FIELD_PVR_TTX);
398         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
399
400         ret = _media_filter_attribute_add(g_attr_handle, PVR_DATA_SERVICE, DB_FIELD_PVR_DATA_SERVICE);
401         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
402
403         ret = _media_filter_attribute_add(g_attr_handle, PVR_CONTENT_LOCK, DB_FIELD_PVR_CONTENT_LOCK);
404         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
405
406         ret = _media_filter_attribute_add(g_attr_handle, PVR_CONTENT_WATCH, DB_FIELD_PVR_CONTENT_WATCH);
407         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
408
409         ret = _media_filter_attribute_add(g_attr_handle, PVR_CONTENT_HAS_AUDIO_ONLY, DB_FIELD_PVR_HAS_AUDIO_ONLY);
410         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
411
412         ret = _media_filter_attribute_add(g_attr_handle, PVR_CONTENT_IS_LOCAL_RECORD, DB_FIELD_PVR_IS_LOCAL_RECORD);
413         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
414
415         ret = _media_filter_attribute_add(g_attr_handle, PVR_CONTENT_RESOLUTION, DB_FIELD_PVR_RESOLUTION);
416         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
417
418         ret = _media_filter_attribute_add(g_attr_handle, PVR_CONTENT_ASPECTRATIO, DB_FIELD_PVR_ASPECTRATIO);
419         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
420
421         ret = _media_filter_attribute_add(g_attr_handle, PVR_MODIFIED_MONTH, DB_FIELD_PVR_MODIFIED_DATE);
422         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
423
424         ret = _media_filter_attribute_add(g_attr_handle, PVR_MODIFIED_DATE, DB_FIELD_PVR_MODIFIED_DATE);
425         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
426
427         ret = _media_filter_attribute_add(g_attr_handle, PVR_SPORTS_TYPE, DB_FIELD_PVR_SPORTS_TYPE);
428         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
429
430         ret = _media_filter_attribute_add(g_attr_handle, PVR_GUIDANCE_LENGTH, DB_FIELD_PVR_GUIDANCE_LENGTH);
431         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
432
433         ret = _media_filter_attribute_add(g_attr_handle, PVR_TVMODE, DB_FIELD_PVR_TVMODE);
434         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
435
436         ret = _media_filter_attribute_add(g_attr_handle, PVR_PLAY_COUNT, DB_FIELD_PVR_PLAY_COUNT);
437         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
438
439         ret = _media_filter_attribute_add(g_attr_handle, PVR_PRIVATE_DATA, DB_FIELD_PVR_PRIVATE_DATA);
440         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
441
442         /* UHD*/
443         ret = _media_filter_attribute_add(g_attr_handle, UHD_CONTENT_TITLE, DB_FIELD_UHD_CONTENT_TITLE);
444         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
445
446         ret = _media_filter_attribute_add(g_attr_handle, UHD_RELEASE_DATE, DB_FIELD_UHD_RELEASE_DATE);
447         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
448
449         ret = _media_filter_attribute_add(g_attr_handle, UHD_SUB_TYPE, DB_FIELD_UHD_SUB_TYPE);
450         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
451
452         ret = _media_filter_attribute_add(g_attr_handle, UHD_FILE_NAME, DB_FIELD_UHD_FILE_NAME);
453         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
454
455         ret = _media_filter_attribute_add(g_attr_handle, UHD_FOLDER_ID, DB_FIELD_FOLDER_ID);
456         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
457
458         ret = _media_filter_attribute_add(g_attr_handle, UHD_PLAYED_COUNT, DB_FIELD_UHD_PLAYED_COUNT);
459         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
460 #endif
461         return ret;
462 }
463
464 static int __media_content_create_alias_attr_handle(void)
465 {
466         int ret = MEDIA_CONTENT_ERROR_NONE;
467
468         ret = _media_filter_attribute_create(&g_alias_attr_handle);
469         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
470
471         /* Media Info */
472         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ID, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ID);
473         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
474
475         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_PATH, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_PATH);
476         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
477
478         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_DISPLAY_NAME, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_DISPLAY_NAME);
479         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
480
481         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_TYPE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_TYPE);
482         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
483
484         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_MIME_TYPE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_MIME_TYPE);
485         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
486
487         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_SIZE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_SIZE);
488         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
489
490         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ADDED_TIME, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ADDED_TIME);
491         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
492
493         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_MODIFIED_TIME, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_MODIFIED_TIME);
494         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
495
496         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_TIMELINE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_TIMELINE);
497         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
498 #ifdef _USE_TV_PROFILE
499         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_FOLDER_ID, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_FOLDER_ID);
500         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
501 #endif
502
503         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_THUMBNAIL_PATH, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_THUMBNAIL_PATH);
504         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
505
506         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_TITLE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_TITLE);
507         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
508
509         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ALBUM, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ALBUM);
510         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
511
512         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ARTIST, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ARTIST);
513         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
514
515         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ALBUM_ARTIST, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ALBUM_ARTIST);
516         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
517
518         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_GENRE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_GENRE);
519         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
520
521         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_COMPOSER, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_COMPOSER);
522         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
523
524         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_YEAR, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_YEAR);
525         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
526
527         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_RECORDED_DATE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_RECORDED_DATE);
528         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
529
530         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_COPYRIGHT, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_COPYRIGHT);
531         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
532
533         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_TRACK_NUM, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_TRACK_NUM);
534         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
535
536         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_DESCRIPTION, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_DESCRIPTION);
537         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
538
539         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_BITRATE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_BITRATE);
540         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
541
542         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_BITPERSAMPLE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_BITPERSAMPLE);
543         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
544
545         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_SAMPLERATE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_SAMPLERATE);
546         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
547
548         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_CHANNEL, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_CHANNEL);
549         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
550
551         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_DURATION, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_DURATION);
552         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
553
554         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_LONGITUDE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_LONGITUDE);
555         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
556
557         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_LATITUDE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_LATITUDE);
558         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
559
560         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ALTITUDE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ALTITUDE);
561         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
562
563         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_WIDTH, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_WIDTH);
564         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
565
566         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_HEIGHT, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_HEIGHT);
567         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
568
569         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_DATETAKEN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_DATETAKEN);
570         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
571
572         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ORIENTATION, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ORIENTATION);
573         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
574
575         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_BURST_ID, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_BURST_ID);
576         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
577
578         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_PLAYED_COUNT, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_PLAYED_COUNT);
579         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
580
581         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_LAST_PLAYED_TIME, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_LAST_PLAYED_TIME);
582         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
583
584         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_LAST_PLAYED_POSITION, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_LAST_PLAYED_POSITION);
585         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
586
587         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_RATING, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_RATING);
588         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
589
590         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_FAVOURITE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_FAVOURITE);
591         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
592
593         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_AUTHOR, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_AUTHOR);
594         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
595
596         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_PROVIDER, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_PROVIDER);
597         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
598
599         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_CONTENT_NAME, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_CONTENT_NAME);
600         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
601
602         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_CATEGORY, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_CATEGORY);
603         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
604
605         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_LOCATION_TAG, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_LOCATION_TAG);
606         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
607
608         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_AGE_RATING, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_AGE_RATING);
609         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
610
611         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_KEYWORD, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_KEYWORD);
612         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
613
614         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_WEATHER, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_WEATHER);
615         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
616
617         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_IS_DRM, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_IS_DRM);
618         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
619
620         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_STORAGE_TYPE, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_STORAGE_TYPE);
621         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
622
623         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_360, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_360);
624         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
625
626 #ifdef _USE_SENIOR_MODE
627         if (_media_content_is_support_senior_mode()) {
628                 ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_CONTACT, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_CONTACT);
629                 media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
630
631                 ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_APP_DATA, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_APP_DATA);
632                 media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
633         }
634 #endif
635
636         /* Pinyin*/
637         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_FILE_NAME_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_FILE_NAME_PINYIN);
638         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
639
640         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_TITLE_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_TITLE_PINYIN);
641         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
642
643         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ALBUM_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ALBUM_PINYIN);
644         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
645
646         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ARTIST_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ARTIST_PINYIN);
647         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
648
649         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_ALBUM_ARTIST_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_ALBUM_ARTIST_PINYIN);
650         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
651
652         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_GENRE_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_GENRE_PINYIN);
653         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
654
655         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_COMPOSER_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_COMPOSER_PINYIN);
656         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
657
658         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_COPYRIGHT_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_COPYRIGHT_PINYIN);
659         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
660
661         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_DESCRIPTION_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_DESCRIPTION_PINYIN);
662         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
663
664         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_AUTHOR_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_AUTHOR_PINYIN);
665         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
666
667         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_PROVIDER_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_PROVIDER_PINYIN);
668         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
669
670         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_CONTENT_NAME_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_CONTENT_NAME_PINYIN);
671         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
672
673         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_CATEGORY_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_CATEGORY_PINYIN);
674         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
675
676         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_LOCATION_TAG_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_LOCATION_TAG_PINYIN);
677         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
678
679         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_AGE_RATING_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_AGE_RATING_PINYIN);
680         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
681
682         ret = _media_filter_attribute_add(g_alias_attr_handle, MEDIA_KEYWORD_PINYIN, DB_TABLE_ALIAS_MEDIA"."DB_FIELD_MEDIA_KEYWORD_PINYIN);
683         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
684
685         /* Folder */
686         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_ID, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_ID);
687         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
688
689         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_PATH, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_PATH);
690         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
691
692         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_NAME, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_NAME);
693         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
694
695         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_MODIFIED_TIME, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_MODIFIED_TIME);
696         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
697
698         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_STORAGE_TYPE, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_STORAGE_TYPE);
699         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
700
701         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_NAME_PINYIN, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_NAME_PINYIN);
702         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
703
704         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_ORDER, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_ORDER);
705         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
706
707         ret = _media_filter_attribute_add(g_alias_attr_handle, FOLDER_PARENT_FOLDER_ID, DB_TABLE_ALIAS_FOLDER"."DB_FIELD_FOLDER_PARENT_FOLDER_ID);
708         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
709
710         /* Playlist*/
711         ret = _media_filter_attribute_add(g_alias_attr_handle, PLAYLIST_NAME, DB_TABLE_ALIAS_PLAYLIST"."DB_FIELD_PLAYLIST_NAME);
712         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
713
714         ret = _media_filter_attribute_add(g_alias_attr_handle, PLAYLIST_MEMBER_ORDER, DB_TABLE_ALIAS_PLAYLIST_MAP"."DB_FIELD_PLAYLIST_MEMBER_ORDER);
715         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
716
717         /* Tag*/
718         ret = _media_filter_attribute_add(g_alias_attr_handle, TAG_NAME, DB_TABLE_ALIAS_TAG"."DB_FIELD_TAG_NAME);
719         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
720
721         /* Bookmark*/
722         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_BOOKMARK_ID, DB_TABLE_ALIAS_BOOKMARK"."DB_FIELD_BOOKMARK_ID);
723         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
724
725         ret = _media_filter_attribute_add(g_alias_attr_handle, BOOKMARK_MARKED_TIME, DB_TABLE_ALIAS_BOOKMARK"."DB_FIELD_BOOKMARK_MARKED_TIME);
726         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
727
728         ret = _media_filter_attribute_add(g_alias_attr_handle, BOOKMARK_NAME, DB_TABLE_ALIAS_BOOKMARK"."DB_FIELD_BOOKMARK_NAME);
729         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
730
731         /* Face */
732         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_FACE_TAG, DB_TABLE_ALIAS_FACE"."DB_FIELD_FACE_TAG);
733         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
734
735         ret = _media_filter_attribute_add(g_attr_handle, MEDIA_FACE_ID, DB_TABLE_ALIAS_FACE"."DB_FIELD_FACE_ID);
736         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
737
738         return ret;
739 }
740
741 static int __media_content_create_attribute_handle(void)
742 {
743         int ret = MEDIA_CONTENT_ERROR_NONE;
744
745         ret = __media_content_create_attr_handle();
746         media_content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
747
748         ret = __media_content_create_alias_attr_handle();
749         if (ret != MEDIA_CONTENT_ERROR_NONE)
750                 _media_filter_attribute_destory(g_attr_handle);
751
752         return ret;
753 }
754
755 static int __media_content_destroy_attribute_handle(void)
756 {
757         int ret = MEDIA_CONTENT_ERROR_NONE;
758
759         ret = _media_filter_attribute_destory(g_attr_handle);
760         ret = _media_filter_attribute_destory(g_alias_attr_handle);
761
762         g_attr_handle = NULL;
763         g_alias_attr_handle = NULL;
764
765         return ret;
766 }
767
768 attribute_h _content_get_attirbute_handle(void)
769 {
770         return g_attr_handle;
771 }
772
773 attribute_h _content_get_alias_attirbute_handle(void)
774 {
775         return g_alias_attr_handle;
776 }
777
778 MediaSvcHandle* _content_get_db_handle(void)
779 {
780         return db_handle;
781 }
782
783 int _content_query_prepare(sqlite3_stmt **stmt, char *select_query, char *condition_query, char *option_query)
784 {
785         int len = 0;
786         int err = MEDIA_CONTENT_ERROR_NONE;
787         char query[MAX_QUERY_SIZE] = {0, };
788         memset(query, '\0', sizeof(query));
789
790         media_content_retvm_if(db_handle == NULL, MEDIA_CONTENT_ERROR_DB_FAILED, "database is not connected");
791         media_content_retvm_if(!STRING_VALID(select_query), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid select_query");
792
793         if (!STRING_VALID(condition_query))
794                 condition_query = (char *)" ";
795
796         if (!STRING_VALID(option_query))
797                 option_query = (char *)" ";
798
799         /*query = sqlite3_mprintf("%s %s %s", select_query, condition_query, option_query);*/
800         len = snprintf(query, sizeof(query), "%s %s %s", select_query, condition_query, option_query);
801         if (len > 0 && len < sizeof(query))
802                 query[len] = '\0';
803         else if (len >= sizeof(query))
804                 query[MAX_QUERY_SIZE -1] = '\0';
805         else {
806                 media_content_error("snprintf failed");
807                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
808         }
809
810         media_content_sec_debug("Query : [%s]", query);
811
812         err = sqlite3_prepare_v2((sqlite3*)db_handle, query, strlen(query), stmt, NULL);
813         if (err != SQLITE_OK) {
814                 media_content_error("DB_FAILED(0x%08x) fail to sqlite3_prepare(), %s", MEDIA_CONTENT_ERROR_DB_FAILED, sqlite3_errmsg((sqlite3*)db_handle));
815
816                 if (err == SQLITE_BUSY) {
817                         media_content_error(" BUSY ERROR");
818                         return MEDIA_CONTENT_ERROR_DB_BUSY;
819                 } else if (err == SQLITE_PERM) {
820                         media_content_error("PERMISSION EROR");
821                         return MEDIA_CONTENT_ERROR_PERMISSION_DENIED;
822                 } else {
823                         media_content_error("OTHER ERROR");
824                         return MEDIA_CONTENT_ERROR_DB_FAILED;
825                 }
826         }
827
828         return MEDIA_CONTENT_ERROR_NONE;
829 }
830
831 #ifdef _USE_SENIOR_MODE
832 int _content_query_prepare_by_union_select(sqlite3_stmt **stmt, char *select_query1, char *condition_query1, char *option_query1, char *select_query2, char *condition_query2, char *option_query2)
833 {
834         int len = 0;
835         int err = MEDIA_CONTENT_ERROR_NONE;
836         char query[MAX_QUERY_SIZE] = {0, };
837         memset(query, '\0', sizeof(query));
838
839         media_content_retvm_if(db_handle == NULL, MEDIA_CONTENT_ERROR_DB_FAILED, "database is not connected");
840         media_content_retvm_if(!STRING_VALID(select_query1), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid select_query1");
841         media_content_retvm_if(!STRING_VALID(select_query2), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid select_query2");
842
843         if (!STRING_VALID(condition_query1))
844                 condition_query1 = (char *)" ";
845
846         if (!STRING_VALID(option_query1))
847                 option_query1 = (char *)" ";
848
849         if (!STRING_VALID(condition_query2))
850                 condition_query2 = (char *)" ";
851
852         if (!STRING_VALID(option_query2))
853                 option_query2 = (char *)" ";
854
855         len = snprintf(query, sizeof(query), "SELECT * FROM (%s %s %s) as table1 UNION ALL SELECT * FROM (%s %s %s) as table2",
856                         select_query1, condition_query1, option_query1, select_query2, condition_query2, option_query2);
857         if (len > 0 && len < sizeof(query)) {
858                 query[len] = '\0';
859         } else if (len >= sizeof(query)) {
860                 query[MAX_QUERY_SIZE -1] = '\0';
861         } else {
862                 media_content_error("snprintf failed");
863                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
864         }
865
866         media_content_sec_debug("Query : [%s]", query);
867
868         err = sqlite3_prepare_v2((sqlite3*)db_handle, query, strlen(query), stmt, NULL);
869         if (err != SQLITE_OK) {
870                 media_content_error("DB_FAILED(0x%08x) fail to sqlite3_prepare(), %s", MEDIA_CONTENT_ERROR_DB_FAILED, sqlite3_errmsg((sqlite3*)db_handle));
871
872                 if (err == SQLITE_BUSY) {
873                         media_content_error(" BUSY ERROR");
874                         return MEDIA_CONTENT_ERROR_DB_BUSY;
875                 } else if (err == SQLITE_PERM) {
876                         media_content_error("PERMISSION EROR");
877                         return MEDIA_CONTENT_ERROR_PERMISSION_DENIED;
878                 } else {
879                         media_content_error("OTHER ERROR");
880                         return MEDIA_CONTENT_ERROR_DB_FAILED;
881                 }
882         }
883
884         return MEDIA_CONTENT_ERROR_NONE;
885 }
886 #endif
887
888 int _content_error_capi(int type, int content_error)
889 {
890         if (content_error != MEDIA_CONTENT_ERROR_NONE)
891                 media_content_error("[type : %d] content_error : %d ", type, content_error);
892
893         /*Error None*/
894         if (content_error == MS_MEDIA_ERR_NONE)
895                 return MEDIA_CONTENT_ERROR_NONE;
896
897         /* Internal operation error*/
898         else if ((content_error == MS_MEDIA_ERR_INVALID_PARAMETER) ||
899                 (content_error == MS_MEDIA_ERR_INVALID_PATH) ||
900                 (content_error == MS_MEDIA_ERR_THUMB_DUPLICATED_REQUEST))
901                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
902
903         else if (content_error == MS_MEDIA_ERR_OUT_OF_MEMORY)
904                 return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
905
906         /* DB operation error*/
907         else if (content_error == MS_MEDIA_ERR_DB_BUSY_FAIL)
908                 return MEDIA_CONTENT_ERROR_DB_BUSY;
909
910         else if ((content_error <= MS_MEDIA_ERR_DB_CONNECT_FAIL) && (content_error >= MS_MEDIA_ERR_DB_INTERNAL))
911                 return MEDIA_CONTENT_ERROR_DB_FAILED;
912
913         /* IPC operation error*/
914         else if ((content_error <= MS_MEDIA_ERR_SOCKET_CONN) && (content_error >= MS_MEDIA_ERR_SOCKET_INTERNAL))
915                 return MEDIA_CONTENT_ERROR_NETWORK;
916
917         /* MEDIA SERVER error*/
918         else if (content_error == MS_MEDIA_ERR_PERMISSION_DENIED)
919                 return MEDIA_CONTENT_ERROR_PERMISSION_DENIED;
920
921         /* Thumbnail error*/
922         else if ((content_error == MS_MEDIA_ERR_THUMB_TOO_BIG) || (content_error == MS_MEDIA_ERR_THUMB_UNSUPPORTED))
923                         return MEDIA_CONTENT_ERROR_UNSUPPORTED_CONTENT;
924
925         /*ETC*/
926         return MEDIA_CONTENT_ERROR_INVALID_OPERATION;
927 }
928
929 int _content_query_sql(char *query_str)
930 {
931         int ret = MEDIA_CONTENT_ERROR_NONE;
932
933         /*DB will be updated by Media Server.*/
934         ret = media_svc_request_update_db(query_str, tzplatform_getuid(TZ_USER_NAME));
935
936         return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
937 }
938
939 int media_content_connect(void)
940 {
941         int ret = MEDIA_CONTENT_ERROR_NONE;
942
943         g_mutex_lock(&db_mutex);
944         media_content_info("ref count : %d", ref_count);
945
946         if (ref_count == 0) {
947                 if (db_handle == NULL) {
948                         ret = __media_content_create_attribute_handle();
949                         if (ret == MEDIA_CONTENT_ERROR_NONE) {
950                                 ret = media_svc_connect(&db_handle, tzplatform_getuid(TZ_USER_NAME), false);
951                                 ret = _content_error_capi(MEDIA_CONTENT_TYPE, ret);
952                                 if (ret == MEDIA_CONTENT_ERROR_NONE)
953                                         ref_count++;
954                                 else
955                                         __media_content_destroy_attribute_handle();
956
957                         } else {
958                                 media_content_error("Internal DB Connection Error");
959                         }
960                 } else {
961                         media_content_error("Wrong DB Connection status");
962                         ret = MEDIA_CONTENT_ERROR_DB_FAILED;
963                 }
964         } else {
965                 if (db_handle != NULL) {
966                         ref_count++;
967                 } else {
968                         media_content_error("Wrong DB Handle status");
969                         ret = MEDIA_CONTENT_ERROR_DB_FAILED;
970                 }
971         }
972
973         media_content_info("ref count changed to: %d", ref_count);
974         g_mutex_unlock(&db_mutex);
975
976         return ret;
977 }
978
979 int media_content_disconnect(void)
980 {
981         int ret = MEDIA_CONTENT_ERROR_NONE;
982
983         g_mutex_lock(&db_mutex);
984         media_content_debug("ref count : %d", ref_count);
985         if (ref_count > 0) {
986                 if (db_handle != NULL) {
987                         ref_count--;
988                 } else {
989                         media_content_error("Wrong DB Handle status");
990                         ret = MEDIA_CONTENT_ERROR_DB_FAILED;
991                 }
992         } else {
993                 media_content_error("DB_FAILED(0x%08x) database is not connected", MEDIA_CONTENT_ERROR_DB_FAILED);
994                 g_mutex_unlock(&db_mutex);
995                 return MEDIA_CONTENT_ERROR_DB_FAILED;
996         }
997
998         if (ref_count == 0) {
999                 if (db_handle != NULL) {
1000                         ret = media_svc_disconnect(db_handle);
1001                         ret = _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1002                         if (ret == MEDIA_CONTENT_ERROR_NONE) {
1003                                 ret = __media_content_destroy_attribute_handle();
1004                                 db_handle = NULL;
1005                         } else {
1006                                 media_content_error("database disconnect fail");
1007                                 ref_count++;
1008                         }
1009                 } else {
1010                         media_content_error("Wrong DB Handle status");
1011                         ret = MEDIA_CONTENT_ERROR_DB_FAILED;
1012                 }
1013
1014                 g_mutex_unlock(&db_mutex);
1015
1016                 media_content_info("ref count changed to: %d", ref_count);
1017
1018                 return ret;
1019         }
1020
1021         g_mutex_unlock(&db_mutex);
1022
1023         media_content_info("ref count changed to: %d", ref_count);
1024
1025         return ret;
1026 }
1027
1028 int media_content_scan_file(const char *path)
1029 {
1030         int ret = MEDIA_CONTENT_ERROR_NONE;
1031         bool ignore_file = FALSE;
1032         bool ignore_dir = FALSE;
1033         char *folder_path = NULL;
1034         int check_file = MEDIA_CONTENT_ERROR_NONE;
1035         char storage_id[MEDIA_CONTENT_UUID_SIZE+1] = {0,};
1036         char repl_path[MAX_PATH_LEN] = {0,};
1037
1038         media_content_retvm_if(!STRING_VALID(path), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid path");
1039
1040         media_content_sec_debug("Path : %s", path);
1041         memset(repl_path, 0, sizeof(repl_path));
1042         ret = _media_content_replace_path(path, repl_path);
1043         media_content_retvm_if(!STRING_VALID(repl_path), MEDIA_CONTENT_ERROR_INVALID_OPERATION, "path replacement failed");
1044
1045         ret = _media_util_check_ignore_file(repl_path, &ignore_file);
1046         media_content_retvm_if(ignore_file == TRUE, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid path");
1047
1048         memset(storage_id, 0x00, sizeof(storage_id));
1049         ret = media_svc_get_storage_id(_content_get_db_handle(), repl_path, storage_id, tzplatform_getuid(TZ_USER_NAME));
1050         if (ret != MS_MEDIA_ERR_NONE) {
1051                 media_content_error("media_svc_get_storage_id failed : %d", ret);
1052                 return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1053         }
1054
1055         check_file = _media_util_check_file_exist(repl_path);
1056         if (check_file == MEDIA_CONTENT_ERROR_NONE) {
1057                 /* This means this path has to be inserted or refreshed */
1058                 folder_path = g_path_get_dirname(repl_path);
1059                 ret = _media_util_check_ignore_dir(folder_path, &ignore_dir);
1060                 SAFE_FREE(folder_path);
1061
1062                 media_content_retvm_if(ignore_dir == TRUE, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid folder path");
1063
1064                 media_svc_storage_type_e storage_type;
1065
1066                 ret = media_svc_get_storage_type(repl_path, &storage_type, tzplatform_getuid(TZ_USER_NAME));
1067                 if (ret != MS_MEDIA_ERR_NONE) {
1068                         media_content_sec_error("media_svc_get_storage_type failed : %d (%s)", ret, repl_path);
1069                         return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1070                 }
1071                 ret = media_svc_check_item_exist_by_path(_content_get_db_handle(), storage_id, repl_path);
1072                 if (ret == MS_MEDIA_ERR_NONE) {
1073                         /* Refresh */
1074                         ret = media_svc_refresh_item(_content_get_db_handle(), storage_id, storage_type, repl_path, tzplatform_getuid(TZ_USER_NAME));
1075                         if (ret != MS_MEDIA_ERR_NONE) {
1076                                 media_content_error("media_svc_refresh_item failed : %d", ret);
1077                                 return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1078                         }
1079
1080                 } else if (ret == MS_MEDIA_ERR_DB_NO_RECORD) {
1081                         /* Insert */
1082                         ret = media_svc_insert_item_immediately(_content_get_db_handle(), storage_id, storage_type, repl_path, tzplatform_getuid(TZ_USER_NAME));
1083                         if (ret != MS_MEDIA_ERR_NONE) {
1084                                 if (ret == MS_MEDIA_ERR_DB_CONSTRAINT_FAIL) {
1085                                         media_content_sec_error("This item is already inserted. This may be normal operation because other process already did this (%s)", repl_path);
1086                                         ret = MEDIA_CONTENT_ERROR_NONE;
1087                                 } else {
1088                                         media_content_sec_error("media_svc_insert_item_immediately failed : %d (%s)", ret, repl_path);
1089                                 }
1090
1091                                 return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1092                         }
1093                 } else {
1094                         media_content_error("media_svc_check_item_exist_by_path failed : %d", ret);
1095                         return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1096                 }
1097         } else if (check_file == MEDIA_CONTENT_ERROR_PERMISSION_DENIED) {
1098                 media_content_error("You have no permission for this file %d", ret);
1099                 return MEDIA_CONTENT_ERROR_PERMISSION_DENIED;
1100         } else {
1101                 /* This means this path has to be deleted */
1102                 media_content_debug("This path doesn't exists in file system... So now start to delete it from DB");
1103                 ret = media_svc_delete_item_by_path(_content_get_db_handle(), storage_id, repl_path, tzplatform_getuid(TZ_USER_NAME));
1104                 if (ret != MS_MEDIA_ERR_NONE) {
1105                         media_content_error("media_svc_delete_item_by_path failed : %d", ret);
1106                         return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1107                 }
1108         }
1109
1110         return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
1111 }
1112
1113 void _media_content_scan_cb(media_request_result_s* result, void *user_data)
1114 {
1115         int err = -1;
1116         media_content_scan_cb_data *cb_data = user_data;
1117
1118         err = _content_error_capi(MEDIA_REGISTER_TYPE, result->result);
1119 #ifdef _USE_TV_PROFILE
1120         if (result->request_type != MEDIA_REQUEST_SCAN_COMPLETE &&
1121                 result->request_type != MEDIA_REQUEST_SCAN_PARTIAL) {
1122                 if (cb_data && cb_data->callback) {
1123                         media_content_debug("begin:User callback is being called now, result=%d", err);
1124                         cb_data->callback(err, cb_data->user_data);
1125                         media_content_debug("end:User callback is being called now, result=%d", err);
1126                 }
1127
1128                 SAFE_FREE(cb_data);
1129         }
1130 #else
1131         if (cb_data && cb_data->callback) {
1132                 media_content_debug("User callback is being called now");
1133                 cb_data->callback(err, cb_data->user_data);
1134         }
1135
1136         SAFE_FREE(cb_data);
1137 #endif
1138
1139         return;
1140 }
1141
1142 #ifdef _USE_TV_PROFILE
1143 void _media_content_scan_cb_v2(media_request_result_s* result, void *user_data)
1144 {
1145         int err = -1;
1146         media_content_scan_cb_data_v2 *cb_data = user_data;
1147         media_content_complete_phase_e complete_phase = -1;
1148         if (!cb_data)
1149                 media_content_debug("cb_data is NULL");
1150         err = _content_error_capi(MEDIA_REGISTER_TYPE, result->result);
1151         media_content_debug("result is %d", err);
1152
1153         if (result->request_type == MEDIA_REQUEST_SCAN_PARTIAL)
1154                 complete_phase = MEDIA_CONTENT_SCAN_PARTIAL_COMPLETE;
1155         else if (result->request_type == MEDIA_REQUEST_SCAN_COMPLETE)
1156                 complete_phase = MEDIA_CONTENT_SCAN_COMPLETE;
1157         else if (result->request_type == MEDIA_REQUEST_EXTRACT_COMPLETE)
1158                 complete_phase = MEDIA_CONTENT_EXTRACT_COMPLETE;
1159
1160         if (cb_data && cb_data->callback)
1161                 cb_data->callback(err, complete_phase, cb_data->user_data);
1162         else
1163                 media_content_debug("run error");
1164
1165         if ((result->request_type != MEDIA_REQUEST_SCAN_COMPLETE) &&
1166         (result->request_type != MEDIA_REQUEST_SCAN_PARTIAL))
1167                 SAFE_FREE(cb_data);
1168
1169         return;
1170 }
1171 #endif
1172
1173 static int __media_content_check_dir(const char *path)
1174 {
1175         DIR *dp = NULL;
1176
1177         dp = opendir(path);
1178         if (dp == NULL) {
1179                 media_content_sec_error("path [%s]", path);
1180                 media_content_stderror("open dir fail");
1181
1182                 if (errno == EACCES || errno == EPERM)
1183                         return MEDIA_CONTENT_ERROR_PERMISSION_DENIED;
1184                 else
1185                         return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
1186         }
1187
1188         closedir(dp);
1189
1190         return MEDIA_CONTENT_ERROR_NONE;
1191 }
1192
1193 int media_content_scan_folder(const char *path, bool is_recursive, media_scan_completed_cb callback, void *user_data)
1194 {
1195         int ret = MEDIA_CONTENT_ERROR_NONE;
1196         bool ignore_dir = FALSE;
1197         char storage_id[MEDIA_CONTENT_UUID_SIZE+1] = {0, };
1198         char repl_path[MAX_PATH_LEN] = {0, };
1199
1200         media_content_retvm_if(!STRING_VALID(path), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid path");
1201         memset(repl_path, 0, sizeof(repl_path));
1202         ret = _media_content_replace_path(path, repl_path);
1203         media_content_retvm_if(!STRING_VALID(repl_path), MEDIA_CONTENT_ERROR_INVALID_OPERATION, "path replacement failed");
1204
1205         memset(storage_id, 0x00, sizeof(storage_id));
1206
1207         ret = __media_content_check_dir(repl_path);
1208         media_content_retvm_if(ret == MEDIA_CONTENT_ERROR_PERMISSION_DENIED, ret, "Permission Denied");
1209
1210         if (ret == MEDIA_CONTENT_ERROR_NONE) {
1211                 /* If directory exist check that's ignore directory or not*/
1212         ret = _media_util_check_ignore_dir(repl_path, &ignore_dir);
1213                 media_content_retvm_if(ignore_dir == TRUE, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid folder path");
1214         } else {
1215                 /* This means this folder has to be deleted */
1216                 media_content_debug("This path doesn't exists in file system... So will be deleted it from DB");
1217         }
1218
1219         media_content_scan_cb_data *cb_data = NULL;
1220         cb_data = (media_content_scan_cb_data *)malloc(sizeof(media_content_scan_cb_data));
1221         media_content_retvm_if(cb_data == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
1222
1223         cb_data->callback = callback;
1224         cb_data->user_data = user_data;
1225
1226         ret = media_svc_get_storage_id(_content_get_db_handle(), repl_path, storage_id, tzplatform_getuid(TZ_USER_NAME));
1227         /*FIX ME. need to check ret value?*/
1228
1229         ret = media_directory_scanning_async(repl_path, storage_id, is_recursive, _media_content_scan_cb, cb_data, tzplatform_getuid(TZ_USER_NAME));
1230         if (ret != MS_MEDIA_ERR_NONE)
1231                 media_content_error("media_directory_scanning_async failed : %d", ret);
1232
1233         return _content_error_capi(MEDIA_REGISTER_TYPE, ret);
1234 }
1235
1236 #ifdef _USE_TV_PROFILE
1237 int media_content_scan_folder_v2(const char *path, bool is_recursive, media_scan_completed_cb_v2 callback, void *user_data)
1238 {
1239         int ret = MEDIA_CONTENT_ERROR_NONE;
1240         bool ignore_dir = FALSE;
1241         char storage_id[MEDIA_CONTENT_UUID_SIZE+1] = {0, };
1242
1243         media_content_retvm_if(!STRING_VALID(path), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid path");
1244         memset(storage_id, 0x00, sizeof(storage_id));
1245
1246         ret = _media_util_check_ignore_dir(path, &ignore_dir);
1247         media_content_retvm_if(ignore_dir, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid folder path");
1248
1249         ret = __media_content_check_dir(path);
1250         media_content_retvm_if(ret == MEDIA_CONTENT_ERROR_PERMISSION_DENIED, ret, "Permission Denied");
1251
1252         media_content_scan_cb_data_v2* cb_data = NULL;
1253         cb_data = (media_content_scan_cb_data_v2*)malloc(sizeof(media_content_scan_cb_data_v2));
1254         media_content_retvm_if(cb_data == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
1255
1256         cb_data->callback = callback;
1257         cb_data->user_data = user_data;
1258
1259         ret = media_svc_get_storage_id(_content_get_db_handle(), path, storage_id, tzplatform_getuid(TZ_USER_NAME));
1260         /*FIX ME. need to check ret value?*/
1261
1262         ret = media_directory_scanning_async(path, storage_id, is_recursive, _media_content_scan_cb_v2, cb_data, tzplatform_getuid(TZ_USER_NAME));
1263         if (ret != MS_MEDIA_ERR_NONE)
1264                 media_content_error("media_directory_scanning_async failed : %d", ret);
1265
1266         return _content_error_capi(MEDIA_REGISTER_TYPE, ret);
1267 }
1268 #endif
1269
1270 int media_content_cancel_scan_folder(const char *path)
1271 {
1272         int ret = MEDIA_CONTENT_ERROR_NONE;
1273         char repl_path[MAX_PATH_LEN] = {0, };
1274
1275         media_content_retvm_if(!STRING_VALID(path), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid path");
1276
1277         memset(repl_path, 0, sizeof(repl_path));
1278         ret = _media_content_replace_path(path, repl_path);
1279         media_content_retvm_if(!STRING_VALID(repl_path), MEDIA_CONTENT_ERROR_INVALID_OPERATION, "path replacement failed");
1280
1281         ret = media_directory_scanning_cancel(repl_path, tzplatform_getuid(TZ_USER_NAME));
1282         if (ret != MS_MEDIA_ERR_NONE)
1283                 media_content_error("media_directory_scanning_async failed : %d", ret);
1284
1285         return _content_error_capi(MEDIA_REGISTER_TYPE, ret);
1286 }
1287
1288 void _media_content_db_update_noti_cb(
1289                                                         int pid,
1290                                                         media_item_type_e item,
1291                                                         media_item_update_type_e update_type,
1292                                                         char* path,
1293                                                         char* uuid,
1294                                                         media_type_e content_type,
1295                                                         char *mime_type,
1296                                                         void *user_data)
1297 {
1298         int error_value = MEDIA_CONTENT_ERROR_NONE;
1299
1300         media_noti_cb_s *_noti_info = (media_noti_cb_s *)user_data;
1301
1302         if (_noti_info != NULL) {
1303                 if (_noti_info->update_noti_cb)
1304                         _noti_info->update_noti_cb(error_value, pid, item, update_type, content_type, uuid, path, mime_type, _noti_info->user_data);
1305         }
1306
1307         return;
1308 }
1309
1310 int media_content_set_db_updated_cb(media_content_db_update_cb callback, void *user_data)
1311 {
1312         int ret = MEDIA_CONTENT_ERROR_NONE;
1313         media_content_warn("DEPRECATION WARNING: media_content_set_db_updated_cb() is deprecated and will be removed from next release. Use media_content_add_db_updated_cb() instead.");
1314
1315         media_content_retvm_if(callback == NULL, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid callback");
1316         media_content_retvm_if(g_noti_info != NULL, MEDIA_CONTENT_ERROR_INVALID_OPERATION, "Noti callback is already set");
1317
1318         g_noti_info = (media_noti_cb_s *)calloc(1, sizeof(media_noti_cb_s));
1319         media_content_retvm_if(g_noti_info == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
1320
1321         g_noti_info->update_noti_cb = callback;
1322         g_noti_info->user_data = user_data;
1323
1324         ret = media_db_update_subscribe(_media_content_db_update_noti_cb, (void *)g_noti_info);
1325
1326         return _content_error_capi(MEDIA_REGISTER_TYPE, ret);
1327 }
1328
1329 int media_content_unset_db_updated_cb(void)
1330 {
1331         int ret = MEDIA_CONTENT_ERROR_NONE;
1332         media_content_warn("DEPRECATION WARNING: media_content_unset_db_updated_cb() is deprecated and will be removed from next release. Use media_content_remove_db_updated_cb() instead.");
1333
1334         SAFE_FREE(g_noti_info);
1335         ret = media_db_update_unsubscribe();
1336
1337         return _content_error_capi(MEDIA_REGISTER_TYPE, ret);
1338 }
1339
1340 int media_content_add_db_updated_cb(media_content_db_update_cb callback, void *user_data, media_content_noti_h *noti_handle)
1341 {
1342         int ret = MEDIA_CONTENT_ERROR_NONE;
1343         media_noti_cb_s *noti_info = NULL;
1344
1345         if (noti_handle == NULL) {
1346                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
1347                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
1348         }
1349
1350         if (callback == NULL) {
1351                 media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
1352                 return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
1353         }
1354
1355         noti_info = (media_noti_cb_s *)calloc(1, sizeof(media_noti_cb_s));
1356         if (noti_info == NULL) {
1357                 media_content_error("Failed to create noti info");
1358                 return MEDIA_CONTENT_ERROR_OUT_OF_MEMORY;
1359         }
1360
1361         noti_info->update_noti_cb = callback;
1362         noti_info->user_data = user_data;
1363
1364         ret = media_db_update_subscribe_internal((MediaNotiHandle*)noti_handle, _media_content_db_update_noti_cb, (void *)noti_info);
1365
1366         return _content_error_capi(MEDIA_REGISTER_TYPE, ret);
1367 }
1368
1369 void __media_content_clear_user_data(void *user_data)
1370 {
1371         media_noti_cb_s *noti_info = user_data;
1372
1373         SAFE_FREE(noti_info);
1374
1375         return;
1376 }
1377
1378 int media_content_remove_db_updated_cb(media_content_noti_h noti_handle)
1379 {
1380         int ret = MEDIA_CONTENT_ERROR_NONE;
1381
1382         ret = media_db_update_unsubscribe_internal((MediaNotiHandle)noti_handle, __media_content_clear_user_data);
1383
1384         return _content_error_capi(MEDIA_REGISTER_TYPE, ret);
1385 }
1386 #ifdef _USE_TV_PROFILE
1387 GMutex* _content_get_db_mutex(void)
1388 {
1389         return &db_mutex;
1390 }
1391 #endif