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