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