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