Add pkgmgrinfo_pkginfo_get_metadata_value()
[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_is_lib(pkgmgrinfo_pkginfo_h handle, bool *lib)
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         retvm_if(lib == NULL, PMINFO_R_EINVAL,
1158                         "Argument supplied to hold return value is NULL\n");
1159
1160         if (info->pkg_info == NULL || info->pkg_info->lib == NULL)
1161                 return PMINFO_R_ERROR;
1162
1163         *lib = _get_bool_value(info->pkg_info->lib);
1164
1165         return PMINFO_R_OK;
1166 }
1167
1168 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1169 {
1170         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1171
1172         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1173
1174         __cleanup_pkginfo(info);
1175
1176         return PMINFO_R_OK;
1177 }
1178
1179 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1180 {
1181         pkgmgrinfo_filter_x *filter;
1182
1183         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1184
1185         filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1186         if (filter == NULL) {
1187                 _LOGE("Out of Memory!!!");
1188                 return PMINFO_R_ERROR;
1189         }
1190
1191         *handle = filter;
1192
1193         return PMINFO_R_OK;
1194 }
1195
1196 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1197 {
1198         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1199
1200         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1201
1202         if (filter->list)
1203                 g_slist_free_full(filter->list,
1204                                 (GDestroyNotify)_pkgmgrinfo_node_destroy);
1205
1206         if (filter->list_metadata)
1207                 g_slist_free_full(filter->list_metadata,
1208                                 __destroy_metadata_node);
1209         if (filter->list_pkg_metadata)
1210                 g_slist_free_full(filter->list_pkg_metadata,
1211                                 __destroy_metadata_node);
1212
1213         free(filter);
1214
1215         return PMINFO_R_OK;
1216 }
1217
1218 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1219                                 const char *property, const int value)
1220 {
1221         char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1222         char *val;
1223         GSList *link;
1224         int prop;
1225         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1226         pkgmgrinfo_node_x *node;
1227
1228         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1229         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1230
1231         prop = _pminfo_pkginfo_convert_to_prop_int(property);
1232         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1233                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1234                 _LOGE("Invalid Integer Property\n");
1235                 return PMINFO_R_EINVAL;
1236         }
1237         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1238         if (node == NULL) {
1239                 _LOGE("Out of Memory!!!\n");
1240                 return PMINFO_R_ERROR;
1241         }
1242         snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1243         val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1244         if (val == NULL) {
1245                 _LOGE("Out of Memory\n");
1246                 free(node);
1247                 return PMINFO_R_ERROR;
1248         }
1249         node->prop = prop;
1250         node->value = val;
1251         /*If API is called multiple times for same property, we should override the previous values.
1252         Last value set will be used for filtering.*/
1253         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1254         if (link) {
1255                 _pkgmgrinfo_node_destroy(link->data);
1256                 filter->list = g_slist_delete_link(filter->list, link);
1257         }
1258         filter->list = g_slist_append(filter->list, (gpointer)node);
1259         return PMINFO_R_OK;
1260
1261 }
1262
1263 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1264                                 const char *property, const bool value)
1265 {
1266         char *val;
1267         GSList *link;
1268         int prop;
1269         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1270         pkgmgrinfo_node_x *node;
1271
1272         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1273         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1274
1275         prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1276         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1277                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1278                 _LOGE("Invalid Boolean Property\n");
1279                 return PMINFO_R_EINVAL;
1280         }
1281         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1282         if (node == NULL) {
1283                 _LOGE("Out of Memory!!!\n");
1284                 return PMINFO_R_ERROR;
1285         }
1286         if (value)
1287                 val = strndup("true", 4);
1288         else
1289                 val = strndup("false", 5);
1290         if (val == NULL) {
1291                 _LOGE("Out of Memory\n");
1292                 free(node);
1293                 return PMINFO_R_ERROR;
1294         }
1295         node->prop = prop;
1296         node->value = val;
1297         /*If API is called multiple times for same property, we should override the previous values.
1298         Last value set will be used for filtering.*/
1299         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1300         if (link) {
1301                 _pkgmgrinfo_node_destroy(link->data);
1302                 filter->list = g_slist_delete_link(filter->list, link);
1303         }
1304         filter->list = g_slist_append(filter->list, (gpointer)node);
1305         return PMINFO_R_OK;
1306
1307 }
1308
1309 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1310                                 const char *property, const char *value)
1311 {
1312         char *val;
1313         GSList *link;
1314         int prop;
1315         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1316         pkgmgrinfo_node_x *node;
1317
1318         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1319         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1320         retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1321
1322         prop = _pminfo_pkginfo_convert_to_prop_str(property);
1323         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1324                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1325                 _LOGE("Invalid String Property\n");
1326                 return PMINFO_R_EINVAL;
1327         }
1328         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1329         if (node == NULL) {
1330                 _LOGE("Out of Memory!!!\n");
1331                 return PMINFO_R_ERROR;
1332         }
1333         if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1334                 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1335         else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1336                 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1337         else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1338                 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1339         else if (strcmp(value, "installed_internal") == 0)
1340                 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1341         else if (strcmp(value, "installed_external") == 0)
1342                 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1343         else
1344                 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1345         if (val == NULL) {
1346                 _LOGE("Out of Memory\n");
1347                 free(node);
1348                 return PMINFO_R_ERROR;
1349         }
1350         node->prop = prop;
1351         node->value = val;
1352         /*If API is called multiple times for same property, we should override the previous values.
1353         Last value set will be used for filtering.*/
1354         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1355         if (link) {
1356                 _pkgmgrinfo_node_destroy(link->data);
1357                 filter->list = g_slist_delete_link(filter->list, link);
1358         }
1359         filter->list = g_slist_append(filter->list, (gpointer)node);
1360         return PMINFO_R_OK;
1361
1362 }
1363
1364 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1365 {
1366         int ret;
1367         int query_count;
1368         GHashTable *list = NULL;
1369
1370         if (handle == NULL || count == NULL) {
1371                 _LOGE("invalid parameter");
1372                 return PMINFO_R_EINVAL;
1373         }
1374
1375         list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1376                         __free_packages);
1377         if (list == NULL)
1378                 return PMINFO_R_ERROR;
1379
1380         if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1381                 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1382                                 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1383                 if (ret != PMINFO_R_OK) {
1384                         g_hash_table_destroy(list);
1385                         return PMINFO_R_ERROR;
1386                 }
1387         }
1388
1389         ret = _pkginfo_get_packages(uid, handle, PMINFO_PKGINFO_GET_BASICINFO, list);
1390         query_count = g_hash_table_size(list);
1391         g_hash_table_destroy(list);
1392         if (ret == PMINFO_R_ERROR)
1393                 return ret;
1394         *count = query_count;
1395         return PMINFO_R_OK;
1396 }
1397
1398 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1399 {
1400         return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1401 }
1402
1403 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1404                 pkgmgrinfo_pkginfo_filter_h handle,
1405                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1406 {
1407         if (handle == NULL || pkg_cb == NULL) {
1408                 LOGE("invalid parameter");
1409                 return PMINFO_R_EINVAL;
1410         }
1411
1412         return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1413                         PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1414 }
1415
1416 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1417                                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1418 {
1419         return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1420 }
1421
1422 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1423                         pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1424 {
1425         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1426         retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1427         int ret;
1428         privilege_x *privilege;
1429         appdefined_privilege_x *appdefined_privilege;
1430         GList *tmp;
1431         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1432
1433         if (info->pkg_info == NULL)
1434                 return PMINFO_R_ERROR;
1435
1436         for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1437                 privilege = (privilege_x *)tmp->data;
1438                 if (privilege == NULL)
1439                         continue;
1440                 ret = privilege_func(privilege->value, user_data);
1441                 if (ret < 0)
1442                         return PMINFO_R_OK;
1443         }
1444
1445         for (tmp = info->pkg_info->appdefined_privileges; tmp;
1446                         tmp = tmp->next) {
1447                 appdefined_privilege = (appdefined_privilege_x *)tmp->data;
1448                 if (appdefined_privilege == NULL)
1449                         continue;
1450                 ret = privilege_func(appdefined_privilege->value, user_data);
1451                 if (ret < 0)
1452                         return PMINFO_R_OK;
1453         }
1454         return PMINFO_R_OK;
1455 }
1456
1457 API int pkgmgrinfo_pkginfo_foreach_plugin(pkgmgrinfo_pkginfo_h handle,
1458                         pkgmgrinfo_plugin_list_cb plugin_func, void *user_data)
1459 {
1460         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1461         retvm_if(plugin_func == NULL, PMINFO_R_EINVAL,
1462                         "Callback function is NULL");
1463         int ret;
1464         plugin_x *plugin;
1465         GList *tmp;
1466         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1467
1468         if (info->pkg_info == NULL)
1469                 return PMINFO_R_ERROR;
1470
1471         for (tmp = info->pkg_info->plugin; tmp; tmp = tmp->next) {
1472                 plugin = (plugin_x *)tmp->data;
1473                 if (plugin == NULL)
1474                         continue;
1475                 ret = plugin_func(plugin->pkgid, plugin->appid,
1476                                 plugin->plugin_type, plugin->plugin_name, user_data);
1477                 if (ret < 0)
1478                         return PMINFO_R_OK;
1479         }
1480
1481         return PMINFO_R_OK;
1482 }
1483
1484 API int pkgmgrinfo_pkginfo_foreach_appdefined_privilege(
1485                 pkgmgrinfo_pkginfo_h handle,
1486                 pkgmgrinfo_pkg_appdefined_privilege_list_cb privilege_func,
1487                 void *user_data)
1488 {
1489         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1490         retvm_if(privilege_func == NULL, PMINFO_R_EINVAL,
1491                         "Callback function is NULL");
1492         int ret;
1493         appdefined_privilege_x *privilege;
1494         GList *tmp;
1495         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1496
1497         if (info->pkg_info == NULL)
1498                 return PMINFO_R_ERROR;
1499
1500         for (tmp = info->pkg_info->appdefined_privileges; tmp;
1501                         tmp = tmp->next) {
1502                 privilege = (appdefined_privilege_x *)tmp->data;
1503                 if (privilege == NULL)
1504                         continue;
1505                 ret = privilege_func(privilege->value, privilege->license,
1506                                 user_data);
1507                 if (ret < 0)
1508                         break;
1509         }
1510         return PMINFO_R_OK;
1511 }
1512
1513 API int pkgmgrinfo_pkginfo_foreach_dependency(pkgmgrinfo_pkginfo_h handle,
1514                 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1515                 void *user_data)
1516 {
1517         int ret;
1518         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1519         GList *tmp;
1520         dependency_x *dependency;
1521
1522         if (handle == NULL || dependency_cb == NULL) {
1523                 LOGE("invalid parameter");
1524                 return PMINFO_R_EINVAL;
1525         }
1526
1527         if (info->pkg_info == NULL)
1528                 return PMINFO_R_ERROR;
1529
1530         for (tmp = info->pkg_info->dependencies; tmp; tmp = tmp->next) {
1531                 dependency = (dependency_x *)tmp->data;
1532                 if (dependency == NULL)
1533                         continue;
1534                 ret = dependency_cb(info->pkg_info->package,
1535                                 dependency->depends_on, dependency->type,
1536                                 dependency->required_version, user_data);
1537                 if (ret < 0)
1538                         break;
1539         }
1540
1541         return PMINFO_R_OK;
1542 }
1543
1544 static void __free_depends_on(gpointer data)
1545 {
1546         dependency_x *dep = (dependency_x *)data;
1547         pkgmgrinfo_basic_free_dependency(dep);
1548 }
1549
1550 /* This API is not exported at the header file */
1551 API int pkgmgrinfo_pkginfo_foreach_depends_on_by_pkgid(const char *pkgid,
1552                 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1553                 void *user_data, uid_t uid)
1554 {
1555         int ret;
1556         GList *pkg_list = NULL;
1557         GList *l;
1558         dependency_x *dep;
1559
1560         if (pkgid == NULL || dependency_cb == NULL) {
1561                 LOGE("invalid parameter");
1562                 return PMINFO_R_EINVAL;
1563         }
1564
1565         ret = _pkginfo_get_depends_on(uid, pkgid, &pkg_list);
1566         if (ret != PMINFO_R_OK)
1567                 return PMINFO_R_ERROR;
1568
1569         for (l = pkg_list; l != NULL; l = g_list_next(l)) {
1570                 dep = (dependency_x *)l->data;
1571                 ret = dependency_cb(dep->pkgid, dep->depends_on,
1572                                 dep->type, dep->required_version, user_data);
1573                 if (ret < 0)
1574                         break;
1575         }
1576         g_list_free_full(pkg_list, __free_depends_on);
1577
1578         return PMINFO_R_OK;
1579 }
1580
1581 API int pkgmgrinfo_pkginfo_foreach_depends_on(pkgmgrinfo_pkginfo_h handle,
1582                 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1583                 void *user_data)
1584 {
1585         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1586
1587         if (handle == NULL || dependency_cb == NULL || info->pkg_info == NULL) {
1588                 LOGE("invalid parameter");
1589                 return PMINFO_R_EINVAL;
1590         }
1591
1592         return pkgmgrinfo_pkginfo_foreach_depends_on_by_pkgid(
1593                         info->pkg_info->package, dependency_cb, user_data,
1594                         info->uid);
1595 }
1596
1597 API int pkgmgrinfo_pkginfo_foreach_res_allowed_package(
1598                 pkgmgrinfo_pkginfo_h handle,
1599                 pkgmgrinfo_res_allowed_package_list_cb res_allowed_package_cb,
1600                 void *user_data)
1601 {
1602         int ret;
1603         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1604         GList *res_pkgs;
1605         res_allowed_package_x *res_allowed_package;
1606
1607         if (handle == NULL || res_allowed_package_cb == NULL) {
1608                 LOGE("invalid parameter");
1609                 return PMINFO_R_EINVAL;
1610         }
1611
1612         if (info->pkg_info == NULL)
1613                 return PMINFO_R_ERROR;
1614
1615         for (res_pkgs = info->pkg_info->res_allowed_packages; res_pkgs;
1616                         res_pkgs = res_pkgs->next) {
1617                 res_allowed_package = (res_allowed_package_x *)res_pkgs->data;
1618                 if (res_allowed_package == NULL)
1619                         continue;
1620
1621                 ret = res_allowed_package_cb(
1622                                 res_allowed_package->allowed_package,
1623                                 res_allowed_package->required_privileges,
1624                                 user_data);
1625                 if (ret < 0)
1626                         return PMINFO_R_OK;
1627         }
1628
1629         return PMINFO_R_OK;
1630 }
1631
1632 API int pkgmgrinfo_pkginfo_foreach_required_privilege(
1633                 required_privilege_h handle,
1634                 pkgmgrinfo_pkg_privilege_list_cb privilege_func,
1635                 void *user_data)
1636 {
1637         int ret;
1638         GList *privs;
1639
1640         if (privilege_func == NULL) {
1641                 LOGE("invalid parameter");
1642                 return PMINFO_R_EINVAL;
1643         }
1644
1645         for (privs = (GList *)handle; privs; privs = privs->next) {
1646                 ret = privilege_func((char *)privs->data, user_data);
1647                 if (ret < 0)
1648                         return PMINFO_R_OK;
1649         }
1650
1651         return PMINFO_R_OK;
1652 }
1653
1654 int __compare_package_version(const char *version, int *major,
1655                 int *minor, int *macro, int *nano)
1656 {
1657         char *version_temp = NULL;
1658         char *major_str = NULL;
1659         char *minor_str = NULL;
1660         char *macro_str = NULL;
1661         char *nano_str = NULL;
1662         char *save_str = NULL;
1663
1664         if (version == NULL || major == NULL || minor == NULL ||
1665                 macro == NULL || nano == NULL) {
1666                 return PMINFO_R_EINVAL;
1667         }
1668
1669         version_temp = strdup(version);
1670         if (version_temp == NULL) {
1671                 LOGE("Out of memory");
1672                 return PMINFO_R_ERROR;
1673         }
1674
1675         major_str = strtok_r(version_temp, ".", &save_str);
1676         if (major_str == NULL) {
1677                 _LOGE("major version is NULL");
1678                 free(version_temp);
1679                 return PMINFO_R_ERROR;
1680         }
1681
1682         minor_str = strtok_r(NULL, ".", &save_str);
1683         if (minor_str == NULL) {
1684                 _LOGE("minor version is NULL");
1685                 free(version_temp);
1686                 return PMINFO_R_ERROR;
1687         }
1688
1689         *major = atoi(major_str);
1690         *minor = atoi(minor_str);
1691         *macro = 0;
1692         *nano = 0;
1693         macro_str = strtok_r(NULL, ".", &save_str);
1694         if (macro_str == NULL) {
1695                 _LOGD("macro version is NULL");
1696         } else {
1697                 *macro = atoi(macro_str);
1698                 nano_str = strtok_r(NULL, ".", &save_str);
1699                 if (nano_str) {
1700                         *nano = atoi(nano_str);
1701                         _LOGD("nano version exists");
1702                 }
1703         }
1704         _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1705                 " macro = [%d], nano = [%d]", version, *major,
1706                 *minor, *macro, *nano);
1707
1708         free(version_temp);
1709
1710         return PMINFO_R_OK;
1711 }
1712
1713 API int pkgmgrinfo_compare_package_version(const char *current_version,
1714                 const char *target_version,
1715                 pkgmgrinfo_version_compare_type *res)
1716 {
1717         int ret = 0;
1718         int current_version_major = 0;
1719         int current_version_minor = 0;
1720         int current_version_macro = 0;
1721         int current_version_nano = 0;
1722         int target_version_major = 0;
1723         int target_version_minor = 0;
1724         int target_version_macro = 0;
1725         int target_version_nano = 0;
1726
1727         if (current_version == NULL || target_version == NULL ||
1728                 res == NULL) {
1729                 _LOGE("Invalid parameter");
1730                 return PMINFO_R_EINVAL;
1731         }
1732
1733         ret = __compare_package_version(target_version,
1734                 &target_version_major, &target_version_minor,
1735                 &target_version_macro, &target_version_nano);
1736         if (ret < 0) {
1737                 _LOGE("Failed to compare target version(%d)", ret);
1738                 return PMINFO_R_ERROR;
1739         }
1740
1741         ret = __compare_package_version(current_version,
1742                 &current_version_major, &current_version_minor,
1743                 &current_version_macro, &current_version_nano);
1744         if (ret < 0) {
1745                 _LOGE("Failed to compare current version(%d)", ret);
1746                 return PMINFO_R_ERROR;
1747         }
1748
1749         _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
1750                 target_version_minor, target_version_macro,
1751                 target_version_nano, current_version_major,
1752                 current_version_minor, current_version_macro,
1753                 target_version_nano);
1754
1755         if (target_version_major > current_version_major)
1756                 *res = PMINFO_VERSION_NEW;
1757         else if (target_version_major < current_version_major)
1758                 *res = PMINFO_VERSION_OLD;
1759         else if (target_version_minor > current_version_minor)
1760                 *res = PMINFO_VERSION_NEW;
1761         else if (target_version_minor < current_version_minor)
1762                 *res = PMINFO_VERSION_OLD;
1763         else if (target_version_macro > current_version_macro)
1764                 *res = PMINFO_VERSION_NEW;
1765         else if (target_version_macro < current_version_macro)
1766                 *res = PMINFO_VERSION_OLD;
1767         else if (target_version_nano > current_version_nano)
1768                 *res = PMINFO_VERSION_NEW;
1769         else if (target_version_nano < current_version_nano)
1770                 *res = PMINFO_VERSION_OLD;
1771         else
1772                 *res = PMINFO_VERSION_SAME;
1773
1774         return PMINFO_R_OK;
1775 }
1776
1777 API int pkgmgrinfo_pkginfo_foreach_metadata(pkgmgrinfo_pkginfo_h handle,
1778                 pkgmgrinfo_pkg_metadata_list_cb metadata_func, void *user_data)
1779 {
1780         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1781         retvm_if(metadata_func == NULL, PMINFO_R_EINVAL,
1782                         "Callback function is NULL");
1783         int ret = -1;
1784         metadata_x *ptr;
1785         GList *tmp;
1786         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1787
1788         if (info->pkg_info == NULL)
1789                 return PMINFO_R_ERROR;
1790
1791         for (tmp = info->pkg_info->metadata; tmp; tmp = tmp->next) {
1792                 ptr = (metadata_x *)tmp->data;
1793                 if (ptr == NULL)
1794                         continue;
1795                 if (ptr->key) {
1796                         ret = metadata_func(ptr->key, ptr->value ?
1797                                         ptr->value : "", user_data);
1798                         if (ret < 0)
1799                                 break;
1800                 }
1801         }
1802         return PMINFO_R_OK;
1803 }
1804
1805 API int pkgmgrinfo_pkginfo_metadata_filter_create(
1806                 pkgmgrinfo_pkginfo_metadata_filter_h *handle)
1807 {
1808         return pkgmgrinfo_pkginfo_filter_create(handle);
1809 }
1810
1811 API int pkgmgrinfo_pkginfo_metadata_filter_destroy(
1812                 pkgmgrinfo_pkginfo_metadata_filter_h handle)
1813 {
1814         return pkgmgrinfo_pkginfo_filter_destroy(handle);
1815 }
1816
1817 API int pkgmgrinfo_pkginfo_metadata_filter_add(
1818                 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1819                 const char *key, const char *value)
1820 {
1821         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1822         pkgmgrinfo_metadata_node_x *node;
1823
1824         /* value can be NULL.
1825          * In that case all pkgs with specified key should be displayed
1826          */
1827         if (handle == NULL || key == NULL) {
1828                 LOGE("invalid parameter");
1829                 return PMINFO_R_EINVAL;
1830         }
1831
1832         node = calloc(1, sizeof(pkgmgrinfo_metadata_node_x));
1833         if (node == NULL) {
1834                 LOGE("out of memory");
1835                 return PMINFO_R_ERROR;
1836         }
1837
1838         node->key = strdup(key);
1839         if (value && strlen(value))
1840                 node->value = strdup(value);
1841
1842         filter->list_pkg_metadata = g_slist_append(filter->list_pkg_metadata,
1843                         (gpointer)node);
1844
1845         return PMINFO_R_OK;
1846 }
1847
1848 API int pkgmgrinfo_pkginfo_usr_metadata_filter_foreach(
1849                 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1850                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1851 {
1852         if (handle == NULL || pkg_cb == NULL) {
1853                 LOGE("invalid parameter");
1854                 return PMINFO_R_EINVAL;
1855         }
1856
1857         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1858
1859         if (pkgmgrinfo_pkginfo_filter_add_bool(filter,
1860                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false))
1861                 return PMINFO_R_ERROR;
1862
1863         return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1864                         PMINFO_PKGINFO_GET_ALL, pkg_cb,
1865                         user_data);
1866 }
1867
1868 API int pkgmgrinfo_pkginfo_metadata_filter_foreach(
1869                 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1870                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1871 {
1872         return pkgmgrinfo_pkginfo_usr_metadata_filter_foreach(handle, pkg_cb,
1873                         user_data, _getuid());
1874 }
1875
1876 API int pkgmgrinfo_pkginfo_get_metadata_value(
1877                 pkgmgrinfo_pkginfo_h handle, const char *metadata_key,
1878                 char **metadata_value)
1879 {
1880         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1881         retvm_if(metadata_key == NULL, PMINFO_R_EINVAL, "metadata_key is NULL");
1882         retvm_if(metadata_value == NULL, PMINFO_R_EINVAL,
1883                         "metadata_value is NULL");
1884
1885         GList *list_md = NULL;
1886         metadata_x *metadata = NULL;
1887         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1888
1889         list_md = info->pkg_info->metadata;
1890
1891         for (; list_md; list_md = list_md->next) {
1892                 metadata = (metadata_x *)list_md->data;
1893                 if (metadata && metadata->key) {
1894                         if (strcasecmp(metadata->key, metadata_key) == 0) {
1895                                 if (metadata->value == NULL)
1896                                         *metadata_value = "";
1897                                 else
1898                                         *metadata_value =
1899                                                         (char *)metadata->value;
1900                                 return PMINFO_R_OK;
1901                         }
1902                 }
1903         }
1904
1905         return PMINFO_R_EINVAL;
1906 }