4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
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>
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
13 * http://www.apache.org/licenses/LICENSE-2.0
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.
30 #include <sys/smack.h>
31 #include <linux/limits.h>
38 #include "pkgmgrinfo_basic.h"
39 #include "pkgmgrinfo_private.h"
40 #include "pkgmgrinfo_debug.h"
41 #include "pkgmgr-info.h"
43 static bool _get_bool_value(const char *str)
45 if (str && !strcmp(str, "true"))
51 static gint __compare_func(gconstpointer data1, gconstpointer data2)
53 pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x *)data1;
54 pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x *)data2;
55 if (node1->prop == node2->prop)
57 else if (node1->prop > node2->prop)
63 static gint __pkg_disable_chk_func(gconstpointer data1, gconstpointer data2)
65 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data1;
67 if (node->prop == E_PMINFO_PKGINFO_PROP_PACKAGE_DISABLE)
73 static void __destroy_each_node(gpointer data, gpointer user_data)
76 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data;
89 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
93 free((void *)data->locale);
97 pkgmgrinfo_basic_free_package(data->pkg_info);
103 long long _pkgmgr_calculate_dir_size(char *dirname)
107 int q = 0; /*quotient*/
108 int r = 0; /*remainder*/
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");
115 dp = opendir(dirname);
117 _LOGE("Couldn't open the directory\n");
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, "..")) {
128 snprintf(abs_filename, FILENAME_MAX, "%s/%s", dirname,
130 if (lstat(abs_filename, &fileinfo) < 0)
131 perror(abs_filename);
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
141 } else if (S_ISLNK(fileinfo.st_mode)) {
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);
150 total += q * BLOCK_SIZE;
159 static int _pkginfo_add_description_info_into_list(const char *locale,
160 char *record, GList **description)
164 info = calloc(1, sizeof(description_x));
166 LOGE("out of memory");
167 return PMINFO_R_ERROR;
169 info->lang = strdup(locale);
171 *description = g_list_append(*description, info);
176 static int _pkginfo_get_privilege(sqlite3 *db, const char *pkgid,
179 static const char query_raw[] =
180 "SELECT DISTINCT privilege, type FROM package_privilege_info "
185 privilege_x *privilege;
187 query = sqlite3_mprintf(query_raw, pkgid);
189 LOGE("out of memory");
190 return PMINFO_R_ERROR;
193 ret = sqlite3_prepare_v2(db, query, strlen(query),
196 if (ret != SQLITE_OK) {
197 LOGE("prepare failed: %s", sqlite3_errmsg(db));
198 return PMINFO_R_ERROR;
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);
209 sqlite3_finalize(stmt);
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";
222 static int _get_filtered_query(pkgmgrinfo_filter_x *filter,
223 const char *locale, char **query, GList **bind_params)
226 char buf[MAX_QUERY_LEN] = { '\0' };
227 char buf2[MAX_QUERY_LEN] = { '\0' };
228 char *condition = NULL;
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, &condition,
240 if (condition == NULL)
243 len += strlen(" AND ");
244 strncat(buf, " AND ", MAX_QUERY_LEN - len - 1);
246 len += strlen(condition);
247 strncat(buf, condition, sizeof(buf) - len - 1);
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));
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);
261 strncat(buf2, buf, MAX_QUERY_LEN - len - 1);
263 *query = strdup(buf2);
265 return PMINFO_R_ERROR;
270 static void __free_packages(gpointer data)
272 pkgmgrinfo_basic_free_package((package_x *)data);
275 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
282 link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
289 static int __bind_params(sqlite3_stmt *stmt, GList *params)
291 GList *tmp_list = NULL;
295 if (stmt == NULL || params == NULL)
296 return PMINFO_R_EINVAL;
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;
309 static int _pkginfo_get_packages(uid_t uid, const char *locale,
310 pkgmgrinfo_filter_x *filter, int flag, GHashTable *packages)
312 static const char query_raw[] =
313 "SELECT DISTINCT pi.package, pi.package_version, "
314 "pi.install_location, pi.package_removable, "
315 "pi.package_preload, pi.package_readonly, pi.package_update, "
316 "pi.package_appsetting, pi.package_system, pi.package_type, "
317 "pi.package_size, pi.installed_time, pi.installed_storage, "
318 "pi.storeclient_id, pi.mainapp_id, pi.package_url, "
319 "pi.root_path, pi.csc_path, pi.package_nodisplay, "
320 "pi.package_api_version, pi.package_support_disable, "
321 "pi.package_tep_name, pi.package_zip_mount_file, pi.external_path, "
322 "pi.package_support_mode";
323 static const char query_author[] =
324 ", pi.author_name, pi.author_email, pi.author_href";
325 static const char query_label[] =
327 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
328 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
329 static const char query_icon[] =
331 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
332 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
333 static const char query_description[] =
335 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
336 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
337 static const char query_from_clause[] = " FROM package_info as pi";
338 int ret = PMINFO_R_ERROR;
342 char *tmp_record = NULL;
343 char *constraints = NULL;
344 char query[MAX_QUERY_LEN] = { '\0' };
345 package_x *info = NULL;
346 author_x *author = NULL;
347 GList *bind_params = NULL;
350 pkgmgrinfo_filter_x *tmp_filter = NULL;
352 dbpath = getUserPkgParserDBPathUID(uid);
354 return PMINFO_R_ERROR;
356 ret = sqlite3_open_v2(dbpath, &db, SQLITE_OPEN_READONLY, NULL);
357 if (ret != SQLITE_OK) {
358 _LOGD("failed to open db: %d", ret);
360 return PMINFO_R_ERROR;
364 if (filter != NULL) {
367 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
368 if (ret != PMINFO_R_OK) {
369 _LOGE("Failed to create filter");
370 return PMINFO_R_ERROR;
374 query_len = strlen(query_raw);
375 snprintf(query, MAX_QUERY_LEN - 1, "%s", query_raw);
376 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
377 strncat(query, query_author, MAX_QUERY_LEN - query_len - 1);
378 query_len += strlen(query_author);
380 if (flag & PMINFO_PKGINFO_GET_LABEL) {
381 strncat(query, query_label, MAX_QUERY_LEN - query_len - 1);
382 query_len += strlen(query_label);
383 bind_params = g_list_append(bind_params, strdup(locale));
385 if (flag & PMINFO_PKGINFO_GET_ICON) {
386 strncat(query, query_icon, MAX_QUERY_LEN - query_len - 1);
387 query_len += strlen(query_icon);
388 bind_params = g_list_append(bind_params, strdup(locale));
390 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
391 strncat(query, query_description, MAX_QUERY_LEN - query_len - 1);
392 query_len += strlen(query_description);
393 bind_params = g_list_append(bind_params, strdup(locale));
396 strncat(query, query_from_clause, MAX_QUERY_LEN - query_len - 1);
397 query_len += strlen(query_from_clause);
399 ret = _get_filtered_query(tmp_filter, locale, &constraints, &bind_params);
400 if (ret != PMINFO_R_OK) {
401 LOGE("Failed to get WHERE clause");
406 strncat(query, constraints, MAX_QUERY_LEN - query_len - 1);
408 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
409 if (ret != SQLITE_OK) {
410 LOGE("prepare failed: %s", sqlite3_errmsg(db));
411 ret = PMINFO_R_ERROR;
415 ret = __bind_params(stmt, bind_params);
416 if (ret != SQLITE_OK) {
417 LOGE("Failed to bind parameters");
421 while (sqlite3_step(stmt) == SQLITE_ROW) {
422 info = calloc(1, sizeof(package_x));
424 LOGE("out of memory");
425 sqlite3_finalize(stmt);
426 sqlite3_close_v2(db);
427 return PMINFO_R_ERROR;
430 _save_column_str(stmt, idx++, &info->package);
431 if (g_hash_table_contains(packages,
432 (gconstpointer)info->package)) {
437 _save_column_str(stmt, idx++, &info->version);
438 _save_column_str(stmt, idx++, &info->installlocation);
439 _save_column_str(stmt, idx++, &info->removable);
440 _save_column_str(stmt, idx++, &info->preload);
441 _save_column_str(stmt, idx++, &info->readonly);
442 _save_column_str(stmt, idx++, &info->update);
443 _save_column_str(stmt, idx++, &info->appsetting);
444 _save_column_str(stmt, idx++, &info->system);
445 _save_column_str(stmt, idx++, &info->type);
446 _save_column_str(stmt, idx++, &info->package_size);
447 _save_column_str(stmt, idx++, &info->installed_time);
448 _save_column_str(stmt, idx++, &info->installed_storage);
449 _save_column_str(stmt, idx++, &info->storeclient_id);
450 _save_column_str(stmt, idx++, &info->mainapp_id);
451 _save_column_str(stmt, idx++, &info->package_url);
452 _save_column_str(stmt, idx++, &info->root_path);
453 _save_column_str(stmt, idx++, &info->csc_path);
454 _save_column_str(stmt, idx++, &info->nodisplay_setting);
455 _save_column_str(stmt, idx++, &info->api_version);
456 _save_column_str(stmt, idx++, &info->support_disable);
457 _save_column_str(stmt, idx++, &info->tep_name);
458 _save_column_str(stmt, idx++, &info->zip_mount_file);
459 _save_column_str(stmt, idx++, &info->external_path);
460 _save_column_str(stmt, idx++, &info->support_mode);
461 info->for_all_users =
462 strdup((uid != GLOBAL_USER) ? "false" : "true");
464 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
465 /* TODO : author should be retrieved at package_localized_info */
466 author = calloc(1, sizeof(author_x));
467 if (author == NULL) {
468 pkgmgrinfo_basic_free_package(info);
469 sqlite3_finalize(stmt);
470 sqlite3_close_v2(db);
471 return PMINFO_R_ERROR;
473 _save_column_str(stmt, idx++, &author->text);
474 _save_column_str(stmt, idx++, &author->email);
475 _save_column_str(stmt, idx++, &author->href);
476 info->author = g_list_append(info->author, author);
479 if (flag & PMINFO_PKGINFO_GET_LABEL) {
481 _save_column_str(stmt, idx++, &tmp_record);
483 if (_add_label_info_into_list(locale, tmp_record, &info->label)) {
484 pkgmgrinfo_basic_free_package(info);
485 sqlite3_finalize(stmt);
486 sqlite3_close_v2(db);
487 return PMINFO_R_ERROR;
491 if (flag & PMINFO_PKGINFO_GET_ICON) {
493 _save_column_str(stmt, idx++, &tmp_record);
494 if (_add_icon_info_into_list(locale, tmp_record, &info->icon)) {
495 pkgmgrinfo_basic_free_package(info);
496 sqlite3_finalize(stmt);
497 sqlite3_close_v2(db);
498 return PMINFO_R_ERROR;
502 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
504 _save_column_str(stmt, idx++, &tmp_record);
505 if (_pkginfo_add_description_info_into_list(locale, tmp_record,
506 &info->description)) {
507 pkgmgrinfo_basic_free_package(info);
508 sqlite3_finalize(stmt);
509 sqlite3_close_v2(db);
510 return PMINFO_R_ERROR;
514 if (flag & PMINFO_PKGINFO_GET_PRIVILEGE) {
515 if (_pkginfo_get_privilege(db, info->package,
516 &info->privileges)) {
517 pkgmgrinfo_basic_free_package(info);
518 sqlite3_finalize(stmt);
519 sqlite3_close_v2(db);
520 return PMINFO_R_ERROR;
524 if (__pkginfo_check_installed_storage(info) != PMINFO_R_OK) {
525 ret = PMINFO_R_ERROR;
526 pkgmgrinfo_basic_free_package(info);
531 g_hash_table_insert(packages, (gpointer)info->package,
541 if (ret != PMINFO_R_OK && info != NULL)
542 pkgmgrinfo_basic_free_package(info);
545 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
547 g_list_free_full(bind_params, free);
548 sqlite3_close_v2(db);
549 sqlite3_finalize(stmt);
554 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
555 pkgmgrinfo_filter_x *filter, int flag,
556 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
561 pkgmgr_pkginfo_x info;
562 pkgmgrinfo_filter_x *tmp_filter = NULL;
567 locale = _get_system_locale();
569 return PMINFO_R_ERROR;
571 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
575 return PMINFO_R_ERROR;
578 if (filter != NULL) {
579 tmp_filter = (pkgmgrinfo_filter_x *)filter;
581 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
582 if (ret != PMINFO_R_OK) {
583 _LOGE("Failed to create filter");
584 return PMINFO_R_ERROR;
588 if (__check_disable_filter_exist(tmp_filter) == false)
589 pkgmgrinfo_pkginfo_filter_add_bool(tmp_filter,
590 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
592 ret = _pkginfo_get_packages(uid, locale, filter, flag, list);
593 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
594 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
597 if (ret != PMINFO_R_OK) {
598 g_hash_table_destroy(list);
601 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
602 return PMINFO_R_ERROR;
605 g_hash_table_iter_init(&iter, list);
606 while (g_hash_table_iter_next(&iter, NULL, &value)) {
607 pkg = (package_x *)value;
610 info.locale = locale;
611 if (pkg_list_cb(&info, user_data) < 0)
615 g_hash_table_destroy(list);
619 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
624 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
625 pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
630 pkgmgr_pkginfo_x *info;
632 if (pkgid == NULL || filter == NULL || handle == NULL) {
633 LOGE("invalid parameter");
634 return PMINFO_R_EINVAL;
637 locale = _get_system_locale();
639 return PMINFO_R_ERROR;
641 list = g_hash_table_new(g_str_hash, g_str_equal);
643 pkgmgrinfo_pkginfo_filter_destroy(filter);
645 return PMINFO_R_ERROR;
648 ret = _pkginfo_get_packages(uid, locale, filter,
649 PMINFO_PKGINFO_GET_ALL, list);
650 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
651 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
652 PMINFO_PKGINFO_GET_ALL, list);
654 if (!g_hash_table_size(list)) {
655 _LOGI("pkginfo for [%s] is not existed for user [%d]",
657 g_hash_table_destroy(list);
659 return PMINFO_R_ENOENT;
662 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
664 _LOGE("out of memory");
665 g_hash_table_destroy(list);
667 return PMINFO_R_ERROR;
671 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
672 info->locale = locale;
674 /* just free list only */
675 g_hash_table_destroy(list);
684 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
685 pkgmgrinfo_pkginfo_h *handle)
688 pkgmgrinfo_pkginfo_filter_h filter;
690 if (pkgid == NULL || handle == NULL) {
691 LOGE("invalid parameter");
692 return PMINFO_R_EINVAL;
695 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
696 if (ret != PMINFO_R_OK)
699 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
700 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
701 if (ret != PMINFO_R_OK) {
702 pkgmgrinfo_pkginfo_filter_destroy(filter);
703 return PMINFO_R_ERROR;
706 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
707 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
708 if (ret != PMINFO_R_OK) {
709 pkgmgrinfo_pkginfo_filter_destroy(filter);
710 return PMINFO_R_ERROR;
713 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
714 pkgmgrinfo_pkginfo_filter_destroy(filter);
719 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
720 pkgmgrinfo_pkginfo_h *handle)
722 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
725 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
726 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
731 pkgmgrinfo_pkginfo_filter_h filter;
732 pkgmgr_pkginfo_x *info;
734 if (pkgid == NULL || handle == NULL) {
735 LOGE("invalid parameter");
736 return PMINFO_R_EINVAL;
739 locale = _get_system_locale();
741 return PMINFO_R_ERROR;
743 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
744 if (ret != PMINFO_R_OK) {
749 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
750 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
751 if (ret != PMINFO_R_OK) {
752 pkgmgrinfo_pkginfo_filter_destroy(filter);
754 return PMINFO_R_ERROR;
757 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
758 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
759 if (ret != PMINFO_R_OK) {
760 pkgmgrinfo_pkginfo_filter_destroy(filter);
762 return PMINFO_R_ERROR;
765 list = g_hash_table_new(g_str_hash, g_str_equal);
767 pkgmgrinfo_pkginfo_filter_destroy(filter);
769 return PMINFO_R_ERROR;
772 ret = _pkginfo_get_packages(uid, locale, filter,
773 PMINFO_PKGINFO_GET_ALL, list);
774 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
775 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
776 PMINFO_PKGINFO_GET_ALL, list);
778 pkgmgrinfo_pkginfo_filter_destroy(filter);
779 if (ret != PMINFO_R_OK) {
780 g_hash_table_destroy(list);
785 if (!g_hash_table_size(list)) {
786 _LOGI("disabled pkginfo for [%s] is not existed for user [%d]",
788 g_hash_table_destroy(list);
790 return PMINFO_R_ENOENT;
793 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
795 _LOGE("out of memory");
796 g_hash_table_destroy(list);
798 return PMINFO_R_ERROR;
802 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
803 info->locale = locale;
805 /* just free list only */
806 g_hash_table_destroy(list);
813 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
814 pkgmgrinfo_pkginfo_h *handle)
818 pkgmgrinfo_pkginfo_filter_h filter;
820 if (pkgid == NULL || handle == NULL) {
821 LOGE("invalid parameter");
822 return PMINFO_R_EINVAL;
825 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
826 if (ret != PMINFO_R_OK)
829 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
830 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
831 if (ret != PMINFO_R_OK) {
832 pkgmgrinfo_pkginfo_filter_destroy(filter);
833 return PMINFO_R_ERROR;
836 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
837 pkgmgrinfo_pkginfo_filter_destroy(filter);
842 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
843 pkgmgrinfo_pkginfo_h *handle)
845 return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
849 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
850 pkgmgrinfo_pkginfo_h *handle)
852 return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
855 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
856 int flag, void *user_data, uid_t uid)
858 if (pkg_list_cb == NULL) {
859 LOGE("invalid parameter");
860 return PMINFO_R_EINVAL;
863 return _pkginfo_get_filtered_foreach_pkginfo(uid, NULL, flag,
864 pkg_list_cb, user_data);
867 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
868 int flag, void *user_data)
870 return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
871 user_data, _getuid());
874 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
875 void *user_data, uid_t uid)
877 if (pkg_list_cb == NULL) {
878 LOGE("invalid parameter");
879 return PMINFO_R_EINVAL;
882 return _pkginfo_get_filtered_foreach_pkginfo(uid, NULL,
883 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
886 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
889 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
893 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
894 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
897 pkgmgrinfo_pkginfo_filter_h filter;
899 if (pkg_list_cb == NULL) {
900 LOGE("invalid parameter");
901 return PMINFO_R_EINVAL;
904 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
905 if (ret != PMINFO_R_OK)
908 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
909 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
910 if (ret != PMINFO_R_OK) {
911 pkgmgrinfo_pkginfo_filter_destroy(filter);
912 return PMINFO_R_ERROR;
915 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
916 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
918 pkgmgrinfo_pkginfo_filter_destroy(filter);
923 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
926 return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
930 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
932 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
934 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
935 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
937 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
938 return PMINFO_R_ERROR;
940 *pkg_name = (char *)info->pkg_info->package;
945 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
947 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
949 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
950 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
952 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
953 return PMINFO_R_ERROR;
955 *pkgid = (char *)info->pkg_info->package;
960 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
962 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
964 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
965 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
967 if (info->pkg_info == NULL)
968 return PMINFO_R_ERROR;
970 if (info->pkg_info->type == NULL)
973 *type = (char *)info->pkg_info->type;
978 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
980 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
982 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
983 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
985 if (info->pkg_info == NULL)
986 return PMINFO_R_ERROR;
988 if (info->pkg_info->version == NULL)
991 *version = (char *)info->pkg_info->version;
996 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
998 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1000 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1001 retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1003 if (info->pkg_info == NULL)
1004 return PMINFO_R_ERROR;
1006 if (info->pkg_info->api_version == NULL)
1009 *api_version = (char *)info->pkg_info->api_version;
1014 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
1016 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1018 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1019 retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1021 if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
1022 return PMINFO_R_ERROR;
1024 *tep_name = (char *)info->pkg_info->tep_name;
1029 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
1031 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1033 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1034 retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1036 if (info->pkg_info == NULL)
1037 return PMINFO_R_ERROR;
1039 if (info->pkg_info->zip_mount_file == NULL)
1040 *zip_mount_file = "";
1042 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
1047 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
1050 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1052 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1053 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1055 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1056 return PMINFO_R_ERROR;
1058 val = (char *)info->pkg_info->installlocation;
1059 if (strcmp(val, "internal-only") == 0)
1060 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
1061 else if (strcmp(val, "prefer-external") == 0)
1062 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
1064 *location = PMINFO_INSTALL_LOCATION_AUTO;
1069 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
1071 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1074 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1075 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1077 if (info->pkg_info == NULL)
1078 return PMINFO_R_ERROR;
1080 if (info->pkg_info->package_size == NULL) {
1083 _LOGE("out of memory");
1084 return PMINFO_R_ERROR;
1086 info->pkg_info->package_size = temp;
1090 *size = atoi((char *)info->pkg_info->package_size);
1095 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
1098 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1100 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1101 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1103 if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
1104 return PMINFO_R_ERROR;
1106 ptr = (icon_x *)info->pkg_info->icon->data;
1108 return PMINFO_R_ERROR;
1110 /* TODO : should we return empty string if there was no icon? */
1111 if (ptr->text == NULL)
1119 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
1122 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1124 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1125 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1127 if (info->pkg_info == NULL || info->pkg_info->label == NULL)
1128 return PMINFO_R_ERROR;
1130 ptr = (label_x *)info->pkg_info->label->data;
1132 return PMINFO_R_ERROR;
1134 /* TODO : should we return empty string if there was no label? */
1135 if (ptr->text == NULL)
1143 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
1146 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1148 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1149 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1151 if (info->pkg_info == NULL || info->pkg_info->description == NULL)
1152 return PMINFO_R_ERROR;
1154 ptr = (description_x *)info->pkg_info->description->data;
1156 return PMINFO_R_ERROR;
1158 if (ptr->text == NULL)
1161 *description = (char *)ptr->text;
1166 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
1168 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1171 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1172 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1174 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1175 return PMINFO_R_ERROR;
1177 author = (author_x *)info->pkg_info->author->data;
1179 return PMINFO_R_ERROR;
1181 if (author->text == NULL)
1184 *author_name = (char *)author->text;
1189 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
1191 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1194 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1195 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1197 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1198 return PMINFO_R_ERROR;
1200 author = (author_x *)info->pkg_info->author->data;
1202 return PMINFO_R_ERROR;
1204 if (author->email == NULL)
1207 *author_email = (char *)author->email;
1212 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
1214 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1217 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1218 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1220 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1221 return PMINFO_R_ERROR;
1223 author = (author_x *)info->pkg_info->author->data;
1225 return PMINFO_R_ERROR;
1227 if (author->href == NULL)
1230 *author_href = (char *)author->href;
1235 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
1237 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1239 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1240 retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1242 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
1243 return PMINFO_R_ERROR;
1245 if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
1246 *storage = PMINFO_INTERNAL_STORAGE;
1247 else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
1248 *storage = PMINFO_EXTERNAL_STORAGE;
1250 return PMINFO_R_ERROR;
1255 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
1257 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1259 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1260 retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1262 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
1263 return PMINFO_R_ERROR;
1265 *installed_time = atoi(info->pkg_info->installed_time);
1270 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
1272 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1274 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1275 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1277 if (info->pkg_info == NULL)
1278 return PMINFO_R_ERROR;
1280 if (info->pkg_info->storeclient_id == NULL)
1281 *storeclientid = "";
1283 *storeclientid = (char *)info->pkg_info->storeclient_id;
1288 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
1290 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1292 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1293 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1295 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
1296 return PMINFO_R_ERROR;
1298 *mainappid = (char *)info->pkg_info->mainapp_id;
1303 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
1305 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1307 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1308 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1310 if (info->pkg_info == NULL)
1311 return PMINFO_R_ERROR;
1313 if (info->pkg_info->package_url == NULL)
1316 *url = (char *)info->pkg_info->package_url;
1321 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
1323 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1325 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1326 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1328 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
1329 return PMINFO_R_ERROR;
1331 *path = (char *)info->pkg_info->root_path;
1336 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
1338 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1340 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1341 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1343 if (info->pkg_info == NULL)
1344 return PMINFO_R_ERROR;
1346 if (info->pkg_info->csc_path == NULL)
1349 *path = (char *)info->pkg_info->csc_path;
1354 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
1356 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1357 retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1359 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1360 if (info->pkg_info->support_mode)
1361 *support_mode = atoi(info->pkg_info->support_mode);
1368 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
1370 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1371 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1373 #if 0 /* smack issue occured, check later */
1375 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
1376 if (pkgid == NULL) {
1377 _LOGD("invalid func parameters\n");
1378 return PMINFO_R_ERROR;
1380 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
1383 char app_mmc_path[FILENAME_MAX] = { 0, };
1384 char app_dir_path[FILENAME_MAX] = { 0, };
1385 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
1386 snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
1387 snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
1388 snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
1390 /*check whether application is in external memory or not */
1391 fp = fopen(app_mmc_path, "r");
1393 _LOGD(" app path in external memory not accesible\n");
1398 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
1402 /*check whether application is in internal or not */
1404 _LOGD(" app path in internal memory not accesible\n");
1406 return PMINFO_R_ERROR;
1409 /*check whether the application is installed in SD card
1410 but SD card is not present*/
1411 fp = fopen(app_mmc_internal_path, "r");
1414 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1418 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1423 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1430 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1432 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1434 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1435 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1437 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1438 return PMINFO_R_ERROR;
1440 *removable = _get_bool_value(info->pkg_info->removable);
1445 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1448 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1450 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1451 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1453 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1454 return PMINFO_R_ERROR;
1456 val = (char *)info->pkg_info->installlocation;
1457 if (strcmp(val, "internal-only") == 0)
1459 else if (strcmp(val, "prefer-external") == 0)
1467 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1469 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1471 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1472 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1474 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1475 return PMINFO_R_ERROR;
1477 *preload = _get_bool_value(info->pkg_info->preload);
1482 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1484 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1486 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1487 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1489 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1490 return PMINFO_R_ERROR;
1492 *system = _get_bool_value(info->pkg_info->system);
1497 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1499 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1501 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1502 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1504 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1505 return PMINFO_R_ERROR;
1507 *readonly = _get_bool_value(info->pkg_info->readonly);
1512 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1514 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1516 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1517 retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1519 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1520 return PMINFO_R_ERROR;
1522 *update = _get_bool_value(info->pkg_info->update);
1527 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1529 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1531 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1532 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1534 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1535 return PMINFO_R_ERROR;
1537 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1542 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1544 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1546 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1547 retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1549 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1550 return PMINFO_R_ERROR;
1552 *global = _get_bool_value(info->pkg_info->for_all_users);
1557 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1559 return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1562 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1564 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1566 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1568 __cleanup_pkginfo(info);
1573 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1575 pkgmgrinfo_filter_x *filter;
1577 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1579 filter = (pkgmgrinfo_filter_x*)calloc(1, sizeof(pkgmgrinfo_filter_x));
1580 if (filter == NULL) {
1581 _LOGE("Out of Memory!!!");
1582 return PMINFO_R_ERROR;
1590 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1592 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1594 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1597 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1598 g_slist_free(filter->list);
1606 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1607 const char *property, const int value)
1609 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1613 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1614 pkgmgrinfo_node_x *node;
1616 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1617 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1619 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1620 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1621 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1622 _LOGE("Invalid Integer Property\n");
1623 return PMINFO_R_EINVAL;
1625 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1627 _LOGE("Out of Memory!!!\n");
1628 return PMINFO_R_ERROR;
1630 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1631 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1633 _LOGE("Out of Memory\n");
1635 return PMINFO_R_ERROR;
1639 /*If API is called multiple times for same property, we should override the previous values.
1640 Last value set will be used for filtering.*/
1641 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1643 filter->list = g_slist_delete_link(filter->list, link);
1644 filter->list = g_slist_append(filter->list, (gpointer)node);
1649 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1650 const char *property, const bool value)
1655 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1656 pkgmgrinfo_node_x *node;
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");
1661 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1662 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1663 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1664 _LOGE("Invalid Boolean Property\n");
1665 return PMINFO_R_EINVAL;
1667 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1669 _LOGE("Out of Memory!!!\n");
1670 return PMINFO_R_ERROR;
1673 val = strndup("true", 4);
1675 val = strndup("false", 5);
1677 _LOGE("Out of Memory\n");
1679 return PMINFO_R_ERROR;
1683 /*If API is called multiple times for same property, we should override the previous values.
1684 Last value set will be used for filtering.*/
1685 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1687 filter->list = g_slist_delete_link(filter->list, link);
1688 filter->list = g_slist_append(filter->list, (gpointer)node);
1693 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1694 const char *property, const char *value)
1699 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1700 pkgmgrinfo_node_x *node;
1702 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1703 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1704 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1706 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1707 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1708 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1709 _LOGE("Invalid String Property\n");
1710 return PMINFO_R_EINVAL;
1712 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1714 _LOGE("Out of Memory!!!\n");
1715 return PMINFO_R_ERROR;
1717 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1718 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1719 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1720 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1721 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1722 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1723 else if (strcmp(value, "installed_internal") == 0)
1724 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1725 else if (strcmp(value, "installed_external") == 0)
1726 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1728 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1730 _LOGE("Out of Memory\n");
1732 return PMINFO_R_ERROR;
1736 /*If API is called multiple times for same property, we should override the previous values.
1737 Last value set will be used for filtering.*/
1738 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1740 filter->list = g_slist_delete_link(filter->list, link);
1741 filter->list = g_slist_append(filter->list, (gpointer)node);
1746 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1750 GHashTable *list = NULL;
1752 if (handle == NULL || count == NULL) {
1753 _LOGE("invalid parameter");
1754 return PMINFO_R_EINVAL;
1757 locale = _get_system_locale();
1759 return PMINFO_R_ERROR;
1761 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1765 return PMINFO_R_ERROR;
1768 if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1769 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1770 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1771 if (ret != PMINFO_R_OK) {
1773 return PMINFO_R_ERROR;
1777 ret = _pkginfo_get_packages(uid, locale,
1778 (pkgmgrinfo_filter_x *)handle, 0, list);
1779 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
1780 ret = _pkginfo_get_packages(GLOBAL_USER, locale, handle, 0,
1783 if (ret != PMINFO_R_OK) {
1784 g_hash_table_destroy(list);
1786 return PMINFO_R_ERROR;
1789 *count = g_hash_table_size(list);
1791 g_hash_table_destroy(list);
1797 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1799 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1802 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1803 pkgmgrinfo_pkginfo_filter_h handle,
1804 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1806 if (handle == NULL || pkg_cb == NULL) {
1807 LOGE("invalid parameter");
1808 return PMINFO_R_EINVAL;
1811 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1812 PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1815 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1816 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1818 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1821 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1822 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1824 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1825 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1827 privilege_x *privilege;
1829 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1831 if (info->pkg_info == NULL)
1832 return PMINFO_R_ERROR;
1834 for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1835 privilege = (privilege_x *)tmp->data;
1836 if (privilege == NULL)
1838 ret = privilege_func(privilege->value, user_data);