4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
6 * Contact: Jayoun Lee <airjany@samsung.com>, Sewook Park <sewook7.park@samsung.com>,
7 * Jaeho Lee <jaeho81.lee@samsung.com>, Shobhit Srivastava <shobhit.s@samsung.com>
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
30 #include <sys/smack.h>
31 #include <linux/limits.h>
38 #include "pkgmgrinfo_basic.h"
39 #include "pkgmgrinfo_private.h"
40 #include "pkgmgrinfo_debug.h"
41 #include "pkgmgr-info.h"
43 static bool _get_bool_value(const char *str)
45 if (str && !strcmp(str, "true"))
51 static gint __compare_func(gconstpointer data1, gconstpointer data2)
53 pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x *)data1;
54 pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x *)data2;
55 if (node1->prop == node2->prop)
57 else if (node1->prop > node2->prop)
63 static gint __pkg_disable_chk_func(gconstpointer data1, gconstpointer data2)
65 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data1;
67 if (node->prop == E_PMINFO_PKGINFO_PROP_PACKAGE_DISABLE)
73 static void __destroy_each_node(gpointer data, gpointer user_data)
76 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data;
89 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
93 free((void *)data->locale);
97 pkgmgrinfo_basic_free_package(data->pkg_info);
103 long long _pkgmgr_calculate_dir_size(char *dirname)
107 int q = 0; /*quotient*/
108 int r = 0; /*remainder*/
110 struct dirent ep, *result;
111 struct stat fileinfo;
112 char abs_filename[FILENAME_MAX] = { 0, };
113 retvm_if(dirname == NULL, PMINFO_R_ERROR, "dirname is NULL");
115 dp = opendir(dirname);
117 _LOGE("Couldn't open the directory\n");
121 for (ret = readdir_r(dp, &ep, &result);
122 ret == 0 && result != NULL;
123 ret = readdir_r(dp, &ep, &result)) {
124 if (!strcmp(ep.d_name, ".") ||
125 !strcmp(ep.d_name, "..")) {
128 snprintf(abs_filename, FILENAME_MAX, "%s/%s", dirname,
130 if (lstat(abs_filename, &fileinfo) < 0)
131 perror(abs_filename);
133 if (S_ISDIR(fileinfo.st_mode)) {
134 total += fileinfo.st_size;
135 if (strcmp(ep.d_name, ".")
136 && strcmp(ep.d_name, "..")) {
137 ret = _pkgmgr_calculate_dir_size
141 } else if (S_ISLNK(fileinfo.st_mode)) {
144 /*It is a file. Calculate the actual
145 size occupied (in terms of 4096 blocks)*/
146 q = (fileinfo.st_size / BLOCK_SIZE);
147 r = (fileinfo.st_size % BLOCK_SIZE);
150 total += q * BLOCK_SIZE;
159 static int _pkginfo_add_description_info_into_list(const char *locale,
160 char *record, GList **description)
164 info = calloc(1, sizeof(description_x));
166 LOGE("out of memory");
167 return PMINFO_R_ERROR;
169 info->lang = strdup(locale);
171 *description = g_list_append(*description, info);
176 static int _pkginfo_get_privilege(sqlite3 *db, const char *pkgid,
179 static const char query_raw[] =
180 "SELECT DISTINCT privilege, type FROM package_privilege_info "
185 privilege_x *privilege;
187 query = sqlite3_mprintf(query_raw, pkgid);
189 LOGE("out of memory");
190 return PMINFO_R_ERROR;
193 ret = sqlite3_prepare_v2(db, query, strlen(query),
196 if (ret != SQLITE_OK) {
197 LOGE("prepare failed: %s", sqlite3_errmsg(db));
198 return PMINFO_R_ERROR;
201 while (sqlite3_step(stmt) == SQLITE_ROW) {
202 privilege = calloc(1, sizeof(privilege_x));
203 _save_column_str(stmt, 0, &privilege->value);
204 _save_column_str(stmt, 1, &privilege->type);
205 *privileges = g_list_append(*privileges,
206 (gpointer)privilege);
209 sqlite3_finalize(stmt);
214 static const char join_localized_info[] =
215 " LEFT OUTER JOIN package_localized_info"
216 " ON pi.package=package_localized_info.package"
217 " AND package_localized_info.package_locale=?";
218 static const char join_privilege_info[] =
219 " LEFT OUTER JOIN package_privilege_info"
220 " ON pi.package=package_privilege_info.package";
222 static int _get_filtered_query(pkgmgrinfo_filter_x *filter,
223 const char *locale, uid_t uid, char **query, GList **bind_params)
226 char buf[MAX_QUERY_LEN] = { '\0' };
227 char buf2[MAX_QUERY_LEN] = { '\0' };
228 char *condition = NULL;
235 len += strlen(" WHERE 1=1 ");
236 strncat(buf, " WHERE 1=1 ", MAX_QUERY_LEN - len - 1);
237 for (list = filter->list; list; list = list->next) {
238 joined |= __get_filter_condition(list->data, uid, &condition,
240 if (condition == NULL)
243 len += strlen(" AND ");
244 strncat(buf, " AND ", MAX_QUERY_LEN - len - 1);
246 len += strlen(condition);
247 strncat(buf, condition, sizeof(buf) - len - 1);
252 if (joined & E_PMINFO_PKGINFO_JOIN_LOCALIZED_INFO) {
253 strncat(buf2, join_localized_info, MAX_QUERY_LEN - len - 1);
254 len += strlen(join_localized_info);
255 *bind_params = g_list_append(*bind_params, strdup(locale));
257 if (joined & E_PMINFO_PKGINFO_JOIN_PRIVILEGE_INFO) {
258 strncat(buf2, join_privilege_info, MAX_QUERY_LEN - len - 1);
259 len += strlen(join_privilege_info);
261 strncat(buf2, buf, MAX_QUERY_LEN - len - 1);
263 *query = strdup(buf2);
265 return PMINFO_R_ERROR;
270 static void __free_packages(gpointer data)
272 pkgmgrinfo_basic_free_package((package_x *)data);
275 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
282 link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
289 static int __bind_params(sqlite3_stmt *stmt, GList *params)
291 GList *tmp_list = NULL;
295 if (stmt == NULL || params == NULL)
296 return PMINFO_R_EINVAL;
300 ret = sqlite3_bind_text(stmt, ++idx, (char *)tmp_list->data, -1, SQLITE_STATIC);
301 if (ret != SQLITE_OK)
302 return PMINFO_R_ERROR;
303 tmp_list = tmp_list->next;
309 static bool __check_package_storage_status(pkgmgrinfo_filter_x *tmp_filter)
311 GSList *tmp_list = NULL;
312 pkgmgrinfo_node_x *tmp_node = NULL;
315 property = _pminfo_pkginfo_convert_to_prop_bool(PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE);
316 for (tmp_list = tmp_filter->list; tmp_list != NULL;
317 tmp_list = g_slist_next(tmp_list)) {
318 tmp_node = (pkgmgrinfo_node_x *)tmp_list->data;
319 if (property == tmp_node->prop) {
320 if (strcmp(tmp_node->value, "true") == 0)
329 static int _pkginfo_get_packages(uid_t uid, const char *locale,
330 pkgmgrinfo_filter_x *filter, int flag, GHashTable *packages)
332 static const char query_raw[] =
333 "SELECT DISTINCT pi.package, pi.package_version, "
334 "pi.install_location, pi.package_removable, "
335 "pi.package_preload, pi.package_readonly, pi.package_update, "
336 "pi.package_appsetting, pi.package_system, pi.package_type, "
337 "pi.package_size, pi.installed_time, pi.installed_storage, "
338 "pi.storeclient_id, pi.mainapp_id, pi.package_url, "
339 "pi.root_path, pi.csc_path, pi.package_nodisplay, "
340 "pi.package_api_version, pi.package_support_disable, "
341 "pi.package_tep_name, pi.package_zip_mount_file, pi.external_path, "
342 "pi.package_support_mode";
343 static const char query_author[] =
344 ", pi.author_name, pi.author_email, pi.author_href";
345 static const char query_label[] =
347 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
348 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
349 static const char query_icon[] =
351 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
352 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
353 static const char query_description[] =
355 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
356 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
357 static const char query_from_clause[] = " FROM package_info as pi";
358 int ret = PMINFO_R_ERROR;
362 char *tmp_record = NULL;
363 char *constraints = NULL;
364 char query[MAX_QUERY_LEN] = { '\0' };
365 package_x *info = NULL;
366 author_x *author = NULL;
367 GList *bind_params = NULL;
370 pkgmgrinfo_filter_x *tmp_filter = NULL;
371 bool is_check_storage = true;
373 dbpath = getUserPkgParserDBPathUID(uid);
375 return PMINFO_R_ERROR;
377 ret = __open_db(dbpath, &db, SQLITE_OPEN_READONLY);
378 if (ret != SQLITE_OK) {
379 _LOGD("failed to open db: %d", ret);
381 return PMINFO_R_ERROR;
385 if (filter != NULL) {
388 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
389 if (ret != PMINFO_R_OK) {
390 _LOGE("Failed to create filter");
391 return PMINFO_R_ERROR;
395 is_check_storage = __check_package_storage_status(tmp_filter);
397 query_len = strlen(query_raw);
398 snprintf(query, MAX_QUERY_LEN - 1, "%s", query_raw);
399 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
400 strncat(query, query_author, MAX_QUERY_LEN - query_len - 1);
401 query_len += strlen(query_author);
403 if (flag & PMINFO_PKGINFO_GET_LABEL) {
404 strncat(query, query_label, MAX_QUERY_LEN - query_len - 1);
405 query_len += strlen(query_label);
406 bind_params = g_list_append(bind_params, strdup(locale));
408 if (flag & PMINFO_PKGINFO_GET_ICON) {
409 strncat(query, query_icon, MAX_QUERY_LEN - query_len - 1);
410 query_len += strlen(query_icon);
411 bind_params = g_list_append(bind_params, strdup(locale));
413 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
414 strncat(query, query_description, MAX_QUERY_LEN - query_len - 1);
415 query_len += strlen(query_description);
416 bind_params = g_list_append(bind_params, strdup(locale));
419 strncat(query, query_from_clause, MAX_QUERY_LEN - query_len - 1);
420 query_len += strlen(query_from_clause);
422 ret = _get_filtered_query(tmp_filter, locale, uid, &constraints, &bind_params);
423 if (ret != PMINFO_R_OK) {
424 LOGE("Failed to get WHERE clause");
429 strncat(query, constraints, MAX_QUERY_LEN - query_len - 1);
431 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
432 if (ret != SQLITE_OK) {
433 LOGE("prepare failed: %s", sqlite3_errmsg(db));
434 ret = PMINFO_R_ERROR;
438 ret = __bind_params(stmt, bind_params);
439 if (ret != SQLITE_OK) {
440 LOGE("Failed to bind parameters");
444 while (sqlite3_step(stmt) == SQLITE_ROW) {
445 info = calloc(1, sizeof(package_x));
447 LOGE("out of memory");
448 sqlite3_finalize(stmt);
449 sqlite3_close_v2(db);
450 return PMINFO_R_ERROR;
453 _save_column_str(stmt, idx++, &info->package);
454 if (g_hash_table_contains(packages,
455 (gconstpointer)info->package)) {
460 _save_column_str(stmt, idx++, &info->version);
461 _save_column_str(stmt, idx++, &info->installlocation);
462 _save_column_str(stmt, idx++, &info->removable);
463 _save_column_str(stmt, idx++, &info->preload);
464 _save_column_str(stmt, idx++, &info->readonly);
465 _save_column_str(stmt, idx++, &info->update);
466 _save_column_str(stmt, idx++, &info->appsetting);
467 _save_column_str(stmt, idx++, &info->system);
468 _save_column_str(stmt, idx++, &info->type);
469 _save_column_str(stmt, idx++, &info->package_size);
470 _save_column_str(stmt, idx++, &info->installed_time);
471 _save_column_str(stmt, idx++, &info->installed_storage);
472 _save_column_str(stmt, idx++, &info->storeclient_id);
473 _save_column_str(stmt, idx++, &info->mainapp_id);
474 _save_column_str(stmt, idx++, &info->package_url);
475 _save_column_str(stmt, idx++, &info->root_path);
476 _save_column_str(stmt, idx++, &info->csc_path);
477 _save_column_str(stmt, idx++, &info->nodisplay_setting);
478 _save_column_str(stmt, idx++, &info->api_version);
479 _save_column_str(stmt, idx++, &info->support_disable);
480 _save_column_str(stmt, idx++, &info->tep_name);
481 _save_column_str(stmt, idx++, &info->zip_mount_file);
482 _save_column_str(stmt, idx++, &info->external_path);
483 _save_column_str(stmt, idx++, &info->support_mode);
484 info->for_all_users =
485 strdup((uid != GLOBAL_USER) ? "false" : "true");
487 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
488 /* TODO : author should be retrieved at package_localized_info */
489 author = calloc(1, sizeof(author_x));
490 if (author == NULL) {
491 pkgmgrinfo_basic_free_package(info);
492 sqlite3_finalize(stmt);
493 sqlite3_close_v2(db);
494 return PMINFO_R_ERROR;
496 _save_column_str(stmt, idx++, &author->text);
497 _save_column_str(stmt, idx++, &author->email);
498 _save_column_str(stmt, idx++, &author->href);
499 info->author = g_list_append(info->author, author);
502 if (flag & PMINFO_PKGINFO_GET_LABEL) {
504 _save_column_str(stmt, idx++, &tmp_record);
506 if (_add_label_info_into_list(locale, tmp_record, &info->label)) {
507 pkgmgrinfo_basic_free_package(info);
508 sqlite3_finalize(stmt);
509 sqlite3_close_v2(db);
510 return PMINFO_R_ERROR;
514 if (flag & PMINFO_PKGINFO_GET_ICON) {
516 _save_column_str(stmt, idx++, &tmp_record);
517 if (_add_icon_info_into_list(locale, tmp_record, &info->icon)) {
518 pkgmgrinfo_basic_free_package(info);
519 sqlite3_finalize(stmt);
520 sqlite3_close_v2(db);
521 return PMINFO_R_ERROR;
525 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
527 _save_column_str(stmt, idx++, &tmp_record);
528 if (_pkginfo_add_description_info_into_list(locale, tmp_record,
529 &info->description)) {
530 pkgmgrinfo_basic_free_package(info);
531 sqlite3_finalize(stmt);
532 sqlite3_close_v2(db);
533 return PMINFO_R_ERROR;
537 if (flag & PMINFO_PKGINFO_GET_PRIVILEGE) {
538 if (_pkginfo_get_privilege(db, info->package,
539 &info->privileges)) {
540 pkgmgrinfo_basic_free_package(info);
541 sqlite3_finalize(stmt);
542 sqlite3_close_v2(db);
543 return 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 return PMINFO_R_ERROR;
612 if (__check_disable_filter_exist(tmp_filter) == false)
613 pkgmgrinfo_pkginfo_filter_add_bool(tmp_filter,
614 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
616 ret = _pkginfo_get_packages(uid, locale, tmp_filter, flag, list);
617 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
618 ret = _pkginfo_get_packages(GLOBAL_USER, locale, tmp_filter,
621 if (ret != PMINFO_R_OK) {
622 g_hash_table_destroy(list);
625 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
626 return PMINFO_R_ERROR;
629 g_hash_table_iter_init(&iter, list);
630 while (g_hash_table_iter_next(&iter, NULL, &value)) {
631 pkg = (package_x *)value;
634 info.locale = locale;
635 if (pkg_list_cb(&info, user_data) < 0)
639 g_hash_table_destroy(list);
643 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
648 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
649 pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
654 pkgmgr_pkginfo_x *info;
656 if (pkgid == NULL || filter == NULL || handle == NULL) {
657 LOGE("invalid parameter");
658 return PMINFO_R_EINVAL;
661 locale = _get_system_locale();
663 return PMINFO_R_ERROR;
665 list = g_hash_table_new(g_str_hash, g_str_equal);
668 return PMINFO_R_ERROR;
671 ret = _pkginfo_get_packages(uid, locale, filter,
672 PMINFO_PKGINFO_GET_ALL, list);
673 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
674 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
675 PMINFO_PKGINFO_GET_ALL, list);
677 if (!g_hash_table_size(list)) {
678 _LOGI("pkginfo for [%s] is not existed for user [%d]",
680 g_hash_table_destroy(list);
682 return PMINFO_R_ENOENT;
685 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
687 _LOGE("out of memory");
688 g_hash_table_destroy(list);
690 return PMINFO_R_ERROR;
694 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
695 info->locale = locale;
697 /* just free list only */
698 g_hash_table_destroy(list);
705 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
706 pkgmgrinfo_pkginfo_h *handle)
709 pkgmgrinfo_pkginfo_filter_h filter;
711 if (pkgid == NULL || handle == NULL) {
712 LOGE("invalid parameter");
713 return PMINFO_R_EINVAL;
716 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
717 if (ret != PMINFO_R_OK)
720 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
721 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
722 if (ret != PMINFO_R_OK) {
723 pkgmgrinfo_pkginfo_filter_destroy(filter);
724 return PMINFO_R_ERROR;
727 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
728 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
729 if (ret != PMINFO_R_OK) {
730 pkgmgrinfo_pkginfo_filter_destroy(filter);
731 return PMINFO_R_ERROR;
734 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
735 pkgmgrinfo_pkginfo_filter_destroy(filter);
740 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
741 pkgmgrinfo_pkginfo_h *handle)
743 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
746 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
747 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
752 pkgmgrinfo_pkginfo_filter_h filter;
753 pkgmgr_pkginfo_x *info;
755 if (pkgid == NULL || handle == NULL) {
756 LOGE("invalid parameter");
757 return PMINFO_R_EINVAL;
760 locale = _get_system_locale();
762 return PMINFO_R_ERROR;
764 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
765 if (ret != PMINFO_R_OK) {
770 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
771 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
772 if (ret != PMINFO_R_OK) {
773 pkgmgrinfo_pkginfo_filter_destroy(filter);
775 return PMINFO_R_ERROR;
778 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
779 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
780 if (ret != PMINFO_R_OK) {
781 pkgmgrinfo_pkginfo_filter_destroy(filter);
783 return PMINFO_R_ERROR;
786 list = g_hash_table_new(g_str_hash, g_str_equal);
788 pkgmgrinfo_pkginfo_filter_destroy(filter);
790 return PMINFO_R_ERROR;
793 ret = _pkginfo_get_packages(uid, locale, filter,
794 PMINFO_PKGINFO_GET_ALL, list);
795 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
796 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
797 PMINFO_PKGINFO_GET_ALL, list);
799 pkgmgrinfo_pkginfo_filter_destroy(filter);
800 if (ret != PMINFO_R_OK) {
801 g_hash_table_destroy(list);
806 if (!g_hash_table_size(list)) {
807 _LOGI("disabled pkginfo for [%s] is not existed for user [%d]",
809 g_hash_table_destroy(list);
811 return PMINFO_R_ENOENT;
814 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
816 _LOGE("out of memory");
817 g_hash_table_destroy(list);
819 return PMINFO_R_ERROR;
823 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
824 info->locale = locale;
826 /* just free list only */
827 g_hash_table_destroy(list);
834 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
835 pkgmgrinfo_pkginfo_h *handle)
839 pkgmgrinfo_pkginfo_filter_h filter;
841 if (pkgid == NULL || handle == NULL) {
842 LOGE("invalid parameter");
843 return PMINFO_R_EINVAL;
846 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
847 if (ret != PMINFO_R_OK)
850 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
851 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
852 if (ret != PMINFO_R_OK) {
853 pkgmgrinfo_pkginfo_filter_destroy(filter);
854 return PMINFO_R_ERROR;
857 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
858 PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
859 if (ret != PMINFO_R_OK) {
860 pkgmgrinfo_pkginfo_filter_destroy(filter);
861 return PMINFO_R_ERROR;
864 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
865 pkgmgrinfo_pkginfo_filter_destroy(filter);
870 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
871 pkgmgrinfo_pkginfo_h *handle)
873 return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
877 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
878 pkgmgrinfo_pkginfo_h *handle)
880 return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
883 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
884 int flag, void *user_data, uid_t uid)
887 pkgmgrinfo_pkginfo_filter_h filter;
889 if (pkg_list_cb == NULL) {
890 LOGE("invalid parameter");
891 return PMINFO_R_EINVAL;
894 /* create an empty filter */
895 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
896 if (ret != PMINFO_R_OK)
899 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
900 pkg_list_cb, user_data);
902 pkgmgrinfo_pkginfo_filter_destroy(filter);
907 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
908 int flag, void *user_data)
910 return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
911 user_data, _getuid());
914 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
915 void *user_data, uid_t uid)
918 pkgmgrinfo_pkginfo_filter_h filter;
920 if (pkg_list_cb == NULL) {
921 LOGE("invalid parameter");
922 return PMINFO_R_EINVAL;
925 /* create an empty filter */
926 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
927 if (ret != PMINFO_R_OK)
930 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
931 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
933 pkgmgrinfo_pkginfo_filter_destroy(filter);
938 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
941 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
945 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
946 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
949 pkgmgrinfo_pkginfo_filter_h filter;
951 if (pkg_list_cb == NULL) {
952 LOGE("invalid parameter");
953 return PMINFO_R_EINVAL;
956 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
957 if (ret != PMINFO_R_OK)
960 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
961 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
962 if (ret != PMINFO_R_OK) {
963 pkgmgrinfo_pkginfo_filter_destroy(filter);
964 return PMINFO_R_ERROR;
967 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
968 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
970 pkgmgrinfo_pkginfo_filter_destroy(filter);
975 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
978 return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
982 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
984 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
986 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
987 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
989 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
990 return PMINFO_R_ERROR;
992 *pkg_name = (char *)info->pkg_info->package;
997 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
999 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1001 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1002 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1004 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
1005 return PMINFO_R_ERROR;
1007 *pkgid = (char *)info->pkg_info->package;
1012 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
1014 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1016 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1017 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1019 if (info->pkg_info == NULL)
1020 return PMINFO_R_ERROR;
1022 if (info->pkg_info->type == NULL)
1025 *type = (char *)info->pkg_info->type;
1030 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
1032 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1034 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1035 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1037 if (info->pkg_info == NULL)
1038 return PMINFO_R_ERROR;
1040 if (info->pkg_info->version == NULL)
1043 *version = (char *)info->pkg_info->version;
1048 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
1050 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1052 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1053 retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1055 if (info->pkg_info == NULL)
1056 return PMINFO_R_ERROR;
1058 if (info->pkg_info->api_version == NULL)
1061 *api_version = (char *)info->pkg_info->api_version;
1066 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
1068 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1070 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1071 retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1073 if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
1074 return PMINFO_R_ERROR;
1076 *tep_name = (char *)info->pkg_info->tep_name;
1081 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
1083 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1085 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1086 retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1088 if (info->pkg_info == NULL)
1089 return PMINFO_R_ERROR;
1091 if (info->pkg_info->zip_mount_file == NULL)
1092 *zip_mount_file = "";
1094 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
1099 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
1102 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1104 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1105 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1107 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1108 return PMINFO_R_ERROR;
1110 val = (char *)info->pkg_info->installlocation;
1111 if (strcmp(val, "internal-only") == 0)
1112 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
1113 else if (strcmp(val, "prefer-external") == 0)
1114 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
1116 *location = PMINFO_INSTALL_LOCATION_AUTO;
1121 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
1123 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1126 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1127 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1129 if (info->pkg_info == NULL)
1130 return PMINFO_R_ERROR;
1132 if (info->pkg_info->package_size == NULL) {
1135 _LOGE("out of memory");
1136 return PMINFO_R_ERROR;
1138 info->pkg_info->package_size = temp;
1142 *size = atoi((char *)info->pkg_info->package_size);
1147 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
1150 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1152 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1153 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1155 if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
1156 return PMINFO_R_ERROR;
1158 ptr = (icon_x *)info->pkg_info->icon->data;
1160 return PMINFO_R_ERROR;
1162 /* TODO : should we return empty string if there was no icon? */
1163 if (ptr->text == NULL)
1171 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
1174 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1176 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1177 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1179 if (info->pkg_info == NULL || info->pkg_info->label == NULL)
1180 return PMINFO_R_ERROR;
1182 ptr = (label_x *)info->pkg_info->label->data;
1184 return PMINFO_R_ERROR;
1186 /* TODO : should we return empty string if there was no label? */
1187 if (ptr->text == NULL)
1195 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
1198 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1200 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1201 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1203 if (info->pkg_info == NULL || info->pkg_info->description == NULL)
1204 return PMINFO_R_ERROR;
1206 ptr = (description_x *)info->pkg_info->description->data;
1208 return PMINFO_R_ERROR;
1210 if (ptr->text == NULL)
1213 *description = (char *)ptr->text;
1218 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
1220 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1223 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1224 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1226 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1227 return PMINFO_R_ERROR;
1229 author = (author_x *)info->pkg_info->author->data;
1231 return PMINFO_R_ERROR;
1233 if (author->text == NULL)
1236 *author_name = (char *)author->text;
1241 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
1243 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1246 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1247 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1249 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1250 return PMINFO_R_ERROR;
1252 author = (author_x *)info->pkg_info->author->data;
1254 return PMINFO_R_ERROR;
1256 if (author->email == NULL)
1259 *author_email = (char *)author->email;
1264 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
1266 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1269 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1270 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1272 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1273 return PMINFO_R_ERROR;
1275 author = (author_x *)info->pkg_info->author->data;
1277 return PMINFO_R_ERROR;
1279 if (author->href == NULL)
1282 *author_href = (char *)author->href;
1287 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
1289 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1291 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1292 retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1294 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
1295 return PMINFO_R_ERROR;
1297 if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
1298 *storage = PMINFO_INTERNAL_STORAGE;
1299 else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
1300 *storage = PMINFO_EXTERNAL_STORAGE;
1302 return PMINFO_R_ERROR;
1307 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
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(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1314 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
1315 return PMINFO_R_ERROR;
1317 *installed_time = atoi(info->pkg_info->installed_time);
1322 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
1324 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1326 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1327 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1329 if (info->pkg_info == NULL)
1330 return PMINFO_R_ERROR;
1332 if (info->pkg_info->storeclient_id == NULL)
1333 *storeclientid = "";
1335 *storeclientid = (char *)info->pkg_info->storeclient_id;
1340 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
1342 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1344 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1345 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1347 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
1348 return PMINFO_R_ERROR;
1350 *mainappid = (char *)info->pkg_info->mainapp_id;
1355 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
1357 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1359 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1360 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1362 if (info->pkg_info == NULL)
1363 return PMINFO_R_ERROR;
1365 if (info->pkg_info->package_url == NULL)
1368 *url = (char *)info->pkg_info->package_url;
1373 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
1375 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1377 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1378 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1380 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
1381 return PMINFO_R_ERROR;
1383 *path = (char *)info->pkg_info->root_path;
1388 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
1390 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1392 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1393 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1395 if (info->pkg_info == NULL)
1396 return PMINFO_R_ERROR;
1398 if (info->pkg_info->csc_path == NULL)
1401 *path = (char *)info->pkg_info->csc_path;
1406 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
1408 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1409 retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1411 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1412 if (info->pkg_info->support_mode)
1413 *support_mode = atoi(info->pkg_info->support_mode);
1420 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
1422 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1423 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1425 #if 0 /* smack issue occured, check later */
1427 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
1428 if (pkgid == NULL) {
1429 _LOGD("invalid func parameters\n");
1430 return PMINFO_R_ERROR;
1432 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
1435 char app_mmc_path[FILENAME_MAX] = { 0, };
1436 char app_dir_path[FILENAME_MAX] = { 0, };
1437 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
1438 snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
1439 snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
1440 snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
1442 /*check whether application is in external memory or not */
1443 fp = fopen(app_mmc_path, "r");
1445 _LOGD(" app path in external memory not accesible\n");
1450 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
1454 /*check whether application is in internal or not */
1456 _LOGD(" app path in internal memory not accesible\n");
1458 return PMINFO_R_ERROR;
1461 /*check whether the application is installed in SD card
1462 but SD card is not present*/
1463 fp = fopen(app_mmc_internal_path, "r");
1466 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1470 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1475 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1482 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1484 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1486 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1487 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1489 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1490 return PMINFO_R_ERROR;
1492 *removable = _get_bool_value(info->pkg_info->removable);
1497 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1500 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1502 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1503 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1505 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1506 return PMINFO_R_ERROR;
1508 val = (char *)info->pkg_info->installlocation;
1509 if (strcmp(val, "internal-only") == 0)
1511 else if (strcmp(val, "prefer-external") == 0)
1519 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1521 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1523 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1524 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1526 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1527 return PMINFO_R_ERROR;
1529 *preload = _get_bool_value(info->pkg_info->preload);
1534 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1536 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1538 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1539 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1541 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1542 return PMINFO_R_ERROR;
1544 *system = _get_bool_value(info->pkg_info->system);
1549 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1551 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1553 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1554 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1556 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1557 return PMINFO_R_ERROR;
1559 *readonly = _get_bool_value(info->pkg_info->readonly);
1564 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1566 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1568 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1569 retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1571 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1572 return PMINFO_R_ERROR;
1574 *update = _get_bool_value(info->pkg_info->update);
1579 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1581 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1583 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1584 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1586 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1587 return PMINFO_R_ERROR;
1589 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1594 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1596 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1598 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1599 retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1601 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1602 return PMINFO_R_ERROR;
1604 *global = _get_bool_value(info->pkg_info->for_all_users);
1609 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1611 return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1614 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1616 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1618 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1620 __cleanup_pkginfo(info);
1625 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1627 pkgmgrinfo_filter_x *filter;
1629 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1631 filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1632 if (filter == NULL) {
1633 _LOGE("Out of Memory!!!");
1634 return PMINFO_R_ERROR;
1642 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1644 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1646 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1649 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1650 g_slist_free(filter->list);
1658 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1659 const char *property, const int value)
1661 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1665 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1666 pkgmgrinfo_node_x *node;
1668 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1669 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1671 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1672 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1673 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1674 _LOGE("Invalid Integer Property\n");
1675 return PMINFO_R_EINVAL;
1677 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1679 _LOGE("Out of Memory!!!\n");
1680 return PMINFO_R_ERROR;
1682 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1683 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1685 _LOGE("Out of Memory\n");
1687 return PMINFO_R_ERROR;
1691 /*If API is called multiple times for same property, we should override the previous values.
1692 Last value set will be used for filtering.*/
1693 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1695 filter->list = g_slist_delete_link(filter->list, link);
1696 filter->list = g_slist_append(filter->list, (gpointer)node);
1701 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1702 const char *property, const bool value)
1707 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1708 pkgmgrinfo_node_x *node;
1710 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1711 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1713 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1714 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1715 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1716 _LOGE("Invalid Boolean Property\n");
1717 return PMINFO_R_EINVAL;
1719 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1721 _LOGE("Out of Memory!!!\n");
1722 return PMINFO_R_ERROR;
1725 val = strndup("true", 4);
1727 val = strndup("false", 5);
1729 _LOGE("Out of Memory\n");
1731 return PMINFO_R_ERROR;
1735 /*If API is called multiple times for same property, we should override the previous values.
1736 Last value set will be used for filtering.*/
1737 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1739 filter->list = g_slist_delete_link(filter->list, link);
1740 filter->list = g_slist_append(filter->list, (gpointer)node);
1745 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1746 const char *property, const char *value)
1751 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1752 pkgmgrinfo_node_x *node;
1754 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1755 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1756 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1758 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1759 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1760 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1761 _LOGE("Invalid String Property\n");
1762 return PMINFO_R_EINVAL;
1764 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1766 _LOGE("Out of Memory!!!\n");
1767 return PMINFO_R_ERROR;
1769 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1770 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1771 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1772 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1773 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1774 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1775 else if (strcmp(value, "installed_internal") == 0)
1776 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1777 else if (strcmp(value, "installed_external") == 0)
1778 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1780 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1782 _LOGE("Out of Memory\n");
1784 return PMINFO_R_ERROR;
1788 /*If API is called multiple times for same property, we should override the previous values.
1789 Last value set will be used for filtering.*/
1790 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1792 filter->list = g_slist_delete_link(filter->list, link);
1793 filter->list = g_slist_append(filter->list, (gpointer)node);
1798 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1802 GHashTable *list = NULL;
1804 if (handle == NULL || count == NULL) {
1805 _LOGE("invalid parameter");
1806 return PMINFO_R_EINVAL;
1809 locale = _get_system_locale();
1811 return PMINFO_R_ERROR;
1813 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1817 return PMINFO_R_ERROR;
1820 if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1821 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1822 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1823 if (ret != PMINFO_R_OK) {
1825 return PMINFO_R_ERROR;
1829 ret = _pkginfo_get_packages(uid, locale,
1830 (pkgmgrinfo_filter_x *)handle, 0, list);
1831 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
1832 ret = _pkginfo_get_packages(GLOBAL_USER, locale, handle, 0,
1835 if (ret != PMINFO_R_OK) {
1836 g_hash_table_destroy(list);
1838 return PMINFO_R_ERROR;
1841 *count = g_hash_table_size(list);
1843 g_hash_table_destroy(list);
1849 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1851 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1854 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1855 pkgmgrinfo_pkginfo_filter_h handle,
1856 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1858 if (handle == NULL || pkg_cb == NULL) {
1859 LOGE("invalid parameter");
1860 return PMINFO_R_EINVAL;
1863 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1864 PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1867 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1868 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1870 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1873 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1874 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1876 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1877 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1879 privilege_x *privilege;
1881 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1883 if (info->pkg_info == NULL)
1884 return PMINFO_R_ERROR;
1886 for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1887 privilege = (privilege_x *)tmp->data;
1888 if (privilege == NULL)
1890 ret = privilege_func(privilege->value, user_data);
1897 int __compare_package_version(const char *version, int *major,
1898 int *minor, int *macro, int *nano)
1900 char *version_temp = NULL;
1901 char *major_str = NULL;
1902 char *minor_str = NULL;
1903 char *macro_str = NULL;
1904 char *nano_str = NULL;
1905 char *save_str = NULL;
1907 if (version == NULL || major == NULL || minor == NULL ||
1908 macro == NULL || nano == NULL) {
1909 return PMINFO_R_EINVAL;
1912 version_temp = strdup(version);
1913 if (version_temp == NULL) {
1914 LOGE("Out of memory");
1915 return PMINFO_R_ERROR;
1918 major_str = strtok_r(version_temp, ".", &save_str);
1919 if (major_str == NULL) {
1920 _LOGE("major version is NULL");
1922 return PMINFO_R_ERROR;
1925 minor_str = strtok_r(NULL, ".", &save_str);
1926 if (minor_str == NULL) {
1927 _LOGE("minor version is NULL");
1929 return PMINFO_R_ERROR;
1932 *major = atoi(major_str);
1933 *minor = atoi(minor_str);
1936 macro_str = strtok_r(NULL, ".", &save_str);
1937 if (macro_str == NULL) {
1938 _LOGD("macro version is NULL");
1940 *macro = atoi(macro_str);
1941 nano_str = strtok_r(NULL, ".", &save_str);
1943 *nano = atoi(nano_str);
1944 _LOGD("nano version exists");
1947 _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1948 " macro = [%d], nano = [%d]", version, *major,
1949 *minor, *macro, *nano);
1956 API int pkgmgrinfo_compare_package_version(const char *current_version,
1957 const char *target_version,
1958 pkgmgrinfo_version_compare_type *res)
1961 int current_version_major = 0;
1962 int current_version_minor = 0;
1963 int current_version_macro = 0;
1964 int current_version_nano = 0;
1965 int target_version_major = 0;
1966 int target_version_minor = 0;
1967 int target_version_macro = 0;
1968 int target_version_nano = 0;
1970 if (current_version == NULL || target_version == NULL ||
1972 _LOGE("Invalid parameter");
1973 return PMINFO_R_EINVAL;
1976 ret = __compare_package_version(target_version,
1977 &target_version_major, &target_version_minor,
1978 &target_version_macro, &target_version_nano);
1980 _LOGE("Failed to compare target version(%d)", ret);
1981 return PMINFO_R_ERROR;
1984 ret = __compare_package_version(current_version,
1985 ¤t_version_major, ¤t_version_minor,
1986 ¤t_version_macro, ¤t_version_nano);
1988 _LOGE("Failed to compare current version(%d)", ret);
1989 return PMINFO_R_ERROR;
1992 _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
1993 target_version_minor, target_version_macro,
1994 target_version_nano, current_version_major,
1995 current_version_minor, current_version_macro,
1996 target_version_nano);
1998 if (target_version_major > current_version_major)
1999 *res = PMINFO_VERSION_NEW;
2000 else if (target_version_major < current_version_major)
2001 *res = PMINFO_VERSION_OLD;
2002 else if (target_version_minor > current_version_minor)
2003 *res = PMINFO_VERSION_NEW;
2004 else if (target_version_minor < current_version_minor)
2005 *res = PMINFO_VERSION_OLD;
2006 else if (target_version_macro > current_version_macro)
2007 *res = PMINFO_VERSION_NEW;
2008 else if (target_version_macro < current_version_macro)
2009 *res = PMINFO_VERSION_OLD;
2010 else if (target_version_nano > current_version_nano)
2011 *res = PMINFO_VERSION_NEW;
2012 else if (target_version_nano < current_version_nano)
2013 *res = PMINFO_VERSION_OLD;
2015 *res = PMINFO_VERSION_SAME;