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