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