Fix static analysis issue
[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
43 static bool _get_bool_value(const char *str)
44 {
45         if (str && !strcmp(str, "true"))
46                 return true;
47         else
48                 return false;
49 }
50
51 static gint __compare_func(gconstpointer data1, gconstpointer data2)
52 {
53         pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x *)data1;
54         pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x *)data2;
55         if (node1->prop == node2->prop)
56                 return 0;
57         else if (node1->prop > node2->prop)
58                 return 1;
59         else
60                 return -1;
61 }
62
63 static gint __pkg_disable_chk_func(gconstpointer data1, gconstpointer data2)
64 {
65         pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data1;
66
67         if (node->prop == E_PMINFO_PKGINFO_PROP_PACKAGE_DISABLE)
68                 return 0;
69         else
70                 return 1;
71 }
72
73 static void __destroy_each_node(gpointer data, gpointer user_data)
74 {
75         ret_if(data == NULL);
76         pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data;
77         if (node->value) {
78                 free(node->value);
79                 node->value = NULL;
80         }
81         if (node->key) {
82                 free(node->key);
83                 node->key = NULL;
84         }
85         free(node);
86         node = NULL;
87 }
88
89 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
90 {
91         ret_if(data == NULL);
92         if (data->locale) {
93                 free((void *)data->locale);
94                 data->locale = NULL;
95         }
96
97         pkgmgrinfo_basic_free_package(data->pkg_info);
98         free((void *)data);
99         data = NULL;
100         return;
101 }
102
103 long long _pkgmgr_calculate_dir_size(char *dirname)
104 {
105         long long total = 0;
106         long long ret = 0;
107         int q = 0; /*quotient*/
108         int r = 0; /*remainder*/
109         DIR *dp = NULL;
110         struct dirent ep, *result;
111         struct stat fileinfo;
112         char abs_filename[FILENAME_MAX] = { 0, };
113         retvm_if(dirname == NULL, PMINFO_R_ERROR, "dirname is NULL");
114
115         dp = opendir(dirname);
116         if (dp == NULL) {
117                 _LOGE("Couldn't open the directory\n");
118                 return -1;
119         }
120
121         for (ret = readdir_r(dp, &ep, &result);
122                         ret == 0 && result != NULL;
123                         ret = readdir_r(dp, &ep, &result)) {
124                 if (!strcmp(ep.d_name, ".") ||
125                         !strcmp(ep.d_name, "..")) {
126                         continue;
127                 }
128                 snprintf(abs_filename, FILENAME_MAX, "%s/%s", dirname,
129                          ep.d_name);
130                 if (lstat(abs_filename, &fileinfo) < 0)
131                         perror(abs_filename);
132                 else {
133                         if (S_ISDIR(fileinfo.st_mode)) {
134                                 total += fileinfo.st_size;
135                                 if (strcmp(ep.d_name, ".")
136                                     && strcmp(ep.d_name, "..")) {
137                                         ret = _pkgmgr_calculate_dir_size
138                                             (abs_filename);
139                                         total = total + ret;
140                                 }
141                         } else if (S_ISLNK(fileinfo.st_mode)) {
142                                 continue;
143                         } else {
144                                 /*It is a file. Calculate the actual
145                                 size occupied (in terms of 4096 blocks)*/
146                         q = (fileinfo.st_size / BLOCK_SIZE);
147                         r = (fileinfo.st_size % BLOCK_SIZE);
148                         if (r)
149                                 q = q + 1;
150                         total += q * BLOCK_SIZE;
151                         }
152                 }
153         }
154         (void)closedir(dp);
155         return total;
156
157 }
158
159 static int _pkginfo_add_description_info_into_list(const char *locale,
160                 char *record, GList **description)
161 {
162         description_x *info;
163
164         info = calloc(1, sizeof(description_x));
165         if (info == NULL) {
166                 LOGE("out of memory");
167                 return PMINFO_R_ERROR;
168         }
169         info->lang = strdup(locale);
170         info->text = record;
171         *description = g_list_append(*description, info);
172
173         return PMINFO_R_OK;
174 }
175
176 static int _pkginfo_get_privilege(sqlite3 *db, const char *pkgid,
177                 GList **privileges)
178 {
179         static const char query_raw[] =
180                 "SELECT DISTINCT privilege, type FROM package_privilege_info "
181                 "WHERE package=%Q";
182         int ret;
183         char *query;
184         sqlite3_stmt *stmt;
185         privilege_x *privilege;
186
187         query = sqlite3_mprintf(query_raw, pkgid);
188         if (query == NULL) {
189                 LOGE("out of memory");
190                 return PMINFO_R_ERROR;
191         }
192
193         ret = sqlite3_prepare_v2(db, query, strlen(query),
194                         &stmt, NULL);
195         sqlite3_free(query);
196         if (ret != SQLITE_OK) {
197                 LOGE("prepare failed: %s", sqlite3_errmsg(db));
198                 return PMINFO_R_ERROR;
199         }
200
201         while (sqlite3_step(stmt) == SQLITE_ROW) {
202                 privilege = calloc(1, sizeof(privilege_x));
203                 _save_column_str(stmt, 0, &privilege->value);
204                 _save_column_str(stmt, 1, &privilege->type);
205                 *privileges = g_list_append(*privileges,
206                                 (gpointer)privilege);
207         }
208
209         sqlite3_finalize(stmt);
210
211         return PMINFO_R_OK;
212 }
213
214 static const char join_localized_info[] =
215         " LEFT OUTER JOIN package_localized_info"
216         "  ON pi.package=package_localized_info.package"
217         "  AND package_localized_info.package_locale=?";
218 static const char join_privilege_info[] =
219         " LEFT OUTER JOIN package_privilege_info"
220         "  ON pi.package=package_privilege_info.package";
221
222 static int _get_filtered_query(pkgmgrinfo_filter_x *filter,
223                 const char *locale, uid_t uid, char **query, GList **bind_params)
224 {
225         int joined = 0;
226         char buf[MAX_QUERY_LEN] = { '\0' };
227         char buf2[MAX_QUERY_LEN] = { '\0' };
228         char *condition = NULL;
229         size_t len = 0;
230         GSList *list = NULL;
231
232         if (filter == NULL)
233                 return PMINFO_R_OK;
234
235         len += strlen(" WHERE 1=1 ");
236         strncat(buf, " WHERE 1=1 ", MAX_QUERY_LEN - len - 1);
237         for (list = filter->list; list; list = list->next) {
238                 joined |= __get_filter_condition(list->data, uid, &condition,
239                                 bind_params);
240                 if (condition == NULL)
241                         continue;
242
243                 len += strlen(" AND ");
244                 strncat(buf, " AND ", MAX_QUERY_LEN - len - 1);
245
246                 len += strlen(condition);
247                 strncat(buf, condition, sizeof(buf) - len - 1);
248                 free(condition);
249                 condition = NULL;
250         }
251
252         if (joined & E_PMINFO_PKGINFO_JOIN_LOCALIZED_INFO) {
253                 strncat(buf2, join_localized_info, MAX_QUERY_LEN - len - 1);
254                 len += strlen(join_localized_info);
255                 *bind_params = g_list_append(*bind_params, strdup(locale));
256         }
257         if (joined & E_PMINFO_PKGINFO_JOIN_PRIVILEGE_INFO) {
258                 strncat(buf2, join_privilege_info, MAX_QUERY_LEN - len - 1);
259                 len += strlen(join_privilege_info);
260         }
261         strncat(buf2, buf, MAX_QUERY_LEN - len - 1);
262
263         *query = strdup(buf2);
264         if (*query == NULL)
265                 return PMINFO_R_ERROR;
266
267         return PMINFO_R_OK;
268 }
269
270 static void __free_packages(gpointer data)
271 {
272         pkgmgrinfo_basic_free_package((package_x *)data);
273 }
274
275 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
276 {
277         GSList *link;
278
279         if (filter == NULL)
280                 return false;
281
282         link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
283         if (link)
284                 return true;
285
286         return false;
287 }
288
289 static int __bind_params(sqlite3_stmt *stmt, GList *params)
290 {
291         GList *tmp_list = NULL;
292         int idx = 0;
293         int ret;
294
295         if (stmt == NULL || params == NULL)
296                 return PMINFO_R_EINVAL;
297
298         tmp_list = params;
299         while (tmp_list) {
300                 ret = sqlite3_bind_text(stmt, ++idx, (char *)tmp_list->data, -1, SQLITE_STATIC);
301                 if (ret != SQLITE_OK)
302                         return PMINFO_R_ERROR;
303                 tmp_list = tmp_list->next;
304         }
305
306         return PMINFO_R_OK;
307 }
308
309 static bool __check_package_storage_status(pkgmgrinfo_filter_x *tmp_filter)
310 {
311         GSList *tmp_list = NULL;
312         pkgmgrinfo_node_x *tmp_node = NULL;
313         int property = -1;
314
315         property = _pminfo_pkginfo_convert_to_prop_bool(PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE);
316         for (tmp_list = tmp_filter->list; tmp_list != NULL;
317                         tmp_list = g_slist_next(tmp_list)) {
318                 tmp_node = (pkgmgrinfo_node_x *)tmp_list->data;
319                 if (property == tmp_node->prop) {
320                         if (strcmp(tmp_node->value, "true") == 0)
321                                 return true;
322                         else
323                                 return false;
324                 }
325         }
326         return true;
327 }
328
329 static int _pkginfo_get_packages(uid_t uid, const char *locale,
330                 pkgmgrinfo_filter_x *filter, int flag, GHashTable *packages)
331 {
332         static const char query_raw[] =
333                 "SELECT DISTINCT pi.package, pi.package_version, "
334                 "pi.install_location, pi.package_removable, "
335                 "pi.package_preload, pi.package_readonly, pi.package_update, "
336                 "pi.package_appsetting, pi.package_system, pi.package_type, "
337                 "pi.package_size, pi.installed_time, pi.installed_storage, "
338                 "pi.storeclient_id, pi.mainapp_id, pi.package_url, "
339                 "pi.root_path, pi.csc_path, pi.package_nodisplay, "
340                 "pi.package_api_version, pi.package_support_disable, "
341                 "pi.package_tep_name, pi.package_zip_mount_file, pi.external_path, "
342                 "pi.package_support_mode";
343         static const char query_author[] =
344                 ", pi.author_name, pi.author_email, pi.author_href";
345         static const char query_label[] =
346                 ", COALESCE("
347                 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
348                 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
349         static const char query_icon[] =
350                 ", COALESCE("
351                 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
352                 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
353         static const char query_description[] =
354                 ", COALESCE("
355                 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
356                 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
357         static const char query_from_clause[] = " FROM package_info as pi";
358         int ret = PMINFO_R_ERROR;
359         int idx = 0;
360         int query_len = 0;
361         char *dbpath;
362         char *tmp_record = NULL;
363         char *constraints = NULL;
364         char query[MAX_QUERY_LEN] = { '\0' };
365         package_x *info = NULL;
366         author_x *author = NULL;
367         GList *bind_params = NULL;
368         sqlite3 *db;
369         sqlite3_stmt *stmt;
370         pkgmgrinfo_filter_x *tmp_filter = NULL;
371         bool is_check_storage = true;
372
373         dbpath = getUserPkgParserDBPathUID(uid);
374         if (dbpath == NULL)
375                 return PMINFO_R_ERROR;
376
377         ret = __open_db(dbpath, &db, SQLITE_OPEN_READONLY);
378         if (ret != SQLITE_OK) {
379                 _LOGD("failed to open db: %d", ret);
380                 free(dbpath);
381                 return PMINFO_R_ERROR;
382         }
383         free(dbpath);
384
385         if (filter != NULL) {
386                 tmp_filter = filter;
387         } else {
388                 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
389                 if (ret != PMINFO_R_OK) {
390                         _LOGE("Failed to create filter");
391                         return PMINFO_R_ERROR;
392                 }
393         }
394
395         is_check_storage = __check_package_storage_status(tmp_filter);
396
397         query_len = strlen(query_raw);
398         snprintf(query, MAX_QUERY_LEN - 1, "%s", query_raw);
399         if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
400                 strncat(query, query_author, MAX_QUERY_LEN - query_len - 1);
401                 query_len += strlen(query_author);
402         }
403         if (flag & PMINFO_PKGINFO_GET_LABEL) {
404                 strncat(query, query_label, MAX_QUERY_LEN - query_len - 1);
405                 query_len += strlen(query_label);
406                 bind_params = g_list_append(bind_params, strdup(locale));
407         }
408         if (flag & PMINFO_PKGINFO_GET_ICON) {
409                 strncat(query, query_icon, MAX_QUERY_LEN - query_len - 1);
410                 query_len += strlen(query_icon);
411                 bind_params = g_list_append(bind_params, strdup(locale));
412         }
413         if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
414                 strncat(query, query_description, MAX_QUERY_LEN - query_len - 1);
415                 query_len += strlen(query_description);
416                 bind_params = g_list_append(bind_params, strdup(locale));
417         }
418
419         strncat(query, query_from_clause, MAX_QUERY_LEN - query_len - 1);
420         query_len += strlen(query_from_clause);
421
422         ret = _get_filtered_query(tmp_filter, locale, uid, &constraints, &bind_params);
423         if (ret != PMINFO_R_OK) {
424                 LOGE("Failed to get WHERE clause");
425                 goto catch;
426         }
427
428         if (constraints)
429                 strncat(query, constraints, MAX_QUERY_LEN - query_len - 1);
430
431         ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
432         if (ret != SQLITE_OK) {
433                 LOGE("prepare failed: %s", sqlite3_errmsg(db));
434                 ret = PMINFO_R_ERROR;
435                 goto catch;
436         }
437
438         ret = __bind_params(stmt, bind_params);
439         if (ret != SQLITE_OK) {
440                 LOGE("Failed to bind parameters");
441                 goto catch;
442         }
443
444         while (sqlite3_step(stmt) == SQLITE_ROW) {
445                 info = calloc(1, sizeof(package_x));
446                 if (info == NULL) {
447                         LOGE("out of memory");
448                         ret = PMINFO_R_ERROR;
449                         goto catch;
450                 }
451                 idx = 0;
452                 _save_column_str(stmt, idx++, &info->package);
453                 if (g_hash_table_contains(packages,
454                                         (gconstpointer)info->package)) {
455                         free(info->package);
456                         free(info);
457                         continue;
458                 }
459                 _save_column_str(stmt, idx++, &info->version);
460                 _save_column_str(stmt, idx++, &info->installlocation);
461                 _save_column_str(stmt, idx++, &info->removable);
462                 _save_column_str(stmt, idx++, &info->preload);
463                 _save_column_str(stmt, idx++, &info->readonly);
464                 _save_column_str(stmt, idx++, &info->update);
465                 _save_column_str(stmt, idx++, &info->appsetting);
466                 _save_column_str(stmt, idx++, &info->system);
467                 _save_column_str(stmt, idx++, &info->type);
468                 _save_column_str(stmt, idx++, &info->package_size);
469                 _save_column_str(stmt, idx++, &info->installed_time);
470                 _save_column_str(stmt, idx++, &info->installed_storage);
471                 _save_column_str(stmt, idx++, &info->storeclient_id);
472                 _save_column_str(stmt, idx++, &info->mainapp_id);
473                 _save_column_str(stmt, idx++, &info->package_url);
474                 _save_column_str(stmt, idx++, &info->root_path);
475                 _save_column_str(stmt, idx++, &info->csc_path);
476                 _save_column_str(stmt, idx++, &info->nodisplay_setting);
477                 _save_column_str(stmt, idx++, &info->api_version);
478                 _save_column_str(stmt, idx++, &info->support_disable);
479                 _save_column_str(stmt, idx++, &info->tep_name);
480                 _save_column_str(stmt, idx++, &info->zip_mount_file);
481                 _save_column_str(stmt, idx++, &info->external_path);
482                 _save_column_str(stmt, idx++, &info->support_mode);
483                 info->for_all_users =
484                         strdup((uid != GLOBAL_USER) ? "false" : "true");
485
486                 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
487                         /* TODO : author should be retrieved at package_localized_info */
488                         author = calloc(1, sizeof(author_x));
489                         if (author == NULL) {
490                                 ret = PMINFO_R_ERROR;
491                                 goto catch;
492                         }
493                         _save_column_str(stmt, idx++, &author->text);
494                         _save_column_str(stmt, idx++, &author->email);
495                         _save_column_str(stmt, idx++, &author->href);
496                         info->author = g_list_append(info->author, author);
497                 }
498
499                 if (flag & PMINFO_PKGINFO_GET_LABEL) {
500                         tmp_record = NULL;
501                         _save_column_str(stmt, idx++, &tmp_record);
502
503                         if (_add_label_info_into_list(locale, tmp_record, &info->label)) {
504                                 ret = PMINFO_R_ERROR;
505                                 goto catch;
506                         }
507                 }
508
509                 if (flag & PMINFO_PKGINFO_GET_ICON) {
510                         tmp_record = NULL;
511                         _save_column_str(stmt, idx++, &tmp_record);
512                         if (_add_icon_info_into_list(locale, tmp_record, &info->icon)) {
513                                 ret = PMINFO_R_ERROR;
514                                 goto catch;
515                         }
516                 }
517
518                 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
519                         tmp_record = NULL;
520                         _save_column_str(stmt, idx++, &tmp_record);
521                         if (_pkginfo_add_description_info_into_list(locale, tmp_record,
522                                         &info->description)) {
523                                 ret = PMINFO_R_ERROR;
524                                 goto catch;
525                         }
526                 }
527
528                 if (flag & PMINFO_PKGINFO_GET_PRIVILEGE) {
529                         if (_pkginfo_get_privilege(db, info->package,
530                                                 &info->privileges)) {
531                                 ret = PMINFO_R_ERROR;
532                                 goto catch;
533                         }
534                 }
535
536                 if (is_check_storage &&
537                                 __pkginfo_check_installed_storage(info) != PMINFO_R_OK) {
538                         ret = PMINFO_R_ERROR;
539                         pkgmgrinfo_basic_free_package(info);
540                         info = NULL;
541                         continue;
542                 }
543
544                 g_hash_table_insert(packages, (gpointer)info->package,
545                                 (gpointer)info);
546         }
547
548         ret = PMINFO_R_OK;
549
550 catch:
551         if (constraints)
552                 free(constraints);
553
554         if (ret != PMINFO_R_OK && info != NULL)
555                 pkgmgrinfo_basic_free_package(info);
556
557         if (filter == NULL)
558                 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
559
560         g_list_free_full(bind_params, free);
561         sqlite3_close_v2(db);
562         sqlite3_finalize(stmt);
563
564         return ret;
565 }
566
567 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
568                 pkgmgrinfo_filter_x *filter, int flag,
569                 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
570 {
571         int ret;
572         char *locale;
573         package_x *pkg;
574         pkgmgr_pkginfo_x info;
575         pkgmgrinfo_filter_x *tmp_filter = NULL;
576         GHashTable *list;
577         GHashTableIter iter;
578         gpointer value;
579
580         locale = _get_system_locale();
581         if (locale == NULL)
582                 return PMINFO_R_ERROR;
583
584         list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
585                         __free_packages);
586         if (list == NULL) {
587                 free(locale);
588                 return PMINFO_R_ERROR;
589         }
590
591         if (filter != NULL) {
592                 tmp_filter = (pkgmgrinfo_filter_x *)filter;
593         } else {
594                 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
595                 if (ret != PMINFO_R_OK) {
596                         _LOGE("Failed to create filter");
597                         g_hash_table_destroy(list);
598                         return PMINFO_R_ERROR;
599                 }
600         }
601
602         if (__check_disable_filter_exist(tmp_filter) == false)
603                 pkgmgrinfo_pkginfo_filter_add_bool(tmp_filter,
604                                 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
605
606         ret = _pkginfo_get_packages(uid, locale, tmp_filter, flag, list);
607         if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
608                 ret = _pkginfo_get_packages(GLOBAL_USER, locale, tmp_filter,
609                                 flag, list);
610
611         if (ret != PMINFO_R_OK) {
612                 g_hash_table_destroy(list);
613                 free(locale);
614                 if (filter == NULL)
615                         pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
616                 return PMINFO_R_ERROR;
617         }
618
619         g_hash_table_iter_init(&iter, list);
620         while (g_hash_table_iter_next(&iter, NULL, &value)) {
621                 pkg = (package_x *)value;
622                 info.uid = uid;
623                 info.pkg_info = pkg;
624                 info.locale = locale;
625                 if (pkg_list_cb(&info, user_data) < 0)
626                         break;
627         }
628
629         g_hash_table_destroy(list);
630         free(locale);
631
632         if (filter == NULL)
633                 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
634
635         return PMINFO_R_OK;
636 }
637
638 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
639         pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
640 {
641         int ret;
642         char *locale;
643         GHashTable *list;
644         pkgmgr_pkginfo_x *info;
645
646         if (pkgid == NULL || filter == NULL || handle == NULL) {
647                         LOGE("invalid parameter");
648                         return PMINFO_R_EINVAL;
649         }
650
651         locale = _get_system_locale();
652         if (locale == NULL)
653                 return PMINFO_R_ERROR;
654
655         list = g_hash_table_new(g_str_hash, g_str_equal);
656         if (list == NULL) {
657                 free(locale);
658                 return PMINFO_R_ERROR;
659         }
660
661         ret = _pkginfo_get_packages(uid, locale, filter,
662                         PMINFO_PKGINFO_GET_ALL, list);
663         if (!g_hash_table_size(list) && uid != GLOBAL_USER)
664                 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
665                                 PMINFO_PKGINFO_GET_ALL, list);
666
667         if (!g_hash_table_size(list)) {
668                 _LOGI("pkginfo for [%s] is not existed for user [%d]",
669                                 pkgid, uid);
670                 g_hash_table_destroy(list);
671                 free(locale);
672                 return PMINFO_R_ENOENT;
673         }
674
675         info = calloc(1, sizeof(pkgmgr_pkginfo_x));
676         if (info == NULL) {
677                 _LOGE("out of memory");
678                 g_hash_table_destroy(list);
679                 free(locale);
680                 return PMINFO_R_ERROR;
681         }
682
683         info->uid = uid;
684         info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
685         info->locale = locale;
686
687         /* just free list only */
688         g_hash_table_destroy(list);
689
690         *handle = info;
691
692         return ret;
693 }
694
695 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
696                 pkgmgrinfo_pkginfo_h *handle)
697 {
698         int ret;
699         pkgmgrinfo_pkginfo_filter_h filter;
700
701         if (pkgid == NULL || handle == NULL) {
702                 LOGE("invalid parameter");
703                 return PMINFO_R_EINVAL;
704         }
705
706         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
707         if (ret != PMINFO_R_OK)
708                 return ret;
709
710         ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
711                         PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
712         if (ret != PMINFO_R_OK) {
713                 pkgmgrinfo_pkginfo_filter_destroy(filter);
714                 return PMINFO_R_ERROR;
715         }
716
717         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
718                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
719         if (ret != PMINFO_R_OK) {
720                 pkgmgrinfo_pkginfo_filter_destroy(filter);
721                 return PMINFO_R_ERROR;
722         }
723
724         ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
725         pkgmgrinfo_pkginfo_filter_destroy(filter);
726
727         return ret;
728 }
729
730 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
731                 pkgmgrinfo_pkginfo_h *handle)
732 {
733         return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
734 }
735
736 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
737                 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
738 {
739         int ret;
740         char *locale;
741         GHashTable *list;
742         pkgmgrinfo_pkginfo_filter_h filter;
743         pkgmgr_pkginfo_x *info;
744
745         if (pkgid == NULL || handle == NULL) {
746                 LOGE("invalid parameter");
747                 return PMINFO_R_EINVAL;
748         }
749
750         locale = _get_system_locale();
751         if (locale == NULL)
752                 return PMINFO_R_ERROR;
753
754         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
755         if (ret != PMINFO_R_OK) {
756                 free(locale);
757                 return ret;
758         }
759
760         ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
761                         PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
762         if (ret != PMINFO_R_OK) {
763                 pkgmgrinfo_pkginfo_filter_destroy(filter);
764                 free(locale);
765                 return PMINFO_R_ERROR;
766         }
767
768         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
769                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
770         if (ret != PMINFO_R_OK) {
771                 pkgmgrinfo_pkginfo_filter_destroy(filter);
772                 free(locale);
773                 return PMINFO_R_ERROR;
774         }
775
776         list = g_hash_table_new(g_str_hash, g_str_equal);
777         if (list == NULL) {
778                 pkgmgrinfo_pkginfo_filter_destroy(filter);
779                 free(locale);
780                 return PMINFO_R_ERROR;
781         }
782
783         ret = _pkginfo_get_packages(uid, locale, filter,
784                         PMINFO_PKGINFO_GET_ALL, list);
785         if (!g_hash_table_size(list) && uid != GLOBAL_USER)
786                 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
787                                 PMINFO_PKGINFO_GET_ALL, list);
788
789         pkgmgrinfo_pkginfo_filter_destroy(filter);
790         if (ret != PMINFO_R_OK) {
791                 g_hash_table_destroy(list);
792                 free(locale);
793                 return ret;
794         }
795
796         if (!g_hash_table_size(list)) {
797                 _LOGI("disabled pkginfo for [%s] is not existed for user [%d]",
798                                 pkgid, uid);
799                 g_hash_table_destroy(list);
800                 free(locale);
801                 return PMINFO_R_ENOENT;
802         }
803
804         info = calloc(1, sizeof(pkgmgr_pkginfo_x));
805         if (info == NULL) {
806                 _LOGE("out of memory");
807                 g_hash_table_destroy(list);
808                 free(locale);
809                 return PMINFO_R_ERROR;
810         }
811
812         info->uid = uid;
813         info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
814         info->locale = locale;
815
816         /* just free list only */
817         g_hash_table_destroy(list);
818
819         *handle = info;
820
821         return ret;
822 }
823
824 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
825                 pkgmgrinfo_pkginfo_h *handle)
826 {
827
828         int ret;
829         pkgmgrinfo_pkginfo_filter_h filter;
830
831         if (pkgid == NULL || handle == NULL) {
832                 LOGE("invalid parameter");
833                 return PMINFO_R_EINVAL;
834         }
835
836         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
837         if (ret != PMINFO_R_OK)
838                 return ret;
839
840         ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
841                         PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
842         if (ret != PMINFO_R_OK) {
843                 pkgmgrinfo_pkginfo_filter_destroy(filter);
844                 return PMINFO_R_ERROR;
845         }
846
847         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
848                         PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
849         if (ret != PMINFO_R_OK) {
850                 pkgmgrinfo_pkginfo_filter_destroy(filter);
851                 return PMINFO_R_ERROR;
852         }
853
854         ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
855         pkgmgrinfo_pkginfo_filter_destroy(filter);
856
857         return ret;
858 }
859
860 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
861                 pkgmgrinfo_pkginfo_h *handle)
862 {
863         return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
864                         handle);
865 }
866
867 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
868                 pkgmgrinfo_pkginfo_h *handle)
869 {
870         return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
871 }
872
873 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
874                 int flag, void *user_data, uid_t uid)
875 {
876         int ret;
877         pkgmgrinfo_pkginfo_filter_h filter;
878
879         if (pkg_list_cb == NULL) {
880                 LOGE("invalid parameter");
881                 return PMINFO_R_EINVAL;
882         }
883
884         /* create an empty filter */
885         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
886         if (ret != PMINFO_R_OK)
887                 return ret;
888
889         ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
890                         pkg_list_cb, user_data);
891
892         pkgmgrinfo_pkginfo_filter_destroy(filter);
893
894         return ret;
895 }
896
897 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
898                 int flag, void *user_data)
899 {
900         return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
901                         user_data, _getuid());
902 }
903
904 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
905                 void *user_data, uid_t uid)
906 {
907         int ret;
908         pkgmgrinfo_pkginfo_filter_h filter;
909
910         if (pkg_list_cb == NULL) {
911                 LOGE("invalid parameter");
912                 return PMINFO_R_EINVAL;
913         }
914
915         /* create an empty filter */
916         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
917         if (ret != PMINFO_R_OK)
918                 return ret;
919
920         ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
921                         PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
922
923         pkgmgrinfo_pkginfo_filter_destroy(filter);
924
925         return ret;
926 }
927
928 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
929                 void *user_data)
930 {
931         return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
932                         _getuid());
933 }
934
935 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
936                 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
937 {
938         int ret;
939         pkgmgrinfo_pkginfo_filter_h filter;
940
941         if (pkg_list_cb == NULL) {
942                 LOGE("invalid parameter");
943                 return PMINFO_R_EINVAL;
944         }
945
946         ret = pkgmgrinfo_pkginfo_filter_create(&filter);
947         if (ret != PMINFO_R_OK)
948                 return ret;
949
950         ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
951                         PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
952         if (ret != PMINFO_R_OK) {
953                 pkgmgrinfo_pkginfo_filter_destroy(filter);
954                 return PMINFO_R_ERROR;
955         }
956
957         ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
958                         PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
959
960         pkgmgrinfo_pkginfo_filter_destroy(filter);
961
962         return ret;
963 }
964
965 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
966                 void *user_data)
967 {
968         return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
969                         _getuid());
970 }
971
972 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
973 {
974         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
975
976         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
977         retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
978
979         if (info->pkg_info == NULL || info->pkg_info->package == NULL)
980                 return PMINFO_R_ERROR;
981
982         *pkg_name = (char *)info->pkg_info->package;
983
984         return PMINFO_R_OK;
985 }
986
987 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
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(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
993
994         if (info->pkg_info == NULL || info->pkg_info->package == NULL)
995                 return PMINFO_R_ERROR;
996
997         *pkgid = (char *)info->pkg_info->package;
998
999         return PMINFO_R_OK;
1000 }
1001
1002 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
1003 {
1004         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1005
1006         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1007         retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1008
1009         if (info->pkg_info == NULL)
1010                 return PMINFO_R_ERROR;
1011
1012         if (info->pkg_info->type == NULL)
1013                 *type = "";
1014         else
1015                 *type = (char *)info->pkg_info->type;
1016
1017         return PMINFO_R_OK;
1018 }
1019
1020 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
1021 {
1022         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1023
1024         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1025         retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1026
1027         if (info->pkg_info == NULL)
1028                 return PMINFO_R_ERROR;
1029
1030         if (info->pkg_info->version == NULL)
1031                 *version = "";
1032         else
1033                 *version = (char *)info->pkg_info->version;
1034
1035         return PMINFO_R_OK;
1036 }
1037
1038 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
1039 {
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(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1044
1045         if (info->pkg_info == NULL)
1046                 return PMINFO_R_ERROR;
1047
1048         if (info->pkg_info->api_version == NULL)
1049                 *api_version = "";
1050         else
1051                 *api_version = (char *)info->pkg_info->api_version;
1052
1053         return PMINFO_R_OK;
1054 }
1055
1056 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
1057 {
1058         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1059
1060         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1061         retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1062
1063         if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
1064                 return PMINFO_R_ERROR;
1065
1066         *tep_name = (char *)info->pkg_info->tep_name;
1067
1068         return PMINFO_R_OK;
1069 }
1070
1071 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
1072 {
1073         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1074
1075         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1076         retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1077
1078         if (info->pkg_info == NULL)
1079                 return PMINFO_R_ERROR;
1080
1081         if (info->pkg_info->zip_mount_file == NULL)
1082                 *zip_mount_file = "";
1083         else
1084                 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
1085
1086         return PMINFO_R_OK;
1087 }
1088
1089 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
1090 {
1091         char *val;
1092         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1093
1094         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1095         retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1096
1097         if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1098                 return PMINFO_R_ERROR;
1099
1100         val = (char *)info->pkg_info->installlocation;
1101         if (strcmp(val, "internal-only") == 0)
1102                 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
1103         else if (strcmp(val, "prefer-external") == 0)
1104                 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
1105         else
1106                 *location = PMINFO_INSTALL_LOCATION_AUTO;
1107
1108         return PMINFO_R_OK;
1109 }
1110
1111 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
1112 {
1113         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1114         char *temp = NULL;
1115
1116         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1117         retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1118
1119         if (info->pkg_info == NULL)
1120                 return PMINFO_R_ERROR;
1121
1122         if (info->pkg_info->package_size == NULL) {
1123                 temp = strdup("");
1124                 if (temp == NULL) {
1125                         _LOGE("out of memory");
1126                         return PMINFO_R_ERROR;
1127                 } else {
1128                         info->pkg_info->package_size = temp;
1129                 }
1130         }
1131
1132         *size = atoi((char *)info->pkg_info->package_size);
1133
1134         return PMINFO_R_OK;
1135 }
1136
1137 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
1138 {
1139         icon_x *ptr;
1140         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1141
1142         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1143         retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1144
1145         if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
1146                 return PMINFO_R_ERROR;
1147
1148         ptr = (icon_x *)info->pkg_info->icon->data;
1149         if (ptr == NULL)
1150                 return PMINFO_R_ERROR;
1151
1152         /* TODO : should we return empty string if there was no icon? */
1153         if (ptr->text == NULL)
1154                 *icon = "";
1155         else
1156                 *icon = ptr->text;
1157
1158         return PMINFO_R_OK;
1159 }
1160
1161 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
1162 {
1163         label_x *ptr;
1164         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1165
1166         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1167         retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1168
1169         if (info->pkg_info == NULL || info->pkg_info->label == NULL)
1170                 return PMINFO_R_ERROR;
1171
1172         ptr = (label_x *)info->pkg_info->label->data;
1173         if (ptr == NULL)
1174                 return PMINFO_R_ERROR;
1175
1176         /* TODO : should we return empty string if there was no label? */
1177         if (ptr->text == NULL)
1178                 *label = "";
1179         else
1180                 *label = ptr->text;
1181
1182         return PMINFO_R_OK;
1183 }
1184
1185 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
1186 {
1187         description_x *ptr;
1188         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1189
1190         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1191         retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1192
1193         if (info->pkg_info == NULL || info->pkg_info->description == NULL)
1194                 return PMINFO_R_ERROR;
1195
1196         ptr = (description_x *)info->pkg_info->description->data;
1197         if (ptr == NULL)
1198                 return PMINFO_R_ERROR;
1199
1200         if (ptr->text == NULL)
1201                 *description = "";
1202         else
1203                 *description = (char *)ptr->text;
1204
1205         return PMINFO_R_OK;
1206 }
1207
1208 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
1209 {
1210         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1211         author_x *author;
1212
1213         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1214         retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1215
1216         if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1217                 return PMINFO_R_ERROR;
1218
1219         author = (author_x *)info->pkg_info->author->data;
1220         if (author == NULL)
1221                 return PMINFO_R_ERROR;
1222
1223         if (author->text == NULL)
1224                 *author_name = "";
1225         else
1226                 *author_name = (char *)author->text;
1227
1228         return PMINFO_R_OK;
1229 }
1230
1231 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
1232 {
1233         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1234         author_x *author;
1235
1236         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1237         retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1238
1239         if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1240                 return PMINFO_R_ERROR;
1241
1242         author = (author_x *)info->pkg_info->author->data;
1243         if (author == NULL)
1244                 return PMINFO_R_ERROR;
1245
1246         if (author->email == NULL)
1247                 *author_email = "";
1248         else
1249                 *author_email = (char *)author->email;
1250
1251         return PMINFO_R_OK;
1252 }
1253
1254 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
1255 {
1256         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1257         author_x *author;
1258
1259         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1260         retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1261
1262         if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1263                 return PMINFO_R_ERROR;
1264
1265         author = (author_x *)info->pkg_info->author->data;
1266         if (author == NULL)
1267                 return PMINFO_R_ERROR;
1268
1269         if (author->href == NULL)
1270                 *author_href = "";
1271         else
1272                 *author_href = (char *)author->href;
1273
1274         return PMINFO_R_OK;
1275 }
1276
1277 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
1278 {
1279         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1280
1281         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1282         retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1283
1284         if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
1285                 return PMINFO_R_ERROR;
1286
1287         if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
1288                 *storage = PMINFO_INTERNAL_STORAGE;
1289         else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
1290                 *storage = PMINFO_EXTERNAL_STORAGE;
1291         else
1292                 return PMINFO_R_ERROR;
1293
1294         return PMINFO_R_OK;
1295 }
1296
1297 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
1298 {
1299         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1300
1301         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1302         retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1303
1304         if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
1305                 return PMINFO_R_ERROR;
1306
1307         *installed_time = atoi(info->pkg_info->installed_time);
1308
1309         return PMINFO_R_OK;
1310 }
1311
1312 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
1313 {
1314         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1315
1316         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1317         retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1318
1319         if (info->pkg_info == NULL)
1320                 return PMINFO_R_ERROR;
1321
1322         if (info->pkg_info->storeclient_id == NULL)
1323                 *storeclientid = "";
1324         else
1325                 *storeclientid = (char *)info->pkg_info->storeclient_id;
1326
1327         return PMINFO_R_OK;
1328 }
1329
1330 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
1331 {
1332         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1333
1334         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1335         retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1336
1337         if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
1338                 return PMINFO_R_ERROR;
1339
1340         *mainappid = (char *)info->pkg_info->mainapp_id;
1341
1342         return PMINFO_R_OK;
1343 }
1344
1345 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
1346 {
1347         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1348
1349         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1350         retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1351
1352         if (info->pkg_info == NULL)
1353                 return PMINFO_R_ERROR;
1354
1355         if (info->pkg_info->package_url == NULL)
1356                 *url = "";
1357         else
1358                 *url = (char *)info->pkg_info->package_url;
1359
1360         return PMINFO_R_OK;
1361 }
1362
1363 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
1364 {
1365         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1366
1367         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1368         retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1369
1370         if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
1371                 return PMINFO_R_ERROR;
1372
1373         *path = (char *)info->pkg_info->root_path;
1374
1375         return PMINFO_R_OK;
1376 }
1377
1378 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
1379 {
1380         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1381
1382         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1383         retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1384
1385         if (info->pkg_info == NULL)
1386                 return PMINFO_R_ERROR;
1387
1388         if (info->pkg_info->csc_path == NULL)
1389                 *path = "";
1390         else
1391                 *path = (char *)info->pkg_info->csc_path;
1392
1393         return PMINFO_R_OK;
1394 }
1395
1396 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
1397 {
1398         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1399         retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1400
1401         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1402         if (info->pkg_info->support_mode)
1403                 *support_mode = atoi(info->pkg_info->support_mode);
1404         else
1405                 *support_mode = 0;
1406
1407         return PMINFO_R_OK;
1408 }
1409
1410 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
1411 {
1412         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1413         retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1414
1415 #if 0 /* smack issue occured, check later */
1416         char *pkgid = NULL;
1417         pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
1418         if (pkgid == NULL) {
1419                  _LOGD("invalid func parameters\n");
1420                  return PMINFO_R_ERROR;
1421         }
1422          _LOGD("pkgmgr_get_pkg_external_validation() called\n");
1423
1424         FILE *fp = NULL;
1425         char app_mmc_path[FILENAME_MAX] = { 0, };
1426         char app_dir_path[FILENAME_MAX] = { 0, };
1427         char app_mmc_internal_path[FILENAME_MAX] = { 0, };
1428         snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
1429         snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
1430         snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
1431
1432         /*check whether application is in external memory or not */
1433         fp = fopen(app_mmc_path, "r");
1434         if (fp == NULL) {
1435                 _LOGD(" app path in external memory not accesible\n");
1436         } else {
1437                 fclose(fp);
1438                 fp = NULL;
1439                 *accessible = 1;
1440                 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
1441                 return PMINFO_R_OK;
1442         }
1443
1444         /*check whether application is in internal or not */
1445         if (fp == NULL) {
1446                 _LOGD(" app path in internal memory not accesible\n");
1447                 *accessible = 0;
1448                 return PMINFO_R_ERROR;
1449         } else {
1450                 fclose(fp);
1451                 /*check whether the application is installed in SD card
1452                 but SD card is not present*/
1453                 fp = fopen(app_mmc_internal_path, "r");
1454                 if (fp == NULL) {
1455                         *accessible = 1;
1456                         _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1457                         return PMINFO_R_OK;
1458                 } else {
1459                         *accessible = 0;
1460                         _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1461                 }
1462                 fclose(fp);
1463         }
1464
1465         _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1466 #endif
1467
1468         *accessible = 1;
1469         return PMINFO_R_OK;
1470 }
1471
1472 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1473 {
1474         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1475
1476         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1477         retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1478
1479         if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1480                 return PMINFO_R_ERROR;
1481
1482         *removable = _get_bool_value(info->pkg_info->removable);
1483
1484         return PMINFO_R_OK;
1485 }
1486
1487 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1488 {
1489         char *val;
1490         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1491
1492         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1493         retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1494
1495         if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1496                 return PMINFO_R_ERROR;
1497
1498         val = (char *)info->pkg_info->installlocation;
1499         if (strcmp(val, "internal-only") == 0)
1500                 *movable = 0;
1501         else if (strcmp(val, "prefer-external") == 0)
1502                 *movable = 1;
1503         else
1504                 *movable = 1;
1505
1506         return PMINFO_R_OK;
1507 }
1508
1509 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1510 {
1511         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1512
1513         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1514         retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1515
1516         if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1517                 return PMINFO_R_ERROR;
1518
1519         *preload = _get_bool_value(info->pkg_info->preload);
1520
1521         return PMINFO_R_OK;
1522 }
1523
1524 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1525 {
1526         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1527
1528         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1529         retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1530
1531         if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1532                 return PMINFO_R_ERROR;
1533
1534         *system = _get_bool_value(info->pkg_info->system);
1535
1536         return PMINFO_R_OK;
1537 }
1538
1539 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1540 {
1541         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1542
1543         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1544         retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1545
1546         if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1547                 return PMINFO_R_ERROR;
1548
1549         *readonly = _get_bool_value(info->pkg_info->readonly);
1550
1551         return PMINFO_R_OK;
1552 }
1553
1554 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1555 {
1556         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1557
1558         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1559         retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1560
1561         if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1562                 return PMINFO_R_ERROR;
1563
1564         *update = _get_bool_value(info->pkg_info->update);
1565
1566         return PMINFO_R_OK;
1567 }
1568
1569 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1570 {
1571         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1572
1573         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1574         retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1575
1576         if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1577                 return PMINFO_R_ERROR;
1578
1579         *support_disable = _get_bool_value(info->pkg_info->support_disable);
1580
1581         return PMINFO_R_OK;
1582 }
1583
1584 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1585 {
1586         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1587
1588         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1589         retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1590
1591         if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1592                 return PMINFO_R_ERROR;
1593
1594         *global = _get_bool_value(info->pkg_info->for_all_users);
1595
1596         return PMINFO_R_OK;
1597 }
1598
1599 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1600 {
1601         return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1602 }
1603
1604 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1605 {
1606         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1607
1608         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1609
1610         __cleanup_pkginfo(info);
1611
1612         return PMINFO_R_OK;
1613 }
1614
1615 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1616 {
1617         pkgmgrinfo_filter_x *filter;
1618
1619         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1620
1621         filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1622         if (filter == NULL) {
1623                 _LOGE("Out of Memory!!!");
1624                 return PMINFO_R_ERROR;
1625         }
1626
1627         *handle = filter;
1628
1629         return PMINFO_R_OK;
1630 }
1631
1632 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1633 {
1634         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1635
1636         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1637
1638         if (filter->list) {
1639                 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1640                 g_slist_free(filter->list);
1641         }
1642
1643         free(filter);
1644
1645         return PMINFO_R_OK;
1646 }
1647
1648 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1649                                 const char *property, const int value)
1650 {
1651         char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1652         char *val;
1653         GSList *link;
1654         int prop;
1655         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1656         pkgmgrinfo_node_x *node;
1657
1658         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1659         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1660
1661         prop = _pminfo_pkginfo_convert_to_prop_int(property);
1662         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1663                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1664                 _LOGE("Invalid Integer Property\n");
1665                 return PMINFO_R_EINVAL;
1666         }
1667         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1668         if (node == NULL) {
1669                 _LOGE("Out of Memory!!!\n");
1670                 return PMINFO_R_ERROR;
1671         }
1672         snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1673         val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1674         if (val == NULL) {
1675                 _LOGE("Out of Memory\n");
1676                 free(node);
1677                 return PMINFO_R_ERROR;
1678         }
1679         node->prop = prop;
1680         node->value = val;
1681         /*If API is called multiple times for same property, we should override the previous values.
1682         Last value set will be used for filtering.*/
1683         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1684         if (link)
1685                 filter->list = g_slist_delete_link(filter->list, link);
1686         filter->list = g_slist_append(filter->list, (gpointer)node);
1687         return PMINFO_R_OK;
1688
1689 }
1690
1691 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1692                                 const char *property, const bool value)
1693 {
1694         char *val;
1695         GSList *link;
1696         int prop;
1697         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1698         pkgmgrinfo_node_x *node;
1699
1700         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1701         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1702
1703         prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1704         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1705                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1706                 _LOGE("Invalid Boolean Property\n");
1707                 return PMINFO_R_EINVAL;
1708         }
1709         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1710         if (node == NULL) {
1711                 _LOGE("Out of Memory!!!\n");
1712                 return PMINFO_R_ERROR;
1713         }
1714         if (value)
1715                 val = strndup("true", 4);
1716         else
1717                 val = strndup("false", 5);
1718         if (val == NULL) {
1719                 _LOGE("Out of Memory\n");
1720                 free(node);
1721                 return PMINFO_R_ERROR;
1722         }
1723         node->prop = prop;
1724         node->value = val;
1725         /*If API is called multiple times for same property, we should override the previous values.
1726         Last value set will be used for filtering.*/
1727         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1728         if (link)
1729                 filter->list = g_slist_delete_link(filter->list, link);
1730         filter->list = g_slist_append(filter->list, (gpointer)node);
1731         return PMINFO_R_OK;
1732
1733 }
1734
1735 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1736                                 const char *property, const char *value)
1737 {
1738         char *val;
1739         GSList *link;
1740         int prop;
1741         pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1742         pkgmgrinfo_node_x *node;
1743
1744         retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1745         retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1746         retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1747
1748         prop = _pminfo_pkginfo_convert_to_prop_str(property);
1749         if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1750                 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1751                 _LOGE("Invalid String Property\n");
1752                 return PMINFO_R_EINVAL;
1753         }
1754         node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1755         if (node == NULL) {
1756                 _LOGE("Out of Memory!!!\n");
1757                 return PMINFO_R_ERROR;
1758         }
1759         if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1760                 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1761         else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1762                 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1763         else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1764                 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1765         else if (strcmp(value, "installed_internal") == 0)
1766                 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1767         else if (strcmp(value, "installed_external") == 0)
1768                 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1769         else
1770                 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1771         if (val == NULL) {
1772                 _LOGE("Out of Memory\n");
1773                 free(node);
1774                 return PMINFO_R_ERROR;
1775         }
1776         node->prop = prop;
1777         node->value = val;
1778         /*If API is called multiple times for same property, we should override the previous values.
1779         Last value set will be used for filtering.*/
1780         link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1781         if (link)
1782                 filter->list = g_slist_delete_link(filter->list, link);
1783         filter->list = g_slist_append(filter->list, (gpointer)node);
1784         return PMINFO_R_OK;
1785
1786 }
1787
1788 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1789 {
1790         int ret;
1791         char *locale;
1792         GHashTable *list = NULL;
1793
1794         if (handle == NULL || count == NULL) {
1795                 _LOGE("invalid parameter");
1796                 return PMINFO_R_EINVAL;
1797         }
1798
1799         locale = _get_system_locale();
1800         if (locale == NULL)
1801                 return PMINFO_R_ERROR;
1802
1803         list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1804                         __free_packages);
1805         if (list == NULL) {
1806                 free(locale);
1807                 return PMINFO_R_ERROR;
1808         }
1809
1810         if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1811                 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1812                                 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1813                 if (ret != PMINFO_R_OK) {
1814                         free(locale);
1815                         g_hash_table_destroy(list);
1816                         return PMINFO_R_ERROR;
1817                 }
1818         }
1819
1820         ret = _pkginfo_get_packages(uid, locale,
1821                         (pkgmgrinfo_filter_x *)handle, 0, list);
1822         if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
1823                 ret = _pkginfo_get_packages(GLOBAL_USER, locale, handle, 0,
1824                                 list);
1825
1826         if (ret != PMINFO_R_OK) {
1827                 g_hash_table_destroy(list);
1828                 free(locale);
1829                 return PMINFO_R_ERROR;
1830         }
1831
1832         *count = g_hash_table_size(list);
1833
1834         g_hash_table_destroy(list);
1835         free(locale);
1836
1837         return PMINFO_R_OK;
1838 }
1839
1840 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1841 {
1842         return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1843 }
1844
1845 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1846                 pkgmgrinfo_pkginfo_filter_h handle,
1847                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1848 {
1849         if (handle == NULL || pkg_cb == NULL) {
1850                 LOGE("invalid parameter");
1851                 return PMINFO_R_EINVAL;
1852         }
1853
1854         return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1855                         PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1856 }
1857
1858 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1859                                 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1860 {
1861         return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1862 }
1863
1864 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1865                         pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1866 {
1867         retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1868         retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1869         int ret;
1870         privilege_x *privilege;
1871         GList *tmp;
1872         pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1873
1874         if (info->pkg_info == NULL)
1875                 return PMINFO_R_ERROR;
1876
1877         for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1878                 privilege = (privilege_x *)tmp->data;
1879                 if (privilege == NULL)
1880                         continue;
1881                 ret = privilege_func(privilege->value, user_data);
1882                 if (ret < 0)
1883                         break;
1884         }
1885         return PMINFO_R_OK;
1886 }
1887
1888 int __compare_package_version(const char *version, int *major,
1889                 int *minor, int *macro, int *nano)
1890 {
1891         char *version_temp = NULL;
1892         char *major_str = NULL;
1893         char *minor_str = NULL;
1894         char *macro_str = NULL;
1895         char *nano_str = NULL;
1896         char *save_str = NULL;
1897
1898         if (version == NULL || major == NULL || minor == NULL ||
1899                 macro == NULL || nano == NULL) {
1900                 return PMINFO_R_EINVAL;
1901         }
1902
1903         version_temp = strdup(version);
1904         if (version_temp == NULL) {
1905                 LOGE("Out of memory");
1906                 return PMINFO_R_ERROR;
1907         }
1908
1909         major_str = strtok_r(version_temp, ".", &save_str);
1910         if (major_str == NULL) {
1911                 _LOGE("major version is NULL");
1912                 free(version_temp);
1913                 return PMINFO_R_ERROR;
1914         }
1915
1916         minor_str = strtok_r(NULL, ".", &save_str);
1917         if (minor_str == NULL) {
1918                 _LOGE("minor version is NULL");
1919                 free(version_temp);
1920                 return PMINFO_R_ERROR;
1921         }
1922
1923         *major = atoi(major_str);
1924         *minor = atoi(minor_str);
1925         *macro = 0;
1926         *minor = 0;
1927         macro_str = strtok_r(NULL, ".", &save_str);
1928         if (macro_str == NULL) {
1929                 _LOGD("macro version is NULL");
1930         } else {
1931                 *macro = atoi(macro_str);
1932                 nano_str = strtok_r(NULL, ".", &save_str);
1933                 if (nano_str) {
1934                         *nano = atoi(nano_str);
1935                         _LOGD("nano version exists");
1936                 }
1937         }
1938         _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1939                 " macro = [%d], nano = [%d]", version, *major,
1940                 *minor, *macro, *nano);
1941
1942         free(version_temp);
1943
1944         return PMINFO_R_OK;
1945 }
1946
1947 API int pkgmgrinfo_compare_package_version(const char *current_version,
1948                 const char *target_version,
1949                 pkgmgrinfo_version_compare_type *res)
1950 {
1951         int ret = 0;
1952         int current_version_major = 0;
1953         int current_version_minor = 0;
1954         int current_version_macro = 0;
1955         int current_version_nano = 0;
1956         int target_version_major = 0;
1957         int target_version_minor = 0;
1958         int target_version_macro = 0;
1959         int target_version_nano = 0;
1960
1961         if (current_version == NULL || target_version == NULL ||
1962                 res == NULL) {
1963                 _LOGE("Invalid parameter");
1964                 return PMINFO_R_EINVAL;
1965         }
1966
1967         ret = __compare_package_version(target_version,
1968                 &target_version_major, &target_version_minor,
1969                 &target_version_macro, &target_version_nano);
1970         if (ret < 0) {
1971                 _LOGE("Failed to compare target version(%d)", ret);
1972                 return PMINFO_R_ERROR;
1973         }
1974
1975         ret = __compare_package_version(current_version,
1976                 &current_version_major, &current_version_minor,
1977                 &current_version_macro, &current_version_nano);
1978         if (ret < 0) {
1979                 _LOGE("Failed to compare current version(%d)", ret);
1980                 return PMINFO_R_ERROR;
1981         }
1982
1983         _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
1984                 target_version_minor, target_version_macro,
1985                 target_version_nano, current_version_major,
1986                 current_version_minor, current_version_macro,
1987                 target_version_nano);
1988
1989         if (target_version_major > current_version_major)
1990                 *res = PMINFO_VERSION_NEW;
1991         else if (target_version_major < current_version_major)
1992                 *res = PMINFO_VERSION_OLD;
1993         else if (target_version_minor > current_version_minor)
1994                 *res = PMINFO_VERSION_NEW;
1995         else if (target_version_minor < current_version_minor)
1996                 *res = PMINFO_VERSION_OLD;
1997         else if (target_version_macro > current_version_macro)
1998                 *res = PMINFO_VERSION_NEW;
1999         else if (target_version_macro < current_version_macro)
2000                 *res = PMINFO_VERSION_OLD;
2001         else if (target_version_nano > current_version_nano)
2002                 *res = PMINFO_VERSION_NEW;
2003         else if (target_version_nano < current_version_nano)
2004                 *res = PMINFO_VERSION_OLD;
2005         else
2006                 *res = PMINFO_VERSION_SAME;
2007
2008         return PMINFO_R_OK;
2009 }