Add pkgmgrinfo_pkginfo_foreach_depends_on_by_pkgid
[platform/core/appfw/pkgmgr-info.git] / src / pkgmgrinfo_pkginfo.c
1 /*
2  * pkgmgr-info
3  *
4  * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
5  *
6  * Contact: Jayoun Lee <airjany@samsung.com>, Sewook Park <sewook7.park@samsung.com>,
7  * Jaeho Lee <jaeho81.lee@samsung.com>, Shobhit Srivastava <shobhit.s@samsung.com>
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  * http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  */
22
23 #define _GNU_SOURCE
24 #include <stdio.h>
25 #include <stdlib.h>
26 #include <string.h>
27 #include <stdbool.h>
28 #include <unistd.h>
29 #include <ctype.h>
30 #include <sys/smack.h>
31 #include <linux/limits.h>
32 #include <sys/stat.h>
33
34 #include <glib.h>
35
36 #include "pkgmgrinfo_basic.h"
37 #include "pkgmgrinfo_private.h"
38 #include "pkgmgrinfo_debug.h"
39 #include "pkgmgr-info.h"
40 #include "manager/pkginfo_manager.h"
41
42 static bool _get_bool_value(const char *str)
43 {
44         if (str && !strcmp(str, "true"))
45                 return true;
46         else
47                 return false;
48 }
49
50 static gint __compare_func(gconstpointer data1, gconstpointer data2)
51 {
52         pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x *)data1;
53         pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x *)data2;
54         if (node1->prop == node2->prop)
55                 return 0;
56         else if (node1->prop > node2->prop)
57                 return 1;
58         else
59                 return -1;
60 }
61
62 static gint __pkg_disable_chk_func(gconstpointer data1, gconstpointer data2)
63 {
64         pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data1;
65
66         if (node->prop == E_PMINFO_PKGINFO_PROP_PACKAGE_DISABLE)
67                 return 0;
68         else
69                 return 1;
70 }
71
72 static void __destroy_metadata_node(gpointer data)
73 {
74         pkgmgrinfo_metadata_node_x *node = (pkgmgrinfo_metadata_node_x *)data;
75         if (node->key)
76                 free(node->key);
77         if (node->value)
78                 free(node->value);
79         free(node);
80 }
81
82 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
83 {
84         ret_if(data == NULL);
85         if (data->locale) {
86                 free((void *)data->locale);
87                 data->locale = NULL;
88         }
89
90         pkgmgrinfo_basic_free_package(data->pkg_info);
91         free((void *)data);
92         data = NULL;
93         return;
94 }
95
96 static void __free_packages(gpointer data)
97 {
98         pkgmgrinfo_basic_free_package((package_x *)data);
99 }
100
101 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
102 {
103         GSList *link;
104
105         if (filter == NULL)
106                 return false;
107
108         link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
109         if (link)
110                 return true;
111
112         return false;
113 }
114
115 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
116                 pkgmgrinfo_filter_x *filter, int flag,
117                 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
118 {
119         int ret;
120         package_x *pkg;
121         pkgmgr_pkginfo_x info;
122         GHashTable *list;
123         GHashTableIter iter;
124         gpointer value;
125
126         list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
127                         __free_packages);
128         if (list == NULL)
129                 return PMINFO_R_ERROR;
130
131         if (__check_disable_filter_exist(filter) == false) {
132                 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
133                                 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
134                 if (ret != PMINFO_R_OK) {
135                         _LOGE("Failed to add filter");
136                         g_hash_table_destroy(list);
137                         return PMINFO_R_ERROR;
138                 }
139         }
140
141         ret = _pkginfo_get_packages(uid, filter, flag, list);
142         if (ret == PMINFO_R_ERROR) {
143                 g_hash_table_destroy(list);
144                 return ret;
145         }
146
147         g_hash_table_iter_init(&iter, list);
148         while (g_hash_table_iter_next(&iter, NULL, &value)) {
149                 pkg = (package_x *)value;
150                 info.uid = uid;
151                 info.pkg_info = pkg;
152                 info.locale = pkg->locale;
153                 if (pkg_list_cb(&info, user_data) < 0)
154                         break;
155         }
156
157         g_hash_table_destroy(list);
158
159         return PMINFO_R_OK;
160 }
161
162 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
163         pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
164 {
165         int ret;
166         GHashTable *list;
167         pkgmgr_pkginfo_x *info;
168
169         if (pkgid == NULL || filter == NULL || handle == NULL) {
170                         LOGE("invalid parameter");
171                         return PMINFO_R_EINVAL;
172         }
173
174         list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
175                         __free_packages);
176         if (list == NULL)
177                 return PMINFO_R_ERROR;
178
179         ret = _pkginfo_get_packages(uid, filter, PMINFO_PKGINFO_GET_ALL, list);
180         if (ret != PMINFO_R_OK) {
181                 g_hash_table_destroy(list);
182                 return ret;
183         }
184
185         if (!g_hash_table_size(list) || !g_hash_table_lookup(list, pkgid)) {
186                 _LOGD("pkginfo for [%s] is not existed for user [%d]",
187                                 pkgid, uid);
188                 g_hash_table_destroy(list);
189                 return PMINFO_R_ENOENT;
190         }
191
192         info = calloc(1, sizeof(pkgmgr_pkginfo_x));
193         if (info == NULL) {
194                 _LOGE("out of memory");
195                 g_hash_table_destroy(list);
196                 return PMINFO_R_ERROR;
197         }
198
199         info->uid = uid;
200         info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
201         info->locale = strdup(info->pkg_info->locale);
202         if (info->locale == NULL) {
203                 _LOGE("Out of memory");
204                 g_hash_table_destroy(list);
205                 free(info);
206                 return PMINFO_R_ERROR;
207         }
208
209         /* just free list only */
210         g_hash_table_steal(list, (gconstpointer)pkgid);
211         g_hash_table_destroy(list);
212
213         *handle = info;
214
215         return ret;
216 }
217
218 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
219                 pkgmgrinfo_pkginfo_h *handle)
220 {
221         int ret;
222         pkgmgrinfo_pkginfo_filter_h filter;
223
224         if (pkgid == NULL || handle == NULL) {
225                 LOGE("invalid parameter");
226                 return PMINFO_R_EINVAL;
227         }
228
229         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
230         if (ret != PMINFO_R_OK)
231                 return ret;
232
233         ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
234                         PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
235         if (ret != PMINFO_R_OK) {
236                 pkgmgrinfo_pkginfo_filter_destroy(filter);
237                 return PMINFO_R_ERROR;
238         }
239
240         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
241                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
242         if (ret != PMINFO_R_OK) {
243                 pkgmgrinfo_pkginfo_filter_destroy(filter);
244                 return PMINFO_R_ERROR;
245         }
246         ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
247         pkgmgrinfo_pkginfo_filter_destroy(filter);
248
249         return ret;
250 }
251
252 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
253                 pkgmgrinfo_pkginfo_h *handle)
254 {
255         return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
256 }
257
258 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
259                 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
260 {
261         int ret;
262         pkgmgrinfo_pkginfo_filter_h filter;
263
264         if (pkgid == NULL || handle == NULL) {
265                 LOGE("invalid parameter");
266                 return PMINFO_R_EINVAL;
267         }
268
269         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
270         if (ret != PMINFO_R_OK) {
271                 return ret;
272         }
273
274         ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
275                         PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
276         if (ret != PMINFO_R_OK) {
277                 pkgmgrinfo_pkginfo_filter_destroy(filter);
278                 return PMINFO_R_ERROR;
279         }
280
281         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
282                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
283         if (ret != PMINFO_R_OK) {
284                 pkgmgrinfo_pkginfo_filter_destroy(filter);
285                 return PMINFO_R_ERROR;
286         }
287
288         ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
289         if (ret == PMINFO_R_ENOENT)
290                 LOGE("disabled pkginfo for [%s] is not existed for user [%d]",
291                                 pkgid, uid);
292         pkgmgrinfo_pkginfo_filter_destroy(filter);
293         return ret;
294 }
295
296 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
297                 pkgmgrinfo_pkginfo_h *handle)
298 {
299         int ret;
300         pkgmgrinfo_pkginfo_filter_h filter;
301
302         if (pkgid == NULL || handle == NULL) {
303                 LOGE("invalid parameter");
304                 return PMINFO_R_EINVAL;
305         }
306
307         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
308         if (ret != PMINFO_R_OK)
309                 return ret;
310
311         ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
312                         PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
313         if (ret != PMINFO_R_OK) {
314                 pkgmgrinfo_pkginfo_filter_destroy(filter);
315                 return PMINFO_R_ERROR;
316         }
317
318         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
319                         PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
320         if (ret != PMINFO_R_OK) {
321                 pkgmgrinfo_pkginfo_filter_destroy(filter);
322                 return PMINFO_R_ERROR;
323         }
324
325         ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
326         pkgmgrinfo_pkginfo_filter_destroy(filter);
327
328         return ret;
329 }
330
331 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
332                 pkgmgrinfo_pkginfo_h *handle)
333 {
334         return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
335                         handle);
336 }
337
338 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
339                 pkgmgrinfo_pkginfo_h *handle)
340 {
341         return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
342 }
343
344 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
345                 int flag, void *user_data, uid_t uid)
346 {
347         int ret;
348         pkgmgrinfo_pkginfo_filter_h filter;
349
350         if (pkg_list_cb == NULL) {
351                 LOGE("invalid parameter");
352                 return PMINFO_R_EINVAL;
353         }
354
355         /* create an empty filter */
356         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
357         if (ret != PMINFO_R_OK)
358                 return ret;
359
360         ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
361                         pkg_list_cb, user_data);
362
363         pkgmgrinfo_pkginfo_filter_destroy(filter);
364
365         return ret;
366 }
367
368 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
369                 int flag, void *user_data)
370 {
371         return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
372                         user_data, _getuid());
373 }
374
375 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
376                 void *user_data, uid_t uid)
377 {
378         int ret;
379         pkgmgrinfo_pkginfo_filter_h filter;
380
381         if (pkg_list_cb == NULL) {
382                 LOGE("invalid parameter");
383                 return PMINFO_R_EINVAL;
384         }
385
386         /* create an empty filter */
387         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
388         if (ret != PMINFO_R_OK)
389                 return ret;
390
391         ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
392                         PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
393
394         pkgmgrinfo_pkginfo_filter_destroy(filter);
395
396         return ret;
397 }
398
399 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
400                 void *user_data)
401 {
402         return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
403                         _getuid());
404 }
405
406 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
407                 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
408 {
409         int ret;
410         pkgmgrinfo_pkginfo_filter_h filter;
411
412         if (pkg_list_cb == NULL) {
413                 LOGE("invalid parameter");
414                 return PMINFO_R_EINVAL;
415         }
416
417         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
418         if (ret != PMINFO_R_OK)
419                 return ret;
420
421         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
422                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
423         if (ret != PMINFO_R_OK) {
424                 pkgmgrinfo_pkginfo_filter_destroy(filter);
425                 return PMINFO_R_ERROR;
426         }
427
428         ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
429                         PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
430
431         pkgmgrinfo_pkginfo_filter_destroy(filter);
432
433         return ret;
434 }
435
436 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
437                 void *user_data)
438 {
439         return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
440                         _getuid());
441 }
442
443 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
444 {
445         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
446
447         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
448         retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
449
450         if (info->pkg_info == NULL || info->pkg_info->package == NULL)
451                 return PMINFO_R_ERROR;
452
453         *pkg_name = (char *)info->pkg_info->package;
454
455         return PMINFO_R_OK;
456 }
457
458 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
459 {
460         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
461
462         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
463         retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
464
465         if (info->pkg_info == NULL || info->pkg_info->package == NULL)
466                 return PMINFO_R_ERROR;
467
468         *pkgid = (char *)info->pkg_info->package;
469
470         return PMINFO_R_OK;
471 }
472
473 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
474 {
475         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
476
477         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
478         retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
479
480         if (info->pkg_info == NULL)
481                 return PMINFO_R_ERROR;
482
483         if (info->pkg_info->type == NULL)
484                 *type = "";
485         else
486                 *type = (char *)info->pkg_info->type;
487
488         return PMINFO_R_OK;
489 }
490
491 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
492 {
493         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
494
495         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
496         retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
497
498         if (info->pkg_info == NULL)
499                 return PMINFO_R_ERROR;
500
501         if (info->pkg_info->version == NULL)
502                 *version = "";
503         else
504                 *version = (char *)info->pkg_info->version;
505
506         return PMINFO_R_OK;
507 }
508
509 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
510 {
511         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
512
513         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
514         retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
515
516         if (info->pkg_info == NULL)
517                 return PMINFO_R_ERROR;
518
519         if (info->pkg_info->api_version == NULL)
520                 *api_version = "";
521         else
522                 *api_version = (char *)info->pkg_info->api_version;
523
524         return PMINFO_R_OK;
525 }
526
527 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
528 {
529         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
530
531         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
532         retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
533
534         if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
535                 return PMINFO_R_ERROR;
536
537         *tep_name = (char *)info->pkg_info->tep_name;
538
539         return PMINFO_R_OK;
540 }
541
542 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
543 {
544         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
545
546         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
547         retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
548
549         if (info->pkg_info == NULL)
550                 return PMINFO_R_ERROR;
551
552         if (info->pkg_info->zip_mount_file == NULL)
553                 *zip_mount_file = "";
554         else
555                 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
556
557         return PMINFO_R_OK;
558 }
559
560 API int pkgmgrinfo_pkginfo_get_external_image_path(pkgmgrinfo_pkginfo_h handle, char **ext_image_path)
561 {
562         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
563
564         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
565         retvm_if(ext_image_path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
566
567         if (info->pkg_info == NULL)
568                 return PMINFO_R_ERROR;
569
570         if (info->pkg_info->external_path == NULL)
571                 return PMINFO_R_ENOENT;
572
573         *ext_image_path = (char *)info->pkg_info->external_path;
574
575         return PMINFO_R_OK;
576 }
577
578 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
579 {
580         char *val;
581         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
582
583         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
584         retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
585
586         if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
587                 return PMINFO_R_ERROR;
588
589         val = (char *)info->pkg_info->installlocation;
590         if (strcmp(val, "internal-only") == 0)
591                 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
592         else if (strcmp(val, "prefer-external") == 0)
593                 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
594         else
595                 *location = PMINFO_INSTALL_LOCATION_AUTO;
596
597         return PMINFO_R_OK;
598 }
599
600 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
601 {
602         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
603         char *temp = NULL;
604
605         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
606         retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
607
608         if (info->pkg_info == NULL)
609                 return PMINFO_R_ERROR;
610
611         if (info->pkg_info->package_size == NULL) {
612                 temp = strdup("");
613                 if (temp == NULL) {
614                         _LOGE("out of memory");
615                         return PMINFO_R_ERROR;
616                 } else {
617                         info->pkg_info->package_size = temp;
618                 }
619         }
620
621         *size = atoi((char *)info->pkg_info->package_size);
622
623         return PMINFO_R_OK;
624 }
625
626 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
627 {
628         icon_x *ptr;
629         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
630
631         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
632         retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
633
634         if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
635                 return PMINFO_R_ERROR;
636
637         ptr = (icon_x *)info->pkg_info->icon->data;
638         if (ptr == NULL)
639                 return PMINFO_R_ERROR;
640
641         /* TODO : should we return empty string if there was no icon? */
642         if (ptr->text == NULL)
643                 *icon = "";
644         else
645                 *icon = ptr->text;
646
647         return PMINFO_R_OK;
648 }
649
650 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
651 {
652         label_x *ptr;
653         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
654
655         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
656         retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
657
658         if (info->pkg_info == NULL || info->pkg_info->label == NULL)
659                 return PMINFO_R_ERROR;
660
661         ptr = (label_x *)info->pkg_info->label->data;
662         if (ptr == NULL)
663                 return PMINFO_R_ERROR;
664
665         /* TODO : should we return empty string if there was no label? */
666         if (ptr->text == NULL)
667                 *label = "";
668         else
669                 *label = ptr->text;
670
671         return PMINFO_R_OK;
672 }
673
674 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
675 {
676         description_x *ptr;
677         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
678
679         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
680         retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
681
682         if (info->pkg_info == NULL || info->pkg_info->description == NULL)
683                 return PMINFO_R_ERROR;
684
685         ptr = (description_x *)info->pkg_info->description->data;
686         if (ptr == NULL)
687                 return PMINFO_R_ERROR;
688
689         if (ptr->text == NULL)
690                 *description = "";
691         else
692                 *description = (char *)ptr->text;
693
694         return PMINFO_R_OK;
695 }
696
697 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
698 {
699         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
700         author_x *author;
701
702         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
703         retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
704
705         if (info->pkg_info == NULL || info->pkg_info->author == NULL)
706                 return PMINFO_R_ERROR;
707
708         author = (author_x *)info->pkg_info->author->data;
709         if (author == NULL)
710                 return PMINFO_R_ERROR;
711
712         if (author->text == NULL)
713                 *author_name = "";
714         else
715                 *author_name = (char *)author->text;
716
717         return PMINFO_R_OK;
718 }
719
720 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
721 {
722         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
723         author_x *author;
724
725         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
726         retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
727
728         if (info->pkg_info == NULL || info->pkg_info->author == NULL)
729                 return PMINFO_R_ERROR;
730
731         author = (author_x *)info->pkg_info->author->data;
732         if (author == NULL)
733                 return PMINFO_R_ERROR;
734
735         if (author->email == NULL)
736                 *author_email = "";
737         else
738                 *author_email = (char *)author->email;
739
740         return PMINFO_R_OK;
741 }
742
743 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
744 {
745         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
746         author_x *author;
747
748         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
749         retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
750
751         if (info->pkg_info == NULL || info->pkg_info->author == NULL)
752                 return PMINFO_R_ERROR;
753
754         author = (author_x *)info->pkg_info->author->data;
755         if (author == NULL)
756                 return PMINFO_R_ERROR;
757
758         if (author->href == NULL)
759                 *author_href = "";
760         else
761                 *author_href = (char *)author->href;
762
763         return PMINFO_R_OK;
764 }
765
766 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
767 {
768         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
769
770         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
771         retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
772
773         if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
774                 return PMINFO_R_ERROR;
775
776         if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
777                 *storage = PMINFO_INTERNAL_STORAGE;
778         else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
779                 *storage = PMINFO_EXTERNAL_STORAGE;
780         else if (strcmp(info->pkg_info->installed_storage, "installed_extended") == 0)
781                 *storage = PMINFO_EXTENDED_STORAGE;
782         else
783                 return PMINFO_R_ERROR;
784
785         return PMINFO_R_OK;
786 }
787
788 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
789 {
790         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
791
792         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
793         retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
794
795         if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
796                 return PMINFO_R_ERROR;
797
798         *installed_time = atoi(info->pkg_info->installed_time);
799
800         return PMINFO_R_OK;
801 }
802
803 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
804 {
805         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
806
807         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
808         retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
809
810         if (info->pkg_info == NULL)
811                 return PMINFO_R_ERROR;
812
813         if (info->pkg_info->storeclient_id == NULL)
814                 *storeclientid = "";
815         else
816                 *storeclientid = (char *)info->pkg_info->storeclient_id;
817
818         return PMINFO_R_OK;
819 }
820
821 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
822 {
823         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
824
825         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
826         retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
827
828         if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
829                 return PMINFO_R_ERROR;
830
831         *mainappid = (char *)info->pkg_info->mainapp_id;
832
833         return PMINFO_R_OK;
834 }
835
836 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
837 {
838         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
839
840         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
841         retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
842
843         if (info->pkg_info == NULL)
844                 return PMINFO_R_ERROR;
845
846         if (info->pkg_info->package_url == NULL)
847                 *url = "";
848         else
849                 *url = (char *)info->pkg_info->package_url;
850
851         return PMINFO_R_OK;
852 }
853
854 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
855 {
856         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
857
858         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
859         retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
860
861         if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
862                 return PMINFO_R_ERROR;
863
864         *path = (char *)info->pkg_info->root_path;
865
866         return PMINFO_R_OK;
867 }
868
869 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
870 {
871         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
872
873         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
874         retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
875
876         if (info->pkg_info == NULL)
877                 return PMINFO_R_ERROR;
878
879         if (info->pkg_info->csc_path == NULL)
880                 *path = "";
881         else
882                 *path = (char *)info->pkg_info->csc_path;
883
884         return PMINFO_R_OK;
885 }
886
887 API int pkgmgrinfo_pkginfo_get_res_type(pkgmgrinfo_pkginfo_h handle,
888                 char **res_type)
889 {
890         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
891
892         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
893         retvm_if(res_type == NULL, PMINFO_R_EINVAL,
894                         "Argument supplied to hold return value is NULL\n");
895
896         if (info->pkg_info == NULL)
897                 return PMINFO_R_ERROR;
898
899         if (info->pkg_info->res_type == NULL)
900                 return PMINFO_R_ENOENT;
901
902         *res_type = (char *)info->pkg_info->res_type;
903
904         return PMINFO_R_OK;
905 }
906
907 API int pkgmgrinfo_pkginfo_get_res_version(pkgmgrinfo_pkginfo_h handle,
908                 char **res_version)
909 {
910         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
911
912         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
913         retvm_if(res_version == NULL, PMINFO_R_EINVAL,
914                         "Argument supplied to hold return value is NULL\n");
915
916         if (info->pkg_info == NULL)
917                 return PMINFO_R_ERROR;
918
919         if (info->pkg_info->res_version == NULL)
920                 return PMINFO_R_ENOENT;
921
922         *res_version = (char *)info->pkg_info->res_version;
923
924         return PMINFO_R_OK;
925 }
926
927 API int pkgmgrinfo_pkginfo_get_light_user_switch_mode(pkgmgrinfo_pkginfo_h handle, char **mode)
928 {
929         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
930
931         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
932         retvm_if(mode == NULL, PMINFO_R_EINVAL,
933                         "Argument supplied to hold return value is NULL\n");
934
935         if (info->pkg_info == NULL)
936                 return PMINFO_R_ERROR;
937
938         if (info->pkg_info->light_user_switch_mode == NULL)
939                 return PMINFO_R_ERROR;
940
941         *mode = (char *)info->pkg_info->light_user_switch_mode;
942
943         return PMINFO_R_OK;
944 }
945
946 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
947 {
948         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
949         retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
950
951         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
952         if (info->pkg_info->support_mode)
953                 *support_mode = atoi(info->pkg_info->support_mode);
954         else
955                 *support_mode = 0;
956
957         return PMINFO_R_OK;
958 }
959
960 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
961 {
962         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
963         retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
964
965 #if 0 /* smack issue occured, check later */
966         char *pkgid = NULL;
967         pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
968         if (pkgid == NULL) {
969                  _LOGD("invalid func parameters\n");
970                  return PMINFO_R_ERROR;
971         }
972          _LOGD("pkgmgr_get_pkg_external_validation() called\n");
973
974         FILE *fp = NULL;
975         char app_mmc_path[FILENAME_MAX] = { 0, };
976         char app_dir_path[FILENAME_MAX] = { 0, };
977         char app_mmc_internal_path[FILENAME_MAX] = { 0, };
978         snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
979         snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
980         snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
981
982         /*check whether application is in external memory or not */
983         fp = fopen(app_mmc_path, "r");
984         if (fp == NULL) {
985                 _LOGD(" app path in external memory not accesible\n");
986         } else {
987                 fclose(fp);
988                 fp = NULL;
989                 *accessible = 1;
990                 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
991                 return PMINFO_R_OK;
992         }
993
994         /*check whether application is in internal or not */
995         if (fp == NULL) {
996                 _LOGD(" app path in internal memory not accesible\n");
997                 *accessible = 0;
998                 return PMINFO_R_ERROR;
999         } else {
1000                 fclose(fp);
1001                 /*check whether the application is installed in SD card
1002                 but SD card is not present*/
1003                 fp = fopen(app_mmc_internal_path, "r");
1004                 if (fp == NULL) {
1005                         *accessible = 1;
1006                         _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1007                         return PMINFO_R_OK;
1008                 } else {
1009                         *accessible = 0;
1010                         _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1011                 }
1012                 fclose(fp);
1013         }
1014
1015         _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1016 #endif
1017
1018         *accessible = 1;
1019         return PMINFO_R_OK;
1020 }
1021
1022 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1023 {
1024         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1025
1026         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1027         retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1028
1029         if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1030                 return PMINFO_R_ERROR;
1031
1032         *removable = _get_bool_value(info->pkg_info->removable);
1033
1034         return PMINFO_R_OK;
1035 }
1036
1037 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1038 {
1039         char *val;
1040         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1041
1042         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1043         retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1044
1045         if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1046                 return PMINFO_R_ERROR;
1047
1048         val = (char *)info->pkg_info->installlocation;
1049         if (strcmp(val, "internal-only") == 0)
1050                 *movable = 0;
1051         else
1052                 *movable = 1;
1053
1054         return PMINFO_R_OK;
1055 }
1056
1057 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1058 {
1059         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1060
1061         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1062         retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1063
1064         if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1065                 return PMINFO_R_ERROR;
1066
1067         *preload = _get_bool_value(info->pkg_info->preload);
1068
1069         return PMINFO_R_OK;
1070 }
1071
1072 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1073 {
1074         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1075
1076         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1077         retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1078
1079         if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1080                 return PMINFO_R_ERROR;
1081
1082         *system = _get_bool_value(info->pkg_info->system);
1083
1084         return PMINFO_R_OK;
1085 }
1086
1087 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1088 {
1089         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1090
1091         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1092         retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1093
1094         if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1095                 return PMINFO_R_ERROR;
1096
1097         *readonly = _get_bool_value(info->pkg_info->readonly);
1098
1099         return PMINFO_R_OK;
1100 }
1101
1102 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1103 {
1104         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1105
1106         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1107         retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1108
1109         if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1110                 return PMINFO_R_ERROR;
1111
1112         *update = _get_bool_value(info->pkg_info->update);
1113
1114         return PMINFO_R_OK;
1115 }
1116
1117 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1118 {
1119         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1120
1121         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1122         retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1123
1124         if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1125                 return PMINFO_R_ERROR;
1126
1127         *support_disable = _get_bool_value(info->pkg_info->support_disable);
1128
1129         return PMINFO_R_OK;
1130 }
1131
1132 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1133 {
1134         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1135
1136         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1137         retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1138
1139         if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1140                 return PMINFO_R_ERROR;
1141
1142         *global = _get_bool_value(info->pkg_info->for_all_users);
1143
1144         return PMINFO_R_OK;
1145 }
1146
1147 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1148 {
1149         return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1150 }
1151
1152 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1153 {
1154         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1155
1156         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1157
1158         __cleanup_pkginfo(info);
1159
1160         return PMINFO_R_OK;
1161 }
1162
1163 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1164 {
1165         pkgmgrinfo_filter_x *filter;
1166
1167         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1168
1169         filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1170         if (filter == NULL) {
1171                 _LOGE("Out of Memory!!!");
1172                 return PMINFO_R_ERROR;
1173         }
1174
1175         *handle = filter;
1176
1177         return PMINFO_R_OK;
1178 }
1179
1180 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1181 {
1182         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1183
1184         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1185
1186         if (filter->list)
1187                 g_slist_free_full(filter->list,
1188                                 (GDestroyNotify)_pkgmgrinfo_node_destroy);
1189
1190         if (filter->list_metadata)
1191                 g_slist_free_full(filter->list_metadata,
1192                                 __destroy_metadata_node);
1193         if (filter->list_pkg_metadata)
1194                 g_slist_free_full(filter->list_pkg_metadata,
1195                                 __destroy_metadata_node);
1196
1197         free(filter);
1198
1199         return PMINFO_R_OK;
1200 }
1201
1202 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1203                                 const char *property, const int value)
1204 {
1205         char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1206         char *val;
1207         GSList *link;
1208         int prop;
1209         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1210         pkgmgrinfo_node_x *node;
1211
1212         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1213         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1214
1215         prop = _pminfo_pkginfo_convert_to_prop_int(property);
1216         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1217                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1218                 _LOGE("Invalid Integer Property\n");
1219                 return PMINFO_R_EINVAL;
1220         }
1221         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1222         if (node == NULL) {
1223                 _LOGE("Out of Memory!!!\n");
1224                 return PMINFO_R_ERROR;
1225         }
1226         snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1227         val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1228         if (val == NULL) {
1229                 _LOGE("Out of Memory\n");
1230                 free(node);
1231                 return PMINFO_R_ERROR;
1232         }
1233         node->prop = prop;
1234         node->value = val;
1235         /*If API is called multiple times for same property, we should override the previous values.
1236         Last value set will be used for filtering.*/
1237         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1238         if (link) {
1239                 _pkgmgrinfo_node_destroy(link->data);
1240                 filter->list = g_slist_delete_link(filter->list, link);
1241         }
1242         filter->list = g_slist_append(filter->list, (gpointer)node);
1243         return PMINFO_R_OK;
1244
1245 }
1246
1247 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1248                                 const char *property, const bool value)
1249 {
1250         char *val;
1251         GSList *link;
1252         int prop;
1253         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1254         pkgmgrinfo_node_x *node;
1255
1256         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1257         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1258
1259         prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1260         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1261                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1262                 _LOGE("Invalid Boolean Property\n");
1263                 return PMINFO_R_EINVAL;
1264         }
1265         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1266         if (node == NULL) {
1267                 _LOGE("Out of Memory!!!\n");
1268                 return PMINFO_R_ERROR;
1269         }
1270         if (value)
1271                 val = strndup("true", 4);
1272         else
1273                 val = strndup("false", 5);
1274         if (val == NULL) {
1275                 _LOGE("Out of Memory\n");
1276                 free(node);
1277                 return PMINFO_R_ERROR;
1278         }
1279         node->prop = prop;
1280         node->value = val;
1281         /*If API is called multiple times for same property, we should override the previous values.
1282         Last value set will be used for filtering.*/
1283         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1284         if (link) {
1285                 _pkgmgrinfo_node_destroy(link->data);
1286                 filter->list = g_slist_delete_link(filter->list, link);
1287         }
1288         filter->list = g_slist_append(filter->list, (gpointer)node);
1289         return PMINFO_R_OK;
1290
1291 }
1292
1293 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1294                                 const char *property, const char *value)
1295 {
1296         char *val;
1297         GSList *link;
1298         int prop;
1299         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1300         pkgmgrinfo_node_x *node;
1301
1302         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1303         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1304         retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1305
1306         prop = _pminfo_pkginfo_convert_to_prop_str(property);
1307         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1308                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1309                 _LOGE("Invalid String Property\n");
1310                 return PMINFO_R_EINVAL;
1311         }
1312         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1313         if (node == NULL) {
1314                 _LOGE("Out of Memory!!!\n");
1315                 return PMINFO_R_ERROR;
1316         }
1317         if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1318                 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1319         else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1320                 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1321         else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1322                 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1323         else if (strcmp(value, "installed_internal") == 0)
1324                 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1325         else if (strcmp(value, "installed_external") == 0)
1326                 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1327         else
1328                 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1329         if (val == NULL) {
1330                 _LOGE("Out of Memory\n");
1331                 free(node);
1332                 return PMINFO_R_ERROR;
1333         }
1334         node->prop = prop;
1335         node->value = val;
1336         /*If API is called multiple times for same property, we should override the previous values.
1337         Last value set will be used for filtering.*/
1338         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1339         if (link) {
1340                 _pkgmgrinfo_node_destroy(link->data);
1341                 filter->list = g_slist_delete_link(filter->list, link);
1342         }
1343         filter->list = g_slist_append(filter->list, (gpointer)node);
1344         return PMINFO_R_OK;
1345
1346 }
1347
1348 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1349 {
1350         int ret;
1351         int query_count;
1352         GHashTable *list = NULL;
1353
1354         if (handle == NULL || count == NULL) {
1355                 _LOGE("invalid parameter");
1356                 return PMINFO_R_EINVAL;
1357         }
1358
1359         list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1360                         __free_packages);
1361         if (list == NULL)
1362                 return PMINFO_R_ERROR;
1363
1364         if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1365                 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1366                                 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1367                 if (ret != PMINFO_R_OK) {
1368                         g_hash_table_destroy(list);
1369                         return PMINFO_R_ERROR;
1370                 }
1371         }
1372
1373         ret = _pkginfo_get_packages(uid, handle, PMINFO_PKGINFO_GET_BASICINFO, list);
1374         query_count = g_hash_table_size(list);
1375         g_hash_table_destroy(list);
1376         if (ret == PMINFO_R_ERROR)
1377                 return ret;
1378         *count = query_count;
1379         return PMINFO_R_OK;
1380 }
1381
1382 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1383 {
1384         return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1385 }
1386
1387 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1388                 pkgmgrinfo_pkginfo_filter_h handle,
1389                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1390 {
1391         if (handle == NULL || pkg_cb == NULL) {
1392                 LOGE("invalid parameter");
1393                 return PMINFO_R_EINVAL;
1394         }
1395
1396         return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1397                         PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1398 }
1399
1400 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1401                                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1402 {
1403         return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1404 }
1405
1406 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1407                         pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1408 {
1409         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1410         retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1411         int ret;
1412         privilege_x *privilege;
1413         appdefined_privilege_x *appdefined_privilege;
1414         GList *tmp;
1415         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1416
1417         if (info->pkg_info == NULL)
1418                 return PMINFO_R_ERROR;
1419
1420         for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1421                 privilege = (privilege_x *)tmp->data;
1422                 if (privilege == NULL)
1423                         continue;
1424                 ret = privilege_func(privilege->value, user_data);
1425                 if (ret < 0)
1426                         return PMINFO_R_OK;
1427         }
1428
1429         for (tmp = info->pkg_info->appdefined_privileges; tmp;
1430                         tmp = tmp->next) {
1431                 appdefined_privilege = (appdefined_privilege_x *)tmp->data;
1432                 if (appdefined_privilege == NULL)
1433                         continue;
1434                 ret = privilege_func(appdefined_privilege->value, user_data);
1435                 if (ret < 0)
1436                         return PMINFO_R_OK;
1437         }
1438         return PMINFO_R_OK;
1439 }
1440
1441 API int pkgmgrinfo_pkginfo_foreach_plugin(pkgmgrinfo_pkginfo_h handle,
1442                         pkgmgrinfo_plugin_list_cb plugin_func, void *user_data)
1443 {
1444         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1445         retvm_if(plugin_func == NULL, PMINFO_R_EINVAL,
1446                         "Callback function is NULL");
1447         int ret;
1448         plugin_x *plugin;
1449         GList *tmp;
1450         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1451
1452         if (info->pkg_info == NULL)
1453                 return PMINFO_R_ERROR;
1454
1455         for (tmp = info->pkg_info->plugin; tmp; tmp = tmp->next) {
1456                 plugin = (plugin_x *)tmp->data;
1457                 if (plugin == NULL)
1458                         continue;
1459                 ret = plugin_func(plugin->pkgid, plugin->appid,
1460                                 plugin->plugin_type, plugin->plugin_name, user_data);
1461                 if (ret < 0)
1462                         return PMINFO_R_OK;
1463         }
1464
1465         return PMINFO_R_OK;
1466 }
1467
1468 API int pkgmgrinfo_pkginfo_foreach_appdefined_privilege(
1469                 pkgmgrinfo_pkginfo_h handle,
1470                 pkgmgrinfo_pkg_appdefined_privilege_list_cb privilege_func,
1471                 void *user_data)
1472 {
1473         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1474         retvm_if(privilege_func == NULL, PMINFO_R_EINVAL,
1475                         "Callback function is NULL");
1476         int ret;
1477         appdefined_privilege_x *privilege;
1478         GList *tmp;
1479         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1480
1481         if (info->pkg_info == NULL)
1482                 return PMINFO_R_ERROR;
1483
1484         for (tmp = info->pkg_info->appdefined_privileges; tmp;
1485                         tmp = tmp->next) {
1486                 privilege = (appdefined_privilege_x *)tmp->data;
1487                 if (privilege == NULL)
1488                         continue;
1489                 ret = privilege_func(privilege->value, privilege->license,
1490                                 user_data);
1491                 if (ret < 0)
1492                         break;
1493         }
1494         return PMINFO_R_OK;
1495 }
1496
1497 API int pkgmgrinfo_pkginfo_foreach_dependency(pkgmgrinfo_pkginfo_h handle,
1498                 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1499                 void *user_data)
1500 {
1501         int ret;
1502         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1503         GList *tmp;
1504         dependency_x *dependency;
1505
1506         if (handle == NULL || dependency_cb == NULL) {
1507                 LOGE("invalid parameter");
1508                 return PMINFO_R_EINVAL;
1509         }
1510
1511         if (info->pkg_info == NULL)
1512                 return PMINFO_R_ERROR;
1513
1514         for (tmp = info->pkg_info->dependencies; tmp; tmp = tmp->next) {
1515                 dependency = (dependency_x *)tmp->data;
1516                 if (dependency == NULL)
1517                         continue;
1518                 ret = dependency_cb(info->pkg_info->package,
1519                                 dependency->depends_on, dependency->type,
1520                                 dependency->required_version, user_data);
1521                 if (ret < 0)
1522                         break;
1523         }
1524
1525         return PMINFO_R_OK;
1526 }
1527
1528 static void __free_depends_on(gpointer data)
1529 {
1530         dependency_x *dep = (dependency_x *)data;
1531         pkgmgrinfo_basic_free_dependency(dep);
1532 }
1533
1534 /* This API is not exported at the header file */
1535 API int pkgmgrinfo_pkginfo_foreach_depends_on_by_pkgid(const char *pkgid,
1536                 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1537                 void *user_data, uid_t uid)
1538 {
1539         int ret;
1540         GList *pkg_list = NULL;
1541         GList *l;
1542         dependency_x *dep;
1543
1544         if (pkgid == NULL || dependency_cb == NULL) {
1545                 LOGE("invalid parameter");
1546                 return PMINFO_R_EINVAL;
1547         }
1548
1549         ret = _pkginfo_get_depends_on(uid, pkgid, &pkg_list);
1550         if (ret != PMINFO_R_OK)
1551                 return PMINFO_R_ERROR;
1552
1553         for (l = pkg_list; l != NULL; l = g_list_next(l)) {
1554                 dep = (dependency_x *)l->data;
1555                 ret = dependency_cb(dep->pkgid, dep->depends_on,
1556                                 dep->type, dep->required_version, user_data);
1557                 if (ret < 0)
1558                         break;
1559         }
1560         g_list_free_full(pkg_list, __free_depends_on);
1561
1562         return PMINFO_R_OK;
1563 }
1564
1565 API int pkgmgrinfo_pkginfo_foreach_depends_on(pkgmgrinfo_pkginfo_h handle,
1566                 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1567                 void *user_data)
1568 {
1569         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1570
1571         if (handle == NULL || dependency_cb == NULL || info->pkg_info == NULL) {
1572                 LOGE("invalid parameter");
1573                 return PMINFO_R_EINVAL;
1574         }
1575
1576         return pkgmgrinfo_pkginfo_foreach_depends_on_by_pkgid(
1577                         info->pkg_info->package, dependency_cb, user_data,
1578                         info->uid);
1579 }
1580
1581 API int pkgmgrinfo_pkginfo_foreach_res_allowed_package(
1582                 pkgmgrinfo_pkginfo_h handle,
1583                 pkgmgrinfo_res_allowed_package_list_cb res_allowed_package_cb,
1584                 void *user_data)
1585 {
1586         int ret;
1587         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1588         GList *res_pkgs;
1589         res_allowed_package_x *res_allowed_package;
1590
1591         if (handle == NULL || res_allowed_package_cb == NULL) {
1592                 LOGE("invalid parameter");
1593                 return PMINFO_R_EINVAL;
1594         }
1595
1596         if (info->pkg_info == NULL)
1597                 return PMINFO_R_ERROR;
1598
1599         for (res_pkgs = info->pkg_info->res_allowed_packages; res_pkgs;
1600                         res_pkgs = res_pkgs->next) {
1601                 res_allowed_package = (res_allowed_package_x *)res_pkgs->data;
1602                 if (res_allowed_package == NULL)
1603                         continue;
1604
1605                 ret = res_allowed_package_cb(
1606                                 res_allowed_package->allowed_package,
1607                                 res_allowed_package->required_privileges,
1608                                 user_data);
1609                 if (ret < 0)
1610                         return PMINFO_R_OK;
1611         }
1612
1613         return PMINFO_R_OK;
1614 }
1615
1616 API int pkgmgrinfo_pkginfo_foreach_required_privilege(
1617                 required_privilege_h handle,
1618                 pkgmgrinfo_pkg_privilege_list_cb privilege_func,
1619                 void *user_data)
1620 {
1621         int ret;
1622         GList *privs;
1623
1624         if (privilege_func == NULL) {
1625                 LOGE("invalid parameter");
1626                 return PMINFO_R_EINVAL;
1627         }
1628
1629         for (privs = (GList *)handle; privs; privs = privs->next) {
1630                 ret = privilege_func((char *)privs->data, user_data);
1631                 if (ret < 0)
1632                         return PMINFO_R_OK;
1633         }
1634
1635         return PMINFO_R_OK;
1636 }
1637
1638 int __compare_package_version(const char *version, int *major,
1639                 int *minor, int *macro, int *nano)
1640 {
1641         char *version_temp = NULL;
1642         char *major_str = NULL;
1643         char *minor_str = NULL;
1644         char *macro_str = NULL;
1645         char *nano_str = NULL;
1646         char *save_str = NULL;
1647
1648         if (version == NULL || major == NULL || minor == NULL ||
1649                 macro == NULL || nano == NULL) {
1650                 return PMINFO_R_EINVAL;
1651         }
1652
1653         version_temp = strdup(version);
1654         if (version_temp == NULL) {
1655                 LOGE("Out of memory");
1656                 return PMINFO_R_ERROR;
1657         }
1658
1659         major_str = strtok_r(version_temp, ".", &save_str);
1660         if (major_str == NULL) {
1661                 _LOGE("major version is NULL");
1662                 free(version_temp);
1663                 return PMINFO_R_ERROR;
1664         }
1665
1666         minor_str = strtok_r(NULL, ".", &save_str);
1667         if (minor_str == NULL) {
1668                 _LOGE("minor version is NULL");
1669                 free(version_temp);
1670                 return PMINFO_R_ERROR;
1671         }
1672
1673         *major = atoi(major_str);
1674         *minor = atoi(minor_str);
1675         *macro = 0;
1676         *nano = 0;
1677         macro_str = strtok_r(NULL, ".", &save_str);
1678         if (macro_str == NULL) {
1679                 _LOGD("macro version is NULL");
1680         } else {
1681                 *macro = atoi(macro_str);
1682                 nano_str = strtok_r(NULL, ".", &save_str);
1683                 if (nano_str) {
1684                         *nano = atoi(nano_str);
1685                         _LOGD("nano version exists");
1686                 }
1687         }
1688         _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1689                 " macro = [%d], nano = [%d]", version, *major,
1690                 *minor, *macro, *nano);
1691
1692         free(version_temp);
1693
1694         return PMINFO_R_OK;
1695 }
1696
1697 API int pkgmgrinfo_compare_package_version(const char *current_version,
1698                 const char *target_version,
1699                 pkgmgrinfo_version_compare_type *res)
1700 {
1701         int ret = 0;
1702         int current_version_major = 0;
1703         int current_version_minor = 0;
1704         int current_version_macro = 0;
1705         int current_version_nano = 0;
1706         int target_version_major = 0;
1707         int target_version_minor = 0;
1708         int target_version_macro = 0;
1709         int target_version_nano = 0;
1710
1711         if (current_version == NULL || target_version == NULL ||
1712                 res == NULL) {
1713                 _LOGE("Invalid parameter");
1714                 return PMINFO_R_EINVAL;
1715         }
1716
1717         ret = __compare_package_version(target_version,
1718                 &target_version_major, &target_version_minor,
1719                 &target_version_macro, &target_version_nano);
1720         if (ret < 0) {
1721                 _LOGE("Failed to compare target version(%d)", ret);
1722                 return PMINFO_R_ERROR;
1723         }
1724
1725         ret = __compare_package_version(current_version,
1726                 &current_version_major, &current_version_minor,
1727                 &current_version_macro, &current_version_nano);
1728         if (ret < 0) {
1729                 _LOGE("Failed to compare current version(%d)", ret);
1730                 return PMINFO_R_ERROR;
1731         }
1732
1733         _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
1734                 target_version_minor, target_version_macro,
1735                 target_version_nano, current_version_major,
1736                 current_version_minor, current_version_macro,
1737                 target_version_nano);
1738
1739         if (target_version_major > current_version_major)
1740                 *res = PMINFO_VERSION_NEW;
1741         else if (target_version_major < current_version_major)
1742                 *res = PMINFO_VERSION_OLD;
1743         else if (target_version_minor > current_version_minor)
1744                 *res = PMINFO_VERSION_NEW;
1745         else if (target_version_minor < current_version_minor)
1746                 *res = PMINFO_VERSION_OLD;
1747         else if (target_version_macro > current_version_macro)
1748                 *res = PMINFO_VERSION_NEW;
1749         else if (target_version_macro < current_version_macro)
1750                 *res = PMINFO_VERSION_OLD;
1751         else if (target_version_nano > current_version_nano)
1752                 *res = PMINFO_VERSION_NEW;
1753         else if (target_version_nano < current_version_nano)
1754                 *res = PMINFO_VERSION_OLD;
1755         else
1756                 *res = PMINFO_VERSION_SAME;
1757
1758         return PMINFO_R_OK;
1759 }
1760
1761 API int pkgmgrinfo_pkginfo_foreach_metadata(pkgmgrinfo_pkginfo_h handle,
1762                 pkgmgrinfo_pkg_metadata_list_cb metadata_func, void *user_data)
1763 {
1764         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1765         retvm_if(metadata_func == NULL, PMINFO_R_EINVAL,
1766                         "Callback function is NULL");
1767         int ret = -1;
1768         metadata_x *ptr;
1769         GList *tmp;
1770         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1771
1772         if (info->pkg_info == NULL)
1773                 return PMINFO_R_ERROR;
1774
1775         for (tmp = info->pkg_info->metadata; tmp; tmp = tmp->next) {
1776                 ptr = (metadata_x *)tmp->data;
1777                 if (ptr == NULL)
1778                         continue;
1779                 if (ptr->key) {
1780                         ret = metadata_func(ptr->key, ptr->value ?
1781                                         ptr->value : "", user_data);
1782                         if (ret < 0)
1783                                 break;
1784                 }
1785         }
1786         return PMINFO_R_OK;
1787 }
1788
1789 API int pkgmgrinfo_pkginfo_metadata_filter_create(
1790                 pkgmgrinfo_pkginfo_metadata_filter_h *handle)
1791 {
1792         return pkgmgrinfo_pkginfo_filter_create(handle);
1793 }
1794
1795 API int pkgmgrinfo_pkginfo_metadata_filter_destroy(
1796                 pkgmgrinfo_pkginfo_metadata_filter_h handle)
1797 {
1798         return pkgmgrinfo_pkginfo_filter_destroy(handle);
1799 }
1800
1801 API int pkgmgrinfo_pkginfo_metadata_filter_add(
1802                 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1803                 const char *key, const char *value)
1804 {
1805         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1806         pkgmgrinfo_metadata_node_x *node;
1807
1808         /* value can be NULL.
1809          * In that case all pkgs with specified key should be displayed
1810          */
1811         if (handle == NULL || key == NULL) {
1812                 LOGE("invalid parameter");
1813                 return PMINFO_R_EINVAL;
1814         }
1815
1816         node = calloc(1, sizeof(pkgmgrinfo_metadata_node_x));
1817         if (node == NULL) {
1818                 LOGE("out of memory");
1819                 return PMINFO_R_ERROR;
1820         }
1821
1822         node->key = strdup(key);
1823         if (value && strlen(value))
1824                 node->value = strdup(value);
1825
1826         filter->list_pkg_metadata = g_slist_append(filter->list_pkg_metadata,
1827                         (gpointer)node);
1828
1829         return PMINFO_R_OK;
1830 }
1831
1832 API int pkgmgrinfo_pkginfo_usr_metadata_filter_foreach(
1833                 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1834                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1835 {
1836         if (handle == NULL || pkg_cb == NULL) {
1837                 LOGE("invalid parameter");
1838                 return PMINFO_R_EINVAL;
1839         }
1840
1841         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1842
1843         if (pkgmgrinfo_pkginfo_filter_add_bool(filter,
1844                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false))
1845                 return PMINFO_R_ERROR;
1846
1847         return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1848                         PMINFO_PKGINFO_GET_ALL, pkg_cb,
1849                         user_data);
1850 }
1851
1852 API int pkgmgrinfo_pkginfo_metadata_filter_foreach(
1853                 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1854                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1855 {
1856         return pkgmgrinfo_pkginfo_usr_metadata_filter_foreach(handle, pkg_cb,
1857                         user_data, _getuid());
1858 }