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