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 strncat(buf, " WHERE 1=1 ", MAX_QUERY_LEN - len - 1);
246 len += strlen(" WHERE 1=1 ");
247 for (list = filter->list; list; list = list->next) {
248 joined |= __get_filter_condition(list->data, uid, &condition,
250 if (condition == NULL)
253 strncat(buf, " AND ", MAX_QUERY_LEN - len - 1);
254 len += strlen(" AND ");
256 strncat(buf, condition, sizeof(buf) - len - 1);
257 len += strlen(condition);
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;
379 sqlite3_stmt *stmt = 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);
574 sqlite3_finalize(stmt);
579 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
580 pkgmgrinfo_filter_x *filter, int flag,
581 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
586 pkgmgr_pkginfo_x info;
587 pkgmgrinfo_filter_x *tmp_filter = NULL;
592 locale = _get_system_locale();
594 return PMINFO_R_ERROR;
596 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
600 return PMINFO_R_ERROR;
603 if (filter != NULL) {
604 tmp_filter = (pkgmgrinfo_filter_x *)filter;
606 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
607 if (ret != PMINFO_R_OK) {
608 _LOGE("Failed to create filter");
609 g_hash_table_destroy(list);
610 return PMINFO_R_ERROR;
614 if (__check_disable_filter_exist(tmp_filter) == false)
615 pkgmgrinfo_pkginfo_filter_add_bool(tmp_filter,
616 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
618 ret = _pkginfo_get_packages(uid, locale, tmp_filter, flag, list);
619 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
620 ret = _pkginfo_get_packages(GLOBAL_USER, locale, tmp_filter,
623 if (ret != PMINFO_R_OK) {
624 g_hash_table_destroy(list);
627 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
628 return PMINFO_R_ERROR;
631 g_hash_table_iter_init(&iter, list);
632 while (g_hash_table_iter_next(&iter, NULL, &value)) {
633 pkg = (package_x *)value;
636 info.locale = locale;
637 if (pkg_list_cb(&info, user_data) < 0)
641 g_hash_table_destroy(list);
645 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
650 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
651 pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
656 pkgmgr_pkginfo_x *info;
658 if (pkgid == NULL || filter == NULL || handle == NULL) {
659 LOGE("invalid parameter");
660 return PMINFO_R_EINVAL;
663 locale = _get_system_locale();
665 return PMINFO_R_ERROR;
667 list = g_hash_table_new(g_str_hash, g_str_equal);
670 return PMINFO_R_ERROR;
673 ret = _pkginfo_get_packages(uid, locale, filter,
674 PMINFO_PKGINFO_GET_ALL, list);
675 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
676 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
677 PMINFO_PKGINFO_GET_ALL, list);
679 if (!g_hash_table_size(list)) {
680 _LOGI("pkginfo for [%s] is not existed for user [%d]",
682 g_hash_table_destroy(list);
684 return PMINFO_R_ENOENT;
687 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
689 _LOGE("out of memory");
690 g_hash_table_destroy(list);
692 return PMINFO_R_ERROR;
696 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
697 info->locale = locale;
699 /* just free list only */
700 g_hash_table_destroy(list);
707 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
708 pkgmgrinfo_pkginfo_h *handle)
711 pkgmgrinfo_pkginfo_filter_h filter;
713 if (pkgid == NULL || handle == NULL) {
714 LOGE("invalid parameter");
715 return PMINFO_R_EINVAL;
718 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
719 if (ret != PMINFO_R_OK)
722 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
723 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
724 if (ret != PMINFO_R_OK) {
725 pkgmgrinfo_pkginfo_filter_destroy(filter);
726 return PMINFO_R_ERROR;
729 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
730 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
731 if (ret != PMINFO_R_OK) {
732 pkgmgrinfo_pkginfo_filter_destroy(filter);
733 return PMINFO_R_ERROR;
736 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
737 pkgmgrinfo_pkginfo_filter_destroy(filter);
742 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
743 pkgmgrinfo_pkginfo_h *handle)
745 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
748 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
749 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
754 pkgmgrinfo_pkginfo_filter_h filter;
755 pkgmgr_pkginfo_x *info;
757 if (pkgid == NULL || handle == NULL) {
758 LOGE("invalid parameter");
759 return PMINFO_R_EINVAL;
762 locale = _get_system_locale();
764 return PMINFO_R_ERROR;
766 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
767 if (ret != PMINFO_R_OK) {
772 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
773 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
774 if (ret != PMINFO_R_OK) {
775 pkgmgrinfo_pkginfo_filter_destroy(filter);
777 return PMINFO_R_ERROR;
780 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
781 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
782 if (ret != PMINFO_R_OK) {
783 pkgmgrinfo_pkginfo_filter_destroy(filter);
785 return PMINFO_R_ERROR;
788 list = g_hash_table_new(g_str_hash, g_str_equal);
790 pkgmgrinfo_pkginfo_filter_destroy(filter);
792 return PMINFO_R_ERROR;
795 ret = _pkginfo_get_packages(uid, locale, filter,
796 PMINFO_PKGINFO_GET_ALL, list);
797 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
798 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
799 PMINFO_PKGINFO_GET_ALL, list);
801 pkgmgrinfo_pkginfo_filter_destroy(filter);
802 if (ret != PMINFO_R_OK) {
803 g_hash_table_destroy(list);
808 if (!g_hash_table_size(list)) {
809 _LOGI("disabled pkginfo for [%s] is not existed for user [%d]",
811 g_hash_table_destroy(list);
813 return PMINFO_R_ENOENT;
816 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
818 _LOGE("out of memory");
819 g_hash_table_destroy(list);
821 return PMINFO_R_ERROR;
825 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
826 info->locale = locale;
828 /* just free list only */
829 g_hash_table_destroy(list);
836 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
837 pkgmgrinfo_pkginfo_h *handle)
841 pkgmgrinfo_pkginfo_filter_h filter;
843 if (pkgid == NULL || handle == NULL) {
844 LOGE("invalid parameter");
845 return PMINFO_R_EINVAL;
848 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
849 if (ret != PMINFO_R_OK)
852 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
853 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
854 if (ret != PMINFO_R_OK) {
855 pkgmgrinfo_pkginfo_filter_destroy(filter);
856 return PMINFO_R_ERROR;
859 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
860 PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
861 if (ret != PMINFO_R_OK) {
862 pkgmgrinfo_pkginfo_filter_destroy(filter);
863 return PMINFO_R_ERROR;
866 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
867 pkgmgrinfo_pkginfo_filter_destroy(filter);
872 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
873 pkgmgrinfo_pkginfo_h *handle)
875 return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
879 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
880 pkgmgrinfo_pkginfo_h *handle)
882 return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
885 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
886 int flag, void *user_data, uid_t uid)
889 pkgmgrinfo_pkginfo_filter_h filter;
891 if (pkg_list_cb == NULL) {
892 LOGE("invalid parameter");
893 return PMINFO_R_EINVAL;
896 /* create an empty filter */
897 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
898 if (ret != PMINFO_R_OK)
901 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
902 pkg_list_cb, user_data);
904 pkgmgrinfo_pkginfo_filter_destroy(filter);
909 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
910 int flag, void *user_data)
912 return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
913 user_data, _getuid());
916 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
917 void *user_data, uid_t uid)
920 pkgmgrinfo_pkginfo_filter_h filter;
922 if (pkg_list_cb == NULL) {
923 LOGE("invalid parameter");
924 return PMINFO_R_EINVAL;
927 /* create an empty filter */
928 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
929 if (ret != PMINFO_R_OK)
932 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
933 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
935 pkgmgrinfo_pkginfo_filter_destroy(filter);
940 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
943 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
947 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
948 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
951 pkgmgrinfo_pkginfo_filter_h filter;
953 if (pkg_list_cb == NULL) {
954 LOGE("invalid parameter");
955 return PMINFO_R_EINVAL;
958 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
959 if (ret != PMINFO_R_OK)
962 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
963 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
964 if (ret != PMINFO_R_OK) {
965 pkgmgrinfo_pkginfo_filter_destroy(filter);
966 return PMINFO_R_ERROR;
969 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
970 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
972 pkgmgrinfo_pkginfo_filter_destroy(filter);
977 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
980 return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
984 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
986 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
988 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
989 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
991 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
992 return PMINFO_R_ERROR;
994 *pkg_name = (char *)info->pkg_info->package;
999 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
1001 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1003 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1004 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1006 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
1007 return PMINFO_R_ERROR;
1009 *pkgid = (char *)info->pkg_info->package;
1014 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
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(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1021 if (info->pkg_info == NULL)
1022 return PMINFO_R_ERROR;
1024 if (info->pkg_info->type == NULL)
1027 *type = (char *)info->pkg_info->type;
1032 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
1034 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1036 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1037 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1039 if (info->pkg_info == NULL)
1040 return PMINFO_R_ERROR;
1042 if (info->pkg_info->version == NULL)
1045 *version = (char *)info->pkg_info->version;
1050 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
1052 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1054 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1055 retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1057 if (info->pkg_info == NULL)
1058 return PMINFO_R_ERROR;
1060 if (info->pkg_info->api_version == NULL)
1063 *api_version = (char *)info->pkg_info->api_version;
1068 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
1070 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1072 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1073 retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1075 if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
1076 return PMINFO_R_ERROR;
1078 *tep_name = (char *)info->pkg_info->tep_name;
1083 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
1085 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1087 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1088 retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1090 if (info->pkg_info == NULL)
1091 return PMINFO_R_ERROR;
1093 if (info->pkg_info->zip_mount_file == NULL)
1094 *zip_mount_file = "";
1096 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
1101 API int pkgmgrinfo_pkginfo_get_external_image_path(pkgmgrinfo_pkginfo_h handle, char **ext_image_path)
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(ext_image_path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1108 if (info->pkg_info == NULL)
1109 return PMINFO_R_ERROR;
1111 if (info->pkg_info->external_path == NULL)
1112 return PMINFO_R_ENOENT;
1114 *ext_image_path = (char *)info->pkg_info->external_path;
1119 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
1122 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1124 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1125 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1127 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1128 return PMINFO_R_ERROR;
1130 val = (char *)info->pkg_info->installlocation;
1131 if (strcmp(val, "internal-only") == 0)
1132 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
1133 else if (strcmp(val, "prefer-external") == 0)
1134 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
1136 *location = PMINFO_INSTALL_LOCATION_AUTO;
1141 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
1143 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1146 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1147 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1149 if (info->pkg_info == NULL)
1150 return PMINFO_R_ERROR;
1152 if (info->pkg_info->package_size == NULL) {
1155 _LOGE("out of memory");
1156 return PMINFO_R_ERROR;
1158 info->pkg_info->package_size = temp;
1162 *size = atoi((char *)info->pkg_info->package_size);
1167 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
1170 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1172 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1173 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1175 if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
1176 return PMINFO_R_ERROR;
1178 ptr = (icon_x *)info->pkg_info->icon->data;
1180 return PMINFO_R_ERROR;
1182 /* TODO : should we return empty string if there was no icon? */
1183 if (ptr->text == NULL)
1191 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
1194 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1196 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1197 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1199 if (info->pkg_info == NULL || info->pkg_info->label == NULL)
1200 return PMINFO_R_ERROR;
1202 ptr = (label_x *)info->pkg_info->label->data;
1204 return PMINFO_R_ERROR;
1206 /* TODO : should we return empty string if there was no label? */
1207 if (ptr->text == NULL)
1215 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
1218 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1220 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1221 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1223 if (info->pkg_info == NULL || info->pkg_info->description == NULL)
1224 return PMINFO_R_ERROR;
1226 ptr = (description_x *)info->pkg_info->description->data;
1228 return PMINFO_R_ERROR;
1230 if (ptr->text == NULL)
1233 *description = (char *)ptr->text;
1238 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
1240 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1243 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1244 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1246 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1247 return PMINFO_R_ERROR;
1249 author = (author_x *)info->pkg_info->author->data;
1251 return PMINFO_R_ERROR;
1253 if (author->text == NULL)
1256 *author_name = (char *)author->text;
1261 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
1263 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1266 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1267 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1269 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1270 return PMINFO_R_ERROR;
1272 author = (author_x *)info->pkg_info->author->data;
1274 return PMINFO_R_ERROR;
1276 if (author->email == NULL)
1279 *author_email = (char *)author->email;
1284 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
1286 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1289 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1290 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1292 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1293 return PMINFO_R_ERROR;
1295 author = (author_x *)info->pkg_info->author->data;
1297 return PMINFO_R_ERROR;
1299 if (author->href == NULL)
1302 *author_href = (char *)author->href;
1307 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
1309 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1311 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1312 retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1314 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
1315 return PMINFO_R_ERROR;
1317 if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
1318 *storage = PMINFO_INTERNAL_STORAGE;
1319 else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
1320 *storage = PMINFO_EXTERNAL_STORAGE;
1322 return PMINFO_R_ERROR;
1327 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
1329 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1331 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1332 retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1334 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
1335 return PMINFO_R_ERROR;
1337 *installed_time = atoi(info->pkg_info->installed_time);
1342 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
1344 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1346 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1347 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1349 if (info->pkg_info == NULL)
1350 return PMINFO_R_ERROR;
1352 if (info->pkg_info->storeclient_id == NULL)
1353 *storeclientid = "";
1355 *storeclientid = (char *)info->pkg_info->storeclient_id;
1360 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
1362 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1364 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1365 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1367 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
1368 return PMINFO_R_ERROR;
1370 *mainappid = (char *)info->pkg_info->mainapp_id;
1375 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
1377 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1379 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1380 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1382 if (info->pkg_info == NULL)
1383 return PMINFO_R_ERROR;
1385 if (info->pkg_info->package_url == NULL)
1388 *url = (char *)info->pkg_info->package_url;
1393 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
1395 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1397 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1398 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1400 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
1401 return PMINFO_R_ERROR;
1403 *path = (char *)info->pkg_info->root_path;
1408 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
1410 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1412 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1413 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1415 if (info->pkg_info == NULL)
1416 return PMINFO_R_ERROR;
1418 if (info->pkg_info->csc_path == NULL)
1421 *path = (char *)info->pkg_info->csc_path;
1426 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
1428 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1429 retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1431 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1432 if (info->pkg_info->support_mode)
1433 *support_mode = atoi(info->pkg_info->support_mode);
1440 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
1442 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1443 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1445 #if 0 /* smack issue occured, check later */
1447 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
1448 if (pkgid == NULL) {
1449 _LOGD("invalid func parameters\n");
1450 return PMINFO_R_ERROR;
1452 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
1455 char app_mmc_path[FILENAME_MAX] = { 0, };
1456 char app_dir_path[FILENAME_MAX] = { 0, };
1457 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
1458 snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
1459 snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
1460 snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
1462 /*check whether application is in external memory or not */
1463 fp = fopen(app_mmc_path, "r");
1465 _LOGD(" app path in external memory not accesible\n");
1470 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
1474 /*check whether application is in internal or not */
1476 _LOGD(" app path in internal memory not accesible\n");
1478 return PMINFO_R_ERROR;
1481 /*check whether the application is installed in SD card
1482 but SD card is not present*/
1483 fp = fopen(app_mmc_internal_path, "r");
1486 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1490 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1495 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1502 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1504 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1506 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1507 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1509 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1510 return PMINFO_R_ERROR;
1512 *removable = _get_bool_value(info->pkg_info->removable);
1517 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1520 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1522 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1523 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1525 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1526 return PMINFO_R_ERROR;
1528 val = (char *)info->pkg_info->installlocation;
1529 if (strcmp(val, "internal-only") == 0)
1531 else if (strcmp(val, "prefer-external") == 0)
1539 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1541 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1543 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1544 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1546 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1547 return PMINFO_R_ERROR;
1549 *preload = _get_bool_value(info->pkg_info->preload);
1554 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1556 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1558 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1559 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1561 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1562 return PMINFO_R_ERROR;
1564 *system = _get_bool_value(info->pkg_info->system);
1569 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1571 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1573 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1574 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1576 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1577 return PMINFO_R_ERROR;
1579 *readonly = _get_bool_value(info->pkg_info->readonly);
1584 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1586 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1588 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1589 retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1591 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1592 return PMINFO_R_ERROR;
1594 *update = _get_bool_value(info->pkg_info->update);
1599 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1601 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1603 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1604 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1606 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1607 return PMINFO_R_ERROR;
1609 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1614 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1616 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1618 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1619 retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1621 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1622 return PMINFO_R_ERROR;
1624 *global = _get_bool_value(info->pkg_info->for_all_users);
1629 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1631 return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1634 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1636 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1638 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1640 __cleanup_pkginfo(info);
1645 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1647 pkgmgrinfo_filter_x *filter;
1649 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1651 filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1652 if (filter == NULL) {
1653 _LOGE("Out of Memory!!!");
1654 return PMINFO_R_ERROR;
1662 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1664 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1666 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1669 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1670 g_slist_free(filter->list);
1673 g_slist_free_full(filter->list_metadata, __destroy_metadata_node);
1680 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1681 const char *property, const int value)
1683 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1687 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1688 pkgmgrinfo_node_x *node;
1690 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1691 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1693 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1694 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1695 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1696 _LOGE("Invalid Integer Property\n");
1697 return PMINFO_R_EINVAL;
1699 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1701 _LOGE("Out of Memory!!!\n");
1702 return PMINFO_R_ERROR;
1704 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1705 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1707 _LOGE("Out of Memory\n");
1709 return PMINFO_R_ERROR;
1713 /*If API is called multiple times for same property, we should override the previous values.
1714 Last value set will be used for filtering.*/
1715 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1717 filter->list = g_slist_delete_link(filter->list, link);
1718 filter->list = g_slist_append(filter->list, (gpointer)node);
1723 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1724 const char *property, const bool value)
1729 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1730 pkgmgrinfo_node_x *node;
1732 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1733 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1735 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1736 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1737 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1738 _LOGE("Invalid Boolean Property\n");
1739 return PMINFO_R_EINVAL;
1741 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1743 _LOGE("Out of Memory!!!\n");
1744 return PMINFO_R_ERROR;
1747 val = strndup("true", 4);
1749 val = strndup("false", 5);
1751 _LOGE("Out of Memory\n");
1753 return PMINFO_R_ERROR;
1757 /*If API is called multiple times for same property, we should override the previous values.
1758 Last value set will be used for filtering.*/
1759 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1761 filter->list = g_slist_delete_link(filter->list, link);
1762 filter->list = g_slist_append(filter->list, (gpointer)node);
1767 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1768 const char *property, const char *value)
1773 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1774 pkgmgrinfo_node_x *node;
1776 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1777 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1778 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1780 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1781 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1782 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1783 _LOGE("Invalid String Property\n");
1784 return PMINFO_R_EINVAL;
1786 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1788 _LOGE("Out of Memory!!!\n");
1789 return PMINFO_R_ERROR;
1791 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1792 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1793 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1794 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1795 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1796 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1797 else if (strcmp(value, "installed_internal") == 0)
1798 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1799 else if (strcmp(value, "installed_external") == 0)
1800 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1802 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1804 _LOGE("Out of Memory\n");
1806 return PMINFO_R_ERROR;
1810 /*If API is called multiple times for same property, we should override the previous values.
1811 Last value set will be used for filtering.*/
1812 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1814 filter->list = g_slist_delete_link(filter->list, link);
1815 filter->list = g_slist_append(filter->list, (gpointer)node);
1820 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1824 GHashTable *list = NULL;
1826 if (handle == NULL || count == NULL) {
1827 _LOGE("invalid parameter");
1828 return PMINFO_R_EINVAL;
1831 locale = _get_system_locale();
1833 return PMINFO_R_ERROR;
1835 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1839 return PMINFO_R_ERROR;
1842 if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1843 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1844 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1845 if (ret != PMINFO_R_OK) {
1847 g_hash_table_destroy(list);
1848 return PMINFO_R_ERROR;
1852 ret = _pkginfo_get_packages(uid, locale,
1853 (pkgmgrinfo_filter_x *)handle, 0, list);
1854 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
1855 ret = _pkginfo_get_packages(GLOBAL_USER, locale, handle, 0,
1858 if (ret != PMINFO_R_OK) {
1859 g_hash_table_destroy(list);
1861 return PMINFO_R_ERROR;
1864 *count = g_hash_table_size(list);
1866 g_hash_table_destroy(list);
1872 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1874 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1877 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1878 pkgmgrinfo_pkginfo_filter_h handle,
1879 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1881 if (handle == NULL || pkg_cb == NULL) {
1882 LOGE("invalid parameter");
1883 return PMINFO_R_EINVAL;
1886 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1887 PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1890 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1891 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1893 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1896 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1897 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1899 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1900 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1902 privilege_x *privilege;
1904 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1906 if (info->pkg_info == NULL)
1907 return PMINFO_R_ERROR;
1909 for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1910 privilege = (privilege_x *)tmp->data;
1911 if (privilege == NULL)
1913 ret = privilege_func(privilege->value, user_data);
1920 int __compare_package_version(const char *version, int *major,
1921 int *minor, int *macro, int *nano)
1923 char *version_temp = NULL;
1924 char *major_str = NULL;
1925 char *minor_str = NULL;
1926 char *macro_str = NULL;
1927 char *nano_str = NULL;
1928 char *save_str = NULL;
1930 if (version == NULL || major == NULL || minor == NULL ||
1931 macro == NULL || nano == NULL) {
1932 return PMINFO_R_EINVAL;
1935 version_temp = strdup(version);
1936 if (version_temp == NULL) {
1937 LOGE("Out of memory");
1938 return PMINFO_R_ERROR;
1941 major_str = strtok_r(version_temp, ".", &save_str);
1942 if (major_str == NULL) {
1943 _LOGE("major version is NULL");
1945 return PMINFO_R_ERROR;
1948 minor_str = strtok_r(NULL, ".", &save_str);
1949 if (minor_str == NULL) {
1950 _LOGE("minor version is NULL");
1952 return PMINFO_R_ERROR;
1955 *major = atoi(major_str);
1956 *minor = atoi(minor_str);
1959 macro_str = strtok_r(NULL, ".", &save_str);
1960 if (macro_str == NULL) {
1961 _LOGD("macro version is NULL");
1963 *macro = atoi(macro_str);
1964 nano_str = strtok_r(NULL, ".", &save_str);
1966 *nano = atoi(nano_str);
1967 _LOGD("nano version exists");
1970 _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1971 " macro = [%d], nano = [%d]", version, *major,
1972 *minor, *macro, *nano);
1979 API int pkgmgrinfo_compare_package_version(const char *current_version,
1980 const char *target_version,
1981 pkgmgrinfo_version_compare_type *res)
1984 int current_version_major = 0;
1985 int current_version_minor = 0;
1986 int current_version_macro = 0;
1987 int current_version_nano = 0;
1988 int target_version_major = 0;
1989 int target_version_minor = 0;
1990 int target_version_macro = 0;
1991 int target_version_nano = 0;
1993 if (current_version == NULL || target_version == NULL ||
1995 _LOGE("Invalid parameter");
1996 return PMINFO_R_EINVAL;
1999 ret = __compare_package_version(target_version,
2000 &target_version_major, &target_version_minor,
2001 &target_version_macro, &target_version_nano);
2003 _LOGE("Failed to compare target version(%d)", ret);
2004 return PMINFO_R_ERROR;
2007 ret = __compare_package_version(current_version,
2008 ¤t_version_major, ¤t_version_minor,
2009 ¤t_version_macro, ¤t_version_nano);
2011 _LOGE("Failed to compare current version(%d)", ret);
2012 return PMINFO_R_ERROR;
2015 _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
2016 target_version_minor, target_version_macro,
2017 target_version_nano, current_version_major,
2018 current_version_minor, current_version_macro,
2019 target_version_nano);
2021 if (target_version_major > current_version_major)
2022 *res = PMINFO_VERSION_NEW;
2023 else if (target_version_major < current_version_major)
2024 *res = PMINFO_VERSION_OLD;
2025 else if (target_version_minor > current_version_minor)
2026 *res = PMINFO_VERSION_NEW;
2027 else if (target_version_minor < current_version_minor)
2028 *res = PMINFO_VERSION_OLD;
2029 else if (target_version_macro > current_version_macro)
2030 *res = PMINFO_VERSION_NEW;
2031 else if (target_version_macro < current_version_macro)
2032 *res = PMINFO_VERSION_OLD;
2033 else if (target_version_nano > current_version_nano)
2034 *res = PMINFO_VERSION_NEW;
2035 else if (target_version_nano < current_version_nano)
2036 *res = PMINFO_VERSION_OLD;
2038 *res = PMINFO_VERSION_SAME;