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 __destroy_metadata_node(gpointer data)
91 pkgmgrinfo_metadata_node_x *node = (pkgmgrinfo_metadata_node_x *)data;
99 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
101 ret_if(data == NULL);
103 free((void *)data->locale);
107 pkgmgrinfo_basic_free_package(data->pkg_info);
113 long long _pkgmgr_calculate_dir_size(char *dirname)
117 int q = 0; /*quotient*/
118 int r = 0; /*remainder*/
120 struct dirent ep, *result;
121 struct stat fileinfo;
122 char abs_filename[FILENAME_MAX] = { 0, };
123 retvm_if(dirname == NULL, PMINFO_R_ERROR, "dirname is NULL");
125 dp = opendir(dirname);
127 _LOGE("Couldn't open the directory\n");
131 for (ret = readdir_r(dp, &ep, &result);
132 ret == 0 && result != NULL;
133 ret = readdir_r(dp, &ep, &result)) {
134 if (!strcmp(ep.d_name, ".") ||
135 !strcmp(ep.d_name, "..")) {
138 snprintf(abs_filename, FILENAME_MAX, "%s/%s", dirname,
140 if (lstat(abs_filename, &fileinfo) < 0)
141 perror(abs_filename);
143 if (S_ISDIR(fileinfo.st_mode)) {
144 total += fileinfo.st_size;
145 if (strcmp(ep.d_name, ".")
146 && strcmp(ep.d_name, "..")) {
147 ret = _pkgmgr_calculate_dir_size
151 } else if (S_ISLNK(fileinfo.st_mode)) {
154 /*It is a file. Calculate the actual
155 size occupied (in terms of 4096 blocks)*/
156 q = (fileinfo.st_size / BLOCK_SIZE);
157 r = (fileinfo.st_size % BLOCK_SIZE);
160 total += q * BLOCK_SIZE;
169 static int _pkginfo_add_description_info_into_list(const char *locale,
170 char *record, GList **description)
174 info = calloc(1, sizeof(description_x));
176 LOGE("out of memory");
177 return PMINFO_R_ERROR;
179 info->lang = strdup(locale);
181 *description = g_list_append(*description, info);
186 static int _pkginfo_get_privilege(sqlite3 *db, const char *pkgid,
189 static const char query_raw[] =
190 "SELECT DISTINCT privilege, type FROM package_privilege_info "
195 privilege_x *privilege;
197 query = sqlite3_mprintf(query_raw, pkgid);
199 LOGE("out of memory");
200 return PMINFO_R_ERROR;
203 ret = sqlite3_prepare_v2(db, query, strlen(query),
206 if (ret != SQLITE_OK) {
207 LOGE("prepare failed: %s", sqlite3_errmsg(db));
208 return PMINFO_R_ERROR;
211 while (sqlite3_step(stmt) == SQLITE_ROW) {
212 privilege = calloc(1, sizeof(privilege_x));
213 _save_column_str(stmt, 0, &privilege->value);
214 _save_column_str(stmt, 1, &privilege->type);
215 *privileges = g_list_append(*privileges,
216 (gpointer)privilege);
219 sqlite3_finalize(stmt);
224 static const char join_localized_info[] =
225 " LEFT OUTER JOIN package_localized_info"
226 " ON pi.package=package_localized_info.package"
227 " AND package_localized_info.package_locale=?";
228 static const char join_privilege_info[] =
229 " LEFT OUTER JOIN package_privilege_info"
230 " ON pi.package=package_privilege_info.package";
232 static int _get_filtered_query(pkgmgrinfo_filter_x *filter,
233 const char *locale, uid_t uid, char **query, GList **bind_params)
236 char buf[MAX_QUERY_LEN] = { '\0' };
237 char buf2[MAX_QUERY_LEN] = { '\0' };
238 char *condition = NULL;
245 len += strlen(" WHERE 1=1 ");
246 strncat(buf, " WHERE 1=1 ", MAX_QUERY_LEN - len - 1);
247 for (list = filter->list; list; list = list->next) {
248 joined |= __get_filter_condition(list->data, uid, &condition,
250 if (condition == NULL)
253 len += strlen(" AND ");
254 strncat(buf, " AND ", MAX_QUERY_LEN - len - 1);
256 len += strlen(condition);
257 strncat(buf, condition, sizeof(buf) - len - 1);
262 if (joined & E_PMINFO_PKGINFO_JOIN_LOCALIZED_INFO) {
263 strncat(buf2, join_localized_info, MAX_QUERY_LEN - len - 1);
264 len += strlen(join_localized_info);
265 *bind_params = g_list_append(*bind_params, strdup(locale));
267 if (joined & E_PMINFO_PKGINFO_JOIN_PRIVILEGE_INFO) {
268 strncat(buf2, join_privilege_info, MAX_QUERY_LEN - len - 1);
269 len += strlen(join_privilege_info);
271 strncat(buf2, buf, MAX_QUERY_LEN - len - 1);
273 *query = strdup(buf2);
275 return PMINFO_R_ERROR;
280 static void __free_packages(gpointer data)
282 pkgmgrinfo_basic_free_package((package_x *)data);
285 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
292 link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
299 static int __bind_params(sqlite3_stmt *stmt, GList *params)
301 GList *tmp_list = NULL;
305 if (stmt == NULL || params == NULL)
306 return PMINFO_R_EINVAL;
310 ret = sqlite3_bind_text(stmt, ++idx, (char *)tmp_list->data, -1, SQLITE_STATIC);
311 if (ret != SQLITE_OK)
312 return PMINFO_R_ERROR;
313 tmp_list = tmp_list->next;
319 static bool __check_package_storage_status(pkgmgrinfo_filter_x *tmp_filter)
321 GSList *tmp_list = NULL;
322 pkgmgrinfo_node_x *tmp_node = NULL;
325 property = _pminfo_pkginfo_convert_to_prop_bool(PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE);
326 for (tmp_list = tmp_filter->list; tmp_list != NULL;
327 tmp_list = g_slist_next(tmp_list)) {
328 tmp_node = (pkgmgrinfo_node_x *)tmp_list->data;
329 if (property == tmp_node->prop) {
330 if (strcmp(tmp_node->value, "true") == 0)
339 static int _pkginfo_get_packages(uid_t uid, const char *locale,
340 pkgmgrinfo_filter_x *filter, int flag, GHashTable *packages)
342 static const char query_raw[] =
343 "SELECT DISTINCT pi.package, pi.package_version, "
344 "pi.install_location, pi.package_removable, "
345 "pi.package_preload, pi.package_readonly, pi.package_update, "
346 "pi.package_appsetting, pi.package_system, pi.package_type, "
347 "pi.package_size, pi.installed_time, pi.installed_storage, "
348 "pi.storeclient_id, pi.mainapp_id, pi.package_url, "
349 "pi.root_path, pi.csc_path, pi.package_nodisplay, "
350 "pi.package_api_version, pi.package_support_disable, "
351 "pi.package_tep_name, pi.package_zip_mount_file, pi.external_path, "
352 "pi.package_support_mode";
353 static const char query_author[] =
354 ", pi.author_name, pi.author_email, pi.author_href";
355 static const char query_label[] =
357 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
358 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
359 static const char query_icon[] =
361 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
362 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
363 static const char query_description[] =
365 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
366 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
367 static const char query_from_clause[] = " FROM package_info as pi";
368 int ret = PMINFO_R_ERROR;
372 char *tmp_record = NULL;
373 char *constraints = NULL;
374 char query[MAX_QUERY_LEN] = { '\0' };
375 package_x *info = NULL;
376 author_x *author = NULL;
377 GList *bind_params = NULL;
380 pkgmgrinfo_filter_x *tmp_filter = NULL;
381 bool is_check_storage = true;
383 dbpath = getUserPkgParserDBPathUID(uid);
385 return PMINFO_R_ERROR;
387 ret = __open_db(dbpath, &db, SQLITE_OPEN_READONLY);
388 if (ret != SQLITE_OK) {
389 _LOGD("failed to open db: %d", ret);
391 return PMINFO_R_ERROR;
395 if (filter != NULL) {
398 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
399 if (ret != PMINFO_R_OK) {
400 _LOGE("Failed to create filter");
401 return PMINFO_R_ERROR;
405 is_check_storage = __check_package_storage_status(tmp_filter);
407 query_len = strlen(query_raw);
408 snprintf(query, MAX_QUERY_LEN - 1, "%s", query_raw);
409 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
410 strncat(query, query_author, MAX_QUERY_LEN - query_len - 1);
411 query_len += strlen(query_author);
413 if (flag & PMINFO_PKGINFO_GET_LABEL) {
414 strncat(query, query_label, MAX_QUERY_LEN - query_len - 1);
415 query_len += strlen(query_label);
416 bind_params = g_list_append(bind_params, strdup(locale));
418 if (flag & PMINFO_PKGINFO_GET_ICON) {
419 strncat(query, query_icon, MAX_QUERY_LEN - query_len - 1);
420 query_len += strlen(query_icon);
421 bind_params = g_list_append(bind_params, strdup(locale));
423 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
424 strncat(query, query_description, MAX_QUERY_LEN - query_len - 1);
425 query_len += strlen(query_description);
426 bind_params = g_list_append(bind_params, strdup(locale));
429 strncat(query, query_from_clause, MAX_QUERY_LEN - query_len - 1);
430 query_len += strlen(query_from_clause);
432 ret = _get_filtered_query(tmp_filter, locale, uid, &constraints, &bind_params);
433 if (ret != PMINFO_R_OK) {
434 LOGE("Failed to get WHERE clause");
439 strncat(query, constraints, MAX_QUERY_LEN - query_len - 1);
441 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
442 if (ret != SQLITE_OK) {
443 LOGE("prepare failed: %s", sqlite3_errmsg(db));
444 ret = PMINFO_R_ERROR;
448 ret = __bind_params(stmt, bind_params);
449 if (ret != SQLITE_OK) {
450 LOGE("Failed to bind parameters");
454 while (sqlite3_step(stmt) == SQLITE_ROW) {
455 info = calloc(1, sizeof(package_x));
457 LOGE("out of memory");
458 ret = PMINFO_R_ERROR;
462 _save_column_str(stmt, idx++, &info->package);
463 if (g_hash_table_contains(packages,
464 (gconstpointer)info->package)) {
470 _save_column_str(stmt, idx++, &info->version);
471 _save_column_str(stmt, idx++, &info->installlocation);
472 _save_column_str(stmt, idx++, &info->removable);
473 _save_column_str(stmt, idx++, &info->preload);
474 _save_column_str(stmt, idx++, &info->readonly);
475 _save_column_str(stmt, idx++, &info->update);
476 _save_column_str(stmt, idx++, &info->appsetting);
477 _save_column_str(stmt, idx++, &info->system);
478 _save_column_str(stmt, idx++, &info->type);
479 _save_column_str(stmt, idx++, &info->package_size);
480 _save_column_str(stmt, idx++, &info->installed_time);
481 _save_column_str(stmt, idx++, &info->installed_storage);
482 _save_column_str(stmt, idx++, &info->storeclient_id);
483 _save_column_str(stmt, idx++, &info->mainapp_id);
484 _save_column_str(stmt, idx++, &info->package_url);
485 _save_column_str(stmt, idx++, &info->root_path);
486 _save_column_str(stmt, idx++, &info->csc_path);
487 _save_column_str(stmt, idx++, &info->nodisplay_setting);
488 _save_column_str(stmt, idx++, &info->api_version);
489 _save_column_str(stmt, idx++, &info->support_disable);
490 _save_column_str(stmt, idx++, &info->tep_name);
491 _save_column_str(stmt, idx++, &info->zip_mount_file);
492 _save_column_str(stmt, idx++, &info->external_path);
493 _save_column_str(stmt, idx++, &info->support_mode);
494 info->for_all_users =
495 strdup((uid != GLOBAL_USER) ? "false" : "true");
497 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
498 /* TODO : author should be retrieved at package_localized_info */
499 author = calloc(1, sizeof(author_x));
500 if (author == NULL) {
501 ret = PMINFO_R_ERROR;
504 _save_column_str(stmt, idx++, &author->text);
505 _save_column_str(stmt, idx++, &author->email);
506 _save_column_str(stmt, idx++, &author->href);
507 info->author = g_list_append(info->author, author);
510 if (flag & PMINFO_PKGINFO_GET_LABEL) {
512 _save_column_str(stmt, idx++, &tmp_record);
514 if (_add_label_info_into_list(locale, tmp_record, &info->label)) {
515 ret = PMINFO_R_ERROR;
520 if (flag & PMINFO_PKGINFO_GET_ICON) {
522 _save_column_str(stmt, idx++, &tmp_record);
523 if (_add_icon_info_into_list(locale, tmp_record, &info->icon)) {
524 ret = PMINFO_R_ERROR;
529 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
531 _save_column_str(stmt, idx++, &tmp_record);
532 if (_pkginfo_add_description_info_into_list(locale, tmp_record,
533 &info->description)) {
534 ret = PMINFO_R_ERROR;
539 if (flag & PMINFO_PKGINFO_GET_PRIVILEGE) {
540 if (_pkginfo_get_privilege(db, info->package,
541 &info->privileges)) {
542 ret = PMINFO_R_ERROR;
547 if (is_check_storage &&
548 __pkginfo_check_installed_storage(info) != PMINFO_R_OK) {
549 ret = PMINFO_R_ERROR;
550 pkgmgrinfo_basic_free_package(info);
555 g_hash_table_insert(packages, (gpointer)info->package,
565 if (ret != PMINFO_R_OK && info != NULL)
566 pkgmgrinfo_basic_free_package(info);
569 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
571 g_list_free_full(bind_params, free);
572 sqlite3_close_v2(db);
573 sqlite3_finalize(stmt);
578 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
579 pkgmgrinfo_filter_x *filter, int flag,
580 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
585 pkgmgr_pkginfo_x info;
586 pkgmgrinfo_filter_x *tmp_filter = NULL;
591 locale = _get_system_locale();
593 return PMINFO_R_ERROR;
595 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
599 return PMINFO_R_ERROR;
602 if (filter != NULL) {
603 tmp_filter = (pkgmgrinfo_filter_x *)filter;
605 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
606 if (ret != PMINFO_R_OK) {
607 _LOGE("Failed to create filter");
608 g_hash_table_destroy(list);
609 return PMINFO_R_ERROR;
613 if (__check_disable_filter_exist(tmp_filter) == false)
614 pkgmgrinfo_pkginfo_filter_add_bool(tmp_filter,
615 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
617 ret = _pkginfo_get_packages(uid, locale, tmp_filter, flag, list);
618 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
619 ret = _pkginfo_get_packages(GLOBAL_USER, locale, tmp_filter,
622 if (ret != PMINFO_R_OK) {
623 g_hash_table_destroy(list);
626 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
627 return PMINFO_R_ERROR;
630 g_hash_table_iter_init(&iter, list);
631 while (g_hash_table_iter_next(&iter, NULL, &value)) {
632 pkg = (package_x *)value;
635 info.locale = locale;
636 if (pkg_list_cb(&info, user_data) < 0)
640 g_hash_table_destroy(list);
644 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
649 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
650 pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
655 pkgmgr_pkginfo_x *info;
657 if (pkgid == NULL || filter == NULL || handle == NULL) {
658 LOGE("invalid parameter");
659 return PMINFO_R_EINVAL;
662 locale = _get_system_locale();
664 return PMINFO_R_ERROR;
666 list = g_hash_table_new(g_str_hash, g_str_equal);
669 return PMINFO_R_ERROR;
672 ret = _pkginfo_get_packages(uid, locale, filter,
673 PMINFO_PKGINFO_GET_ALL, list);
674 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
675 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
676 PMINFO_PKGINFO_GET_ALL, list);
678 if (!g_hash_table_size(list)) {
679 _LOGI("pkginfo for [%s] is not existed for user [%d]",
681 g_hash_table_destroy(list);
683 return PMINFO_R_ENOENT;
686 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
688 _LOGE("out of memory");
689 g_hash_table_destroy(list);
691 return PMINFO_R_ERROR;
695 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
696 info->locale = locale;
698 /* just free list only */
699 g_hash_table_destroy(list);
706 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
707 pkgmgrinfo_pkginfo_h *handle)
710 pkgmgrinfo_pkginfo_filter_h filter;
712 if (pkgid == NULL || handle == NULL) {
713 LOGE("invalid parameter");
714 return PMINFO_R_EINVAL;
717 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
718 if (ret != PMINFO_R_OK)
721 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
722 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
723 if (ret != PMINFO_R_OK) {
724 pkgmgrinfo_pkginfo_filter_destroy(filter);
725 return PMINFO_R_ERROR;
728 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
729 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
730 if (ret != PMINFO_R_OK) {
731 pkgmgrinfo_pkginfo_filter_destroy(filter);
732 return PMINFO_R_ERROR;
735 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
736 pkgmgrinfo_pkginfo_filter_destroy(filter);
741 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
742 pkgmgrinfo_pkginfo_h *handle)
744 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
747 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
748 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
753 pkgmgrinfo_pkginfo_filter_h filter;
754 pkgmgr_pkginfo_x *info;
756 if (pkgid == NULL || handle == NULL) {
757 LOGE("invalid parameter");
758 return PMINFO_R_EINVAL;
761 locale = _get_system_locale();
763 return PMINFO_R_ERROR;
765 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
766 if (ret != PMINFO_R_OK) {
771 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
772 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
773 if (ret != PMINFO_R_OK) {
774 pkgmgrinfo_pkginfo_filter_destroy(filter);
776 return PMINFO_R_ERROR;
779 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
780 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
781 if (ret != PMINFO_R_OK) {
782 pkgmgrinfo_pkginfo_filter_destroy(filter);
784 return PMINFO_R_ERROR;
787 list = g_hash_table_new(g_str_hash, g_str_equal);
789 pkgmgrinfo_pkginfo_filter_destroy(filter);
791 return PMINFO_R_ERROR;
794 ret = _pkginfo_get_packages(uid, locale, filter,
795 PMINFO_PKGINFO_GET_ALL, list);
796 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
797 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
798 PMINFO_PKGINFO_GET_ALL, list);
800 pkgmgrinfo_pkginfo_filter_destroy(filter);
801 if (ret != PMINFO_R_OK) {
802 g_hash_table_destroy(list);
807 if (!g_hash_table_size(list)) {
808 _LOGI("disabled pkginfo for [%s] is not existed for user [%d]",
810 g_hash_table_destroy(list);
812 return PMINFO_R_ENOENT;
815 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
817 _LOGE("out of memory");
818 g_hash_table_destroy(list);
820 return PMINFO_R_ERROR;
824 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
825 info->locale = locale;
827 /* just free list only */
828 g_hash_table_destroy(list);
835 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
836 pkgmgrinfo_pkginfo_h *handle)
840 pkgmgrinfo_pkginfo_filter_h filter;
842 if (pkgid == NULL || handle == NULL) {
843 LOGE("invalid parameter");
844 return PMINFO_R_EINVAL;
847 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
848 if (ret != PMINFO_R_OK)
851 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
852 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
853 if (ret != PMINFO_R_OK) {
854 pkgmgrinfo_pkginfo_filter_destroy(filter);
855 return PMINFO_R_ERROR;
858 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
859 PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
860 if (ret != PMINFO_R_OK) {
861 pkgmgrinfo_pkginfo_filter_destroy(filter);
862 return PMINFO_R_ERROR;
865 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
866 pkgmgrinfo_pkginfo_filter_destroy(filter);
871 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
872 pkgmgrinfo_pkginfo_h *handle)
874 return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
878 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
879 pkgmgrinfo_pkginfo_h *handle)
881 return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
884 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
885 int flag, void *user_data, uid_t uid)
888 pkgmgrinfo_pkginfo_filter_h filter;
890 if (pkg_list_cb == NULL) {
891 LOGE("invalid parameter");
892 return PMINFO_R_EINVAL;
895 /* create an empty filter */
896 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
897 if (ret != PMINFO_R_OK)
900 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
901 pkg_list_cb, user_data);
903 pkgmgrinfo_pkginfo_filter_destroy(filter);
908 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
909 int flag, void *user_data)
911 return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
912 user_data, _getuid());
915 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
916 void *user_data, uid_t uid)
919 pkgmgrinfo_pkginfo_filter_h filter;
921 if (pkg_list_cb == NULL) {
922 LOGE("invalid parameter");
923 return PMINFO_R_EINVAL;
926 /* create an empty filter */
927 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
928 if (ret != PMINFO_R_OK)
931 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
932 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
934 pkgmgrinfo_pkginfo_filter_destroy(filter);
939 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
942 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
946 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
947 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
950 pkgmgrinfo_pkginfo_filter_h filter;
952 if (pkg_list_cb == NULL) {
953 LOGE("invalid parameter");
954 return PMINFO_R_EINVAL;
957 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
958 if (ret != PMINFO_R_OK)
961 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
962 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
963 if (ret != PMINFO_R_OK) {
964 pkgmgrinfo_pkginfo_filter_destroy(filter);
965 return PMINFO_R_ERROR;
968 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
969 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
971 pkgmgrinfo_pkginfo_filter_destroy(filter);
976 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
979 return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
983 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
985 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
987 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
988 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
990 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
991 return PMINFO_R_ERROR;
993 *pkg_name = (char *)info->pkg_info->package;
998 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
1000 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1002 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1003 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1005 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
1006 return PMINFO_R_ERROR;
1008 *pkgid = (char *)info->pkg_info->package;
1013 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
1015 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1017 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1018 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1020 if (info->pkg_info == NULL)
1021 return PMINFO_R_ERROR;
1023 if (info->pkg_info->type == NULL)
1026 *type = (char *)info->pkg_info->type;
1031 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
1033 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1035 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1036 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1038 if (info->pkg_info == NULL)
1039 return PMINFO_R_ERROR;
1041 if (info->pkg_info->version == NULL)
1044 *version = (char *)info->pkg_info->version;
1049 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
1051 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1053 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1054 retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1056 if (info->pkg_info == NULL)
1057 return PMINFO_R_ERROR;
1059 if (info->pkg_info->api_version == NULL)
1062 *api_version = (char *)info->pkg_info->api_version;
1067 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
1069 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1071 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1072 retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1074 if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
1075 return PMINFO_R_ERROR;
1077 *tep_name = (char *)info->pkg_info->tep_name;
1082 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
1084 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1086 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1087 retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1089 if (info->pkg_info == NULL)
1090 return PMINFO_R_ERROR;
1092 if (info->pkg_info->zip_mount_file == NULL)
1093 *zip_mount_file = "";
1095 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
1100 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
1103 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1105 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1106 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1108 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1109 return PMINFO_R_ERROR;
1111 val = (char *)info->pkg_info->installlocation;
1112 if (strcmp(val, "internal-only") == 0)
1113 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
1114 else if (strcmp(val, "prefer-external") == 0)
1115 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
1117 *location = PMINFO_INSTALL_LOCATION_AUTO;
1122 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
1124 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1127 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1128 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1130 if (info->pkg_info == NULL)
1131 return PMINFO_R_ERROR;
1133 if (info->pkg_info->package_size == NULL) {
1136 _LOGE("out of memory");
1137 return PMINFO_R_ERROR;
1139 info->pkg_info->package_size = temp;
1143 *size = atoi((char *)info->pkg_info->package_size);
1148 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
1151 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1153 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1154 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1156 if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
1157 return PMINFO_R_ERROR;
1159 ptr = (icon_x *)info->pkg_info->icon->data;
1161 return PMINFO_R_ERROR;
1163 /* TODO : should we return empty string if there was no icon? */
1164 if (ptr->text == NULL)
1172 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
1175 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1177 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1178 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1180 if (info->pkg_info == NULL || info->pkg_info->label == NULL)
1181 return PMINFO_R_ERROR;
1183 ptr = (label_x *)info->pkg_info->label->data;
1185 return PMINFO_R_ERROR;
1187 /* TODO : should we return empty string if there was no label? */
1188 if (ptr->text == NULL)
1196 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
1199 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1201 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1202 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1204 if (info->pkg_info == NULL || info->pkg_info->description == NULL)
1205 return PMINFO_R_ERROR;
1207 ptr = (description_x *)info->pkg_info->description->data;
1209 return PMINFO_R_ERROR;
1211 if (ptr->text == NULL)
1214 *description = (char *)ptr->text;
1219 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
1221 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1224 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1225 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1227 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1228 return PMINFO_R_ERROR;
1230 author = (author_x *)info->pkg_info->author->data;
1232 return PMINFO_R_ERROR;
1234 if (author->text == NULL)
1237 *author_name = (char *)author->text;
1242 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
1244 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1247 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1248 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1250 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1251 return PMINFO_R_ERROR;
1253 author = (author_x *)info->pkg_info->author->data;
1255 return PMINFO_R_ERROR;
1257 if (author->email == NULL)
1260 *author_email = (char *)author->email;
1265 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
1267 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1270 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1271 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1273 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1274 return PMINFO_R_ERROR;
1276 author = (author_x *)info->pkg_info->author->data;
1278 return PMINFO_R_ERROR;
1280 if (author->href == NULL)
1283 *author_href = (char *)author->href;
1288 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
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(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1295 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
1296 return PMINFO_R_ERROR;
1298 if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
1299 *storage = PMINFO_INTERNAL_STORAGE;
1300 else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
1301 *storage = PMINFO_EXTERNAL_STORAGE;
1303 return PMINFO_R_ERROR;
1308 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
1310 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1312 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1313 retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1315 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
1316 return PMINFO_R_ERROR;
1318 *installed_time = atoi(info->pkg_info->installed_time);
1323 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
1325 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1327 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1328 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1330 if (info->pkg_info == NULL)
1331 return PMINFO_R_ERROR;
1333 if (info->pkg_info->storeclient_id == NULL)
1334 *storeclientid = "";
1336 *storeclientid = (char *)info->pkg_info->storeclient_id;
1341 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
1343 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1345 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1346 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1348 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
1349 return PMINFO_R_ERROR;
1351 *mainappid = (char *)info->pkg_info->mainapp_id;
1356 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
1358 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1360 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1361 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1363 if (info->pkg_info == NULL)
1364 return PMINFO_R_ERROR;
1366 if (info->pkg_info->package_url == NULL)
1369 *url = (char *)info->pkg_info->package_url;
1374 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
1376 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1378 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1379 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1381 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
1382 return PMINFO_R_ERROR;
1384 *path = (char *)info->pkg_info->root_path;
1389 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
1391 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1393 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1394 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1396 if (info->pkg_info == NULL)
1397 return PMINFO_R_ERROR;
1399 if (info->pkg_info->csc_path == NULL)
1402 *path = (char *)info->pkg_info->csc_path;
1407 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
1409 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1410 retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1412 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1413 if (info->pkg_info->support_mode)
1414 *support_mode = atoi(info->pkg_info->support_mode);
1421 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
1423 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1424 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1426 #if 0 /* smack issue occured, check later */
1428 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
1429 if (pkgid == NULL) {
1430 _LOGD("invalid func parameters\n");
1431 return PMINFO_R_ERROR;
1433 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
1436 char app_mmc_path[FILENAME_MAX] = { 0, };
1437 char app_dir_path[FILENAME_MAX] = { 0, };
1438 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
1439 snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
1440 snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
1441 snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
1443 /*check whether application is in external memory or not */
1444 fp = fopen(app_mmc_path, "r");
1446 _LOGD(" app path in external memory not accesible\n");
1451 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
1455 /*check whether application is in internal or not */
1457 _LOGD(" app path in internal memory not accesible\n");
1459 return PMINFO_R_ERROR;
1462 /*check whether the application is installed in SD card
1463 but SD card is not present*/
1464 fp = fopen(app_mmc_internal_path, "r");
1467 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1471 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1476 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1483 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1485 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1487 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1488 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1490 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1491 return PMINFO_R_ERROR;
1493 *removable = _get_bool_value(info->pkg_info->removable);
1498 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1501 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1503 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1504 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1506 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1507 return PMINFO_R_ERROR;
1509 val = (char *)info->pkg_info->installlocation;
1510 if (strcmp(val, "internal-only") == 0)
1512 else if (strcmp(val, "prefer-external") == 0)
1520 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1522 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1524 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1525 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1527 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1528 return PMINFO_R_ERROR;
1530 *preload = _get_bool_value(info->pkg_info->preload);
1535 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1537 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1539 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1540 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1542 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1543 return PMINFO_R_ERROR;
1545 *system = _get_bool_value(info->pkg_info->system);
1550 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1552 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1554 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1555 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1557 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1558 return PMINFO_R_ERROR;
1560 *readonly = _get_bool_value(info->pkg_info->readonly);
1565 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1567 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1569 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1570 retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1572 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1573 return PMINFO_R_ERROR;
1575 *update = _get_bool_value(info->pkg_info->update);
1580 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1582 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1584 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1585 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1587 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1588 return PMINFO_R_ERROR;
1590 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1595 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1597 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1599 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1600 retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1602 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1603 return PMINFO_R_ERROR;
1605 *global = _get_bool_value(info->pkg_info->for_all_users);
1610 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1612 return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1615 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1617 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1619 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1621 __cleanup_pkginfo(info);
1626 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1628 pkgmgrinfo_filter_x *filter;
1630 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1632 filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1633 if (filter == NULL) {
1634 _LOGE("Out of Memory!!!");
1635 return PMINFO_R_ERROR;
1643 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1645 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1647 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1650 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1651 g_slist_free(filter->list);
1654 g_slist_free_full(filter->list_metadata, __destroy_metadata_node);
1661 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1662 const char *property, const int value)
1664 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1668 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1669 pkgmgrinfo_node_x *node;
1671 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1672 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1674 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1675 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1676 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1677 _LOGE("Invalid Integer Property\n");
1678 return PMINFO_R_EINVAL;
1680 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1682 _LOGE("Out of Memory!!!\n");
1683 return PMINFO_R_ERROR;
1685 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1686 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1688 _LOGE("Out of Memory\n");
1690 return PMINFO_R_ERROR;
1694 /*If API is called multiple times for same property, we should override the previous values.
1695 Last value set will be used for filtering.*/
1696 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1698 filter->list = g_slist_delete_link(filter->list, link);
1699 filter->list = g_slist_append(filter->list, (gpointer)node);
1704 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1705 const char *property, const bool value)
1710 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1711 pkgmgrinfo_node_x *node;
1713 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1714 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1716 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1717 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1718 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1719 _LOGE("Invalid Boolean Property\n");
1720 return PMINFO_R_EINVAL;
1722 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1724 _LOGE("Out of Memory!!!\n");
1725 return PMINFO_R_ERROR;
1728 val = strndup("true", 4);
1730 val = strndup("false", 5);
1732 _LOGE("Out of Memory\n");
1734 return PMINFO_R_ERROR;
1738 /*If API is called multiple times for same property, we should override the previous values.
1739 Last value set will be used for filtering.*/
1740 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1742 filter->list = g_slist_delete_link(filter->list, link);
1743 filter->list = g_slist_append(filter->list, (gpointer)node);
1748 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1749 const char *property, const char *value)
1754 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1755 pkgmgrinfo_node_x *node;
1757 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1758 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1759 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1761 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1762 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1763 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1764 _LOGE("Invalid String Property\n");
1765 return PMINFO_R_EINVAL;
1767 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1769 _LOGE("Out of Memory!!!\n");
1770 return PMINFO_R_ERROR;
1772 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1773 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1774 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1775 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1776 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1777 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1778 else if (strcmp(value, "installed_internal") == 0)
1779 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1780 else if (strcmp(value, "installed_external") == 0)
1781 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1783 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1785 _LOGE("Out of Memory\n");
1787 return PMINFO_R_ERROR;
1791 /*If API is called multiple times for same property, we should override the previous values.
1792 Last value set will be used for filtering.*/
1793 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1795 filter->list = g_slist_delete_link(filter->list, link);
1796 filter->list = g_slist_append(filter->list, (gpointer)node);
1801 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1805 GHashTable *list = NULL;
1807 if (handle == NULL || count == NULL) {
1808 _LOGE("invalid parameter");
1809 return PMINFO_R_EINVAL;
1812 locale = _get_system_locale();
1814 return PMINFO_R_ERROR;
1816 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1820 return PMINFO_R_ERROR;
1823 if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1824 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1825 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1826 if (ret != PMINFO_R_OK) {
1828 g_hash_table_destroy(list);
1829 return PMINFO_R_ERROR;
1833 ret = _pkginfo_get_packages(uid, locale,
1834 (pkgmgrinfo_filter_x *)handle, 0, list);
1835 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
1836 ret = _pkginfo_get_packages(GLOBAL_USER, locale, handle, 0,
1839 if (ret != PMINFO_R_OK) {
1840 g_hash_table_destroy(list);
1842 return PMINFO_R_ERROR;
1845 *count = g_hash_table_size(list);
1847 g_hash_table_destroy(list);
1853 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1855 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1858 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1859 pkgmgrinfo_pkginfo_filter_h handle,
1860 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1862 if (handle == NULL || pkg_cb == NULL) {
1863 LOGE("invalid parameter");
1864 return PMINFO_R_EINVAL;
1867 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1868 PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1871 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1872 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1874 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1877 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1878 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1880 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1881 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1883 privilege_x *privilege;
1885 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1887 if (info->pkg_info == NULL)
1888 return PMINFO_R_ERROR;
1890 for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1891 privilege = (privilege_x *)tmp->data;
1892 if (privilege == NULL)
1894 ret = privilege_func(privilege->value, user_data);
1901 int __compare_package_version(const char *version, int *major,
1902 int *minor, int *macro, int *nano)
1904 char *version_temp = NULL;
1905 char *major_str = NULL;
1906 char *minor_str = NULL;
1907 char *macro_str = NULL;
1908 char *nano_str = NULL;
1909 char *save_str = NULL;
1911 if (version == NULL || major == NULL || minor == NULL ||
1912 macro == NULL || nano == NULL) {
1913 return PMINFO_R_EINVAL;
1916 version_temp = strdup(version);
1917 if (version_temp == NULL) {
1918 LOGE("Out of memory");
1919 return PMINFO_R_ERROR;
1922 major_str = strtok_r(version_temp, ".", &save_str);
1923 if (major_str == NULL) {
1924 _LOGE("major version is NULL");
1926 return PMINFO_R_ERROR;
1929 minor_str = strtok_r(NULL, ".", &save_str);
1930 if (minor_str == NULL) {
1931 _LOGE("minor version is NULL");
1933 return PMINFO_R_ERROR;
1936 *major = atoi(major_str);
1937 *minor = atoi(minor_str);
1940 macro_str = strtok_r(NULL, ".", &save_str);
1941 if (macro_str == NULL) {
1942 _LOGD("macro version is NULL");
1944 *macro = atoi(macro_str);
1945 nano_str = strtok_r(NULL, ".", &save_str);
1947 *nano = atoi(nano_str);
1948 _LOGD("nano version exists");
1951 _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1952 " macro = [%d], nano = [%d]", version, *major,
1953 *minor, *macro, *nano);
1960 API int pkgmgrinfo_compare_package_version(const char *current_version,
1961 const char *target_version,
1962 pkgmgrinfo_version_compare_type *res)
1965 int current_version_major = 0;
1966 int current_version_minor = 0;
1967 int current_version_macro = 0;
1968 int current_version_nano = 0;
1969 int target_version_major = 0;
1970 int target_version_minor = 0;
1971 int target_version_macro = 0;
1972 int target_version_nano = 0;
1974 if (current_version == NULL || target_version == NULL ||
1976 _LOGE("Invalid parameter");
1977 return PMINFO_R_EINVAL;
1980 ret = __compare_package_version(target_version,
1981 &target_version_major, &target_version_minor,
1982 &target_version_macro, &target_version_nano);
1984 _LOGE("Failed to compare target version(%d)", ret);
1985 return PMINFO_R_ERROR;
1988 ret = __compare_package_version(current_version,
1989 ¤t_version_major, ¤t_version_minor,
1990 ¤t_version_macro, ¤t_version_nano);
1992 _LOGE("Failed to compare current version(%d)", ret);
1993 return PMINFO_R_ERROR;
1996 _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
1997 target_version_minor, target_version_macro,
1998 target_version_nano, current_version_major,
1999 current_version_minor, current_version_macro,
2000 target_version_nano);
2002 if (target_version_major > current_version_major)
2003 *res = PMINFO_VERSION_NEW;
2004 else if (target_version_major < current_version_major)
2005 *res = PMINFO_VERSION_OLD;
2006 else if (target_version_minor > current_version_minor)
2007 *res = PMINFO_VERSION_NEW;
2008 else if (target_version_minor < current_version_minor)
2009 *res = PMINFO_VERSION_OLD;
2010 else if (target_version_macro > current_version_macro)
2011 *res = PMINFO_VERSION_NEW;
2012 else if (target_version_macro < current_version_macro)
2013 *res = PMINFO_VERSION_OLD;
2014 else if (target_version_nano > current_version_nano)
2015 *res = PMINFO_VERSION_NEW;
2016 else if (target_version_nano < current_version_nano)
2017 *res = PMINFO_VERSION_OLD;
2019 *res = PMINFO_VERSION_SAME;